]> git.ipfire.org Git - thirdparty/iproute2.git/commitdiff
utils: Add helper to map string to unsigned int
authorParav Pandit <parav@nvidia.com>
Wed, 10 Feb 2021 18:34:44 +0000 (20:34 +0200)
committerDavid Ahern <dsahern@kernel.org>
Thu, 11 Feb 2021 16:09:10 +0000 (09:09 -0700)
In subsequent patch need to map a string to a unsigned int.
Hence, add an API to map a string to unsigned int.

Signed-off-by: Parav Pandit <parav@nvidia.com>
Signed-off-by: David Ahern <dsahern@kernel.org>
include/utils.h
lib/utils.c

index 9b76c92a948390eecd45fc835971f4e2a380473b..b29c3798f898786f326cde87f55464fb251c7661 100644 (file)
@@ -342,10 +342,12 @@ int parse_mapping(int *argcp, char ***argvp, bool allow_all,
 
 struct str_num_map {
        const char *str;
-       int num;
+       unsigned int num;
 };
 
 int str_map_lookup_str(const struct str_num_map *map, const char *needle);
+const char *str_map_lookup_uint(const struct str_num_map *map,
+                               unsigned int val);
 const char *str_map_lookup_u16(const struct str_num_map *map, uint16_t val);
 const char *str_map_lookup_u8(const struct str_num_map *map, uint8_t val);
 
index cc6d0e34896c66f543686f937cdcf736442ae9a2..633f635908a0e67f9218ce3a7839057e099e2bdb 100644 (file)
@@ -1953,9 +1953,22 @@ int str_map_lookup_str(const struct str_num_map *map, const char *needle)
        return -EINVAL;
 }
 
+const char *str_map_lookup_uint(const struct str_num_map *map, unsigned int val)
+{
+       unsigned int num = val;
+
+       while (map && map->str) {
+               if (num == map->num)
+                       return map->str;
+
+               map++;
+       }
+       return NULL;
+}
+
 const char *str_map_lookup_u16(const struct str_num_map *map, uint16_t val)
 {
-       int num = val;
+       unsigned int num = val;
 
        while (map && map->str) {
                if (num == map->num)
@@ -1968,7 +1981,7 @@ const char *str_map_lookup_u16(const struct str_num_map *map, uint16_t val)
 
 const char *str_map_lookup_u8(const struct str_num_map *map, uint8_t val)
 {
-       int num = val;
+       unsigned int num = val;
 
        while (map && map->str) {
                if (num == map->num)