提交 07bc5c69 编写于 作者: W Wang Nan 提交者: Arnaldo Carvalho de Melo

perf tools: Make fetch_kernel_version() publicly available

There are 2 places in llvm-utils.c which find kernel version information
through uname. This patch extracts the uname related code into a
fetch_kernel_version() function and puts it into util.h so it can be
reused.
Signed-off-by: NWang Nan <wangnan0@huawei.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Zefan Li <lizefan@huawei.com>
Cc: pi3orama@163.com
Link: http://lkml.kernel.org/r/1446818135-87310-1-git-send-email-wangnan0@huawei.comSigned-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
上级 45825d8a
...@@ -4,7 +4,6 @@ ...@@ -4,7 +4,6 @@
*/ */
#include <stdio.h> #include <stdio.h>
#include <sys/utsname.h>
#include "util.h" #include "util.h"
#include "debug.h" #include "debug.h"
#include "llvm-utils.h" #include "llvm-utils.h"
...@@ -216,18 +215,19 @@ static int detect_kbuild_dir(char **kbuild_dir) ...@@ -216,18 +215,19 @@ static int detect_kbuild_dir(char **kbuild_dir)
const char *suffix_dir = ""; const char *suffix_dir = "";
char *autoconf_path; char *autoconf_path;
struct utsname utsname;
int err; int err;
if (!test_dir) { if (!test_dir) {
err = uname(&utsname); /* _UTSNAME_LENGTH is 65 */
if (err) { char release[128];
pr_warning("uname failed: %s\n", strerror(errno));
err = fetch_kernel_version(NULL, release,
sizeof(release));
if (err)
return -EINVAL; return -EINVAL;
}
test_dir = utsname.release; test_dir = release;
prefix_dir = "/lib/modules/"; prefix_dir = "/lib/modules/";
suffix_dir = "/build"; suffix_dir = "/build";
} }
...@@ -325,38 +325,18 @@ get_kbuild_opts(char **kbuild_dir, char **kbuild_include_opts) ...@@ -325,38 +325,18 @@ get_kbuild_opts(char **kbuild_dir, char **kbuild_include_opts)
pr_debug("include option is set to %s\n", *kbuild_include_opts); pr_debug("include option is set to %s\n", *kbuild_include_opts);
} }
static unsigned long
fetch_kernel_version(void)
{
struct utsname utsname;
int version, patchlevel, sublevel, err;
if (uname(&utsname))
return 0;
err = sscanf(utsname.release, "%d.%d.%d",
&version, &patchlevel, &sublevel);
if (err != 3) {
pr_debug("Unablt to get kernel version from uname '%s'\n",
utsname.release);
return 0;
}
return (version << 16) + (patchlevel << 8) + sublevel;
}
int llvm__compile_bpf(const char *path, void **p_obj_buf, int llvm__compile_bpf(const char *path, void **p_obj_buf,
size_t *p_obj_buf_sz) size_t *p_obj_buf_sz)
{ {
size_t obj_buf_sz;
void *obj_buf = NULL;
int err, nr_cpus_avail; int err, nr_cpus_avail;
char clang_path[PATH_MAX], nr_cpus_avail_str[64]; unsigned int kernel_version;
char linux_version_code_str[64]; char linux_version_code_str[64];
const char *clang_opt = llvm_param.clang_opt; const char *clang_opt = llvm_param.clang_opt;
const char *template = llvm_param.clang_bpf_cmd_template; char clang_path[PATH_MAX], nr_cpus_avail_str[64];
char *kbuild_dir = NULL, *kbuild_include_opts = NULL; char *kbuild_dir = NULL, *kbuild_include_opts = NULL;
void *obj_buf = NULL; const char *template = llvm_param.clang_bpf_cmd_template;
size_t obj_buf_sz;
if (!template) if (!template)
template = CLANG_BPF_CMD_DEFAULT_TEMPLATE; template = CLANG_BPF_CMD_DEFAULT_TEMPLATE;
...@@ -388,8 +368,11 @@ int llvm__compile_bpf(const char *path, void **p_obj_buf, ...@@ -388,8 +368,11 @@ int llvm__compile_bpf(const char *path, void **p_obj_buf,
snprintf(nr_cpus_avail_str, sizeof(nr_cpus_avail_str), "%d", snprintf(nr_cpus_avail_str, sizeof(nr_cpus_avail_str), "%d",
nr_cpus_avail); nr_cpus_avail);
if (fetch_kernel_version(&kernel_version, NULL, 0))
kernel_version = 0;
snprintf(linux_version_code_str, sizeof(linux_version_code_str), snprintf(linux_version_code_str, sizeof(linux_version_code_str),
"0x%lx", fetch_kernel_version()); "0x%x", kernel_version);
force_set_env("NR_CPUS", nr_cpus_avail_str); force_set_env("NR_CPUS", nr_cpus_avail_str);
force_set_env("LINUX_VERSION_CODE", linux_version_code_str); force_set_env("LINUX_VERSION_CODE", linux_version_code_str);
......
...@@ -3,6 +3,7 @@ ...@@ -3,6 +3,7 @@
#include "debug.h" #include "debug.h"
#include <api/fs/fs.h> #include <api/fs/fs.h>
#include <sys/mman.h> #include <sys/mman.h>
#include <sys/utsname.h>
#ifdef HAVE_BACKTRACE_SUPPORT #ifdef HAVE_BACKTRACE_SUPPORT
#include <execinfo.h> #include <execinfo.h>
#endif #endif
...@@ -665,3 +666,32 @@ bool find_process(const char *name) ...@@ -665,3 +666,32 @@ bool find_process(const char *name)
closedir(dir); closedir(dir);
return ret ? false : true; return ret ? false : true;
} }
int
fetch_kernel_version(unsigned int *puint, char *str,
size_t str_size)
{
struct utsname utsname;
int version, patchlevel, sublevel, err;
if (uname(&utsname))
return -1;
if (str && str_size) {
strncpy(str, utsname.release, str_size);
str[str_size - 1] = '\0';
}
err = sscanf(utsname.release, "%d.%d.%d",
&version, &patchlevel, &sublevel);
if (err != 3) {
pr_debug("Unablt to get kernel version from uname '%s'\n",
utsname.release);
return -1;
}
if (puint)
*puint = (version << 16) + (patchlevel << 8) + sublevel;
return 0;
}
...@@ -350,4 +350,7 @@ static inline char *asprintf_expr_not_in_ints(const char *var, size_t nints, int ...@@ -350,4 +350,7 @@ static inline char *asprintf_expr_not_in_ints(const char *var, size_t nints, int
int get_stack_size(const char *str, unsigned long *_size); int get_stack_size(const char *str, unsigned long *_size);
int fetch_kernel_version(unsigned int *puint,
char *str, size_t str_sz);
#endif /* GIT_COMPAT_UTIL_H */ #endif /* GIT_COMPAT_UTIL_H */
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册