perf config: Call perf_config__init() lazily

We check what perf_config__init() does at each perf_config() call,
namely if the static perf_config instance was created, so instead of
bailing out in that case, try to allocate it, bailing if it fails.

Now to get the perf_config() call out of the start of perf's main()
function, doing it also lazily.

Cc: Adrian Hunter <adrian.hunter@intel.com>
Cc: David Ahern <dsahern@gmail.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Taeung Song <treeze.taeung@gmail.com>
Cc: Wang Nan <wangnan0@huawei.com>
Link: https://lkml.kernel.org/n/tip-4bo45k6ivsmbxpfpdte4orsg@git.kernel.orgSigned-off-by: NArnaldo Carvalho de Melo <acme@redhat.com>
上级 5aafae8d
...@@ -458,7 +458,6 @@ int main(int argc, const char **argv) ...@@ -458,7 +458,6 @@ int main(int argc, const char **argv)
srandom(time(NULL)); srandom(time(NULL));
perf_config__init();
err = perf_config(perf_default_config, NULL); err = perf_config(perf_default_config, NULL);
if (err) if (err)
return err; return err;
......
...@@ -707,6 +707,14 @@ struct perf_config_set *perf_config_set__new(void) ...@@ -707,6 +707,14 @@ struct perf_config_set *perf_config_set__new(void)
return set; return set;
} }
static int perf_config__init(void)
{
if (config_set == NULL)
config_set = perf_config_set__new();
return config_set == NULL;
}
int perf_config(config_fn_t fn, void *data) int perf_config(config_fn_t fn, void *data)
{ {
int ret = 0; int ret = 0;
...@@ -714,7 +722,7 @@ int perf_config(config_fn_t fn, void *data) ...@@ -714,7 +722,7 @@ int perf_config(config_fn_t fn, void *data)
struct perf_config_section *section; struct perf_config_section *section;
struct perf_config_item *item; struct perf_config_item *item;
if (config_set == NULL) if (config_set == NULL && perf_config__init())
return -1; return -1;
perf_config_set__for_each_entry(config_set, section, item) { perf_config_set__for_each_entry(config_set, section, item) {
...@@ -735,12 +743,6 @@ int perf_config(config_fn_t fn, void *data) ...@@ -735,12 +743,6 @@ int perf_config(config_fn_t fn, void *data)
return ret; return ret;
} }
void perf_config__init(void)
{
if (config_set == NULL)
config_set = perf_config_set__new();
}
void perf_config__exit(void) void perf_config__exit(void)
{ {
perf_config_set__delete(config_set); perf_config_set__delete(config_set);
......
...@@ -38,7 +38,6 @@ struct perf_config_set *perf_config_set__new(void); ...@@ -38,7 +38,6 @@ struct perf_config_set *perf_config_set__new(void);
void perf_config_set__delete(struct perf_config_set *set); void perf_config_set__delete(struct perf_config_set *set);
int perf_config_set__collect(struct perf_config_set *set, const char *file_name, int perf_config_set__collect(struct perf_config_set *set, const char *file_name,
const char *var, const char *value); const char *var, const char *value);
void perf_config__init(void);
void perf_config__exit(void); void perf_config__exit(void);
void perf_config__refresh(void); void perf_config__refresh(void);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册