perf tools: Use kmod_path__parse in map_groups__set_modules_path_dir
authorJiri Olsa <jolsa@kernel.org>
Thu, 12 Feb 2015 21:20:01 +0000 (22:20 +0100)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Mon, 23 Mar 2015 14:43:25 +0000 (11:43 -0300)
Replacing the file name parsing with kmod_path__parse
and moving the dso update into new separate function.

Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Acked-by: Namhyung Kim <namhyung@kernel.org>
Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/n/tip-q0ed76ajcyoaofotntrg5sla@git.kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/machine.c

index eb95b88..6ca61a3 100644 (file)
@@ -851,6 +851,39 @@ static char *get_kernel_version(const char *root_dir)
        return strdup(name);
 }
 
+static bool is_kmod_dso(struct dso *dso)
+{
+       return dso->symtab_type == DSO_BINARY_TYPE__SYSTEM_PATH_KMODULE ||
+              dso->symtab_type == DSO_BINARY_TYPE__GUEST_KMODULE;
+}
+
+static int map_groups__set_module_path(struct map_groups *mg, const char *path,
+                                      struct kmod_path *m)
+{
+       struct map *map;
+       char *long_name;
+
+       map = map_groups__find_by_name(mg, MAP__FUNCTION, m->name);
+       if (map == NULL)
+               return 0;
+
+       long_name = strdup(path);
+       if (long_name == NULL)
+               return -ENOMEM;
+
+       dso__set_long_name(map->dso, long_name, true);
+       dso__kernel_module_get_build_id(map->dso, "");
+
+       /*
+        * Full name could reveal us kmod compression, so
+        * we need to update the symtab_type if needed.
+        */
+       if (m->comp && is_kmod_dso(map->dso))
+               map->dso->symtab_type++;
+
+       return 0;
+}
+
 static int map_groups__set_modules_path_dir(struct map_groups *mg,
                                const char *dir_name, int depth)
 {
@@ -889,35 +922,19 @@ static int map_groups__set_modules_path_dir(struct map_groups *mg,
                        if (ret < 0)
                                goto out;
                } else {
-                       char *dot = strrchr(dent->d_name, '.'),
-                            dso_name[PATH_MAX];
-                       struct map *map;
-                       char *long_name;
+                       struct kmod_path m;
 
-                       if (dot == NULL)
-                               continue;
+                       ret = kmod_path__parse_name(&m, dent->d_name);
+                       if (ret)
+                               goto out;
 
-                       /* On some system, modules are compressed like .ko.gz */
-                       if (is_supported_compression(dot + 1) &&
-                           is_kmodule_extension(dot - 2))
-                               dot -= 3;
+                       if (m.kmod)
+                               ret = map_groups__set_module_path(mg, path, &m);
 
-                       snprintf(dso_name, sizeof(dso_name), "[%.*s]",
-                                (int)(dot - dent->d_name), dent->d_name);
+                       free(m.name);
 
-                       strxfrchar(dso_name, '-', '_');
-                       map = map_groups__find_by_name(mg, MAP__FUNCTION,
-                                                      dso_name);
-                       if (map == NULL)
-                               continue;
-
-                       long_name = strdup(path);
-                       if (long_name == NULL) {
-                               ret = -1;
+                       if (ret)
                                goto out;
-                       }
-                       dso__set_long_name(map->dso, long_name, true);
-                       dso__kernel_module_get_build_id(map->dso, "");
                }
        }