summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric W. Biederman <ebiederm@xmission.com>2017-10-31 16:53:09 -0500
committerEric W. Biederman <ebiederm@xmission.com>2017-10-31 17:23:13 -0500
commitece66133979b211324cc6aff9285889b425243d2 (patch)
treec759c36d2efc544743c9e2f39c2441a42403c752
parentd5e7b3c5f51fc6d34e12b6d87bfd30ab277c4625 (diff)
userns: Make map_id_down a wrapper for map_id_range_down
There is no good reason for this code duplication, the number of cache line accesses not the number of instructions are the bottleneck in this code. Therefore simplify maintenance by removing unnecessary code. Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
-rw-r--r--kernel/user_namespace.c38
1 files changed, 1 insertions, 37 deletions
diff --git a/kernel/user_namespace.c b/kernel/user_namespace.c
index 4f7e357ac1e2..1d0298870ee3 100644
--- a/kernel/user_namespace.c
+++ b/kernel/user_namespace.c
@@ -313,45 +313,9 @@ static u32 map_id_range_down(struct uid_gid_map *map, u32 id, u32 count)
return id;
}
-/**
- * map_id_down_base - Find idmap via binary search in static extent array.
- * Can only be called if number of mappings is equal or less than
- * UID_GID_MAP_MAX_BASE_EXTENTS.
- */
-static struct uid_gid_extent *
-map_id_down_base(unsigned extents, struct uid_gid_map *map, u32 id)
-{
- unsigned idx;
- u32 first, last;
-
- /* Find the matching extent */
- for (idx = 0; idx < extents; idx++) {
- first = map->extent[idx].first;
- last = first + map->extent[idx].count - 1;
- if (id >= first && id <= last)
- return &map->extent[idx];
- }
- return NULL;
-}
-
static u32 map_id_down(struct uid_gid_map *map, u32 id)
{
- struct uid_gid_extent *extent;
- unsigned extents = map->nr_extents;
- smp_rmb();
-
- if (extents <= UID_GID_MAP_MAX_BASE_EXTENTS)
- extent = map_id_down_base(extents, map, id);
- else
- extent = map_id_range_down_max(extents, map, id, 1);
-
- /* Map the id or note failure */
- if (extent)
- id = (id - extent->first) + extent->lower_first;
- else
- id = (u32) -1;
-
- return id;
+ return map_id_range_down(map, id, 1);
}
/**