From mboxrd@z Thu Jan 1 00:00:00 1970 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759176AbeAIPr1 (ORCPT + 1 other); Tue, 9 Jan 2018 10:47:27 -0500 Received: from mx1.redhat.com ([209.132.183.28]:47452 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758922AbeAIPfw (ORCPT ); Tue, 9 Jan 2018 10:35:52 -0500 From: Jiri Olsa To: Arnaldo Carvalho de Melo Cc: lkml , Ingo Molnar , Namhyung Kim , David Ahern , Andi Kleen , Alexander Shishkin , Peter Zijlstra Subject: [PATCH 12/49] perf tools: Add perf_data__create_index function Date: Tue, 9 Jan 2018 16:34:45 +0100 Message-Id: <20180109153522.14116-13-jolsa@kernel.org> In-Reply-To: <20180109153522.14116-1-jolsa@kernel.org> References: <20180109153522.14116-1-jolsa@kernel.org> X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.39]); Tue, 09 Jan 2018 15:35:52 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Return-Path: Adding perf_data__create_index function to create and open index files within perf_data struct. Link: http://lkml.kernel.org/n/tip-kl4s1f13cg6wycrg367p85qm@git.kernel.org Signed-off-by: Jiri Olsa --- tools/perf/util/data.c | 64 ++++++++++++++++++++++++++++++++++++++++++++++++++ tools/perf/util/data.h | 5 ++++ 2 files changed, 69 insertions(+) diff --git a/tools/perf/util/data.c b/tools/perf/util/data.c index 48094fde0a68..261f370023a9 100644 --- a/tools/perf/util/data.c +++ b/tools/perf/util/data.c @@ -197,3 +197,67 @@ int perf_data__switch(struct perf_data *data, free(new_filepath); return ret; } + +static void free_index(struct perf_data_file *index, int nr) +{ + while (--nr >= 1) { + close(index[nr].fd); + free((char *) index[nr].path); + } + free(index); +} + +static void clean_index(struct perf_data *data, + struct perf_data_file *index, + int index_nr) +{ + char path[PATH_MAX]; + + scnprintf(path, sizeof(path), "%s.dir", data->file.path); + rm_rf(path); + + free_index(index, index_nr); +} + +void perf_data__clean_index(struct perf_data *data) +{ + clean_index(data, data->index, data->index_nr); +} + +int perf_data__create_index(struct perf_data *data, int nr) +{ + struct perf_data_file *index; + char path[PATH_MAX]; + int ret = -1, i = 0; + + index = malloc(nr * sizeof(*index)); + if (!index) + return -ENOMEM; + + data->index = index; + data->index_nr = nr; + + scnprintf(path, sizeof(path), "%s.dir", data->file.path); + if (rm_rf(path) < 0 || mkdir(path, S_IRWXU) < 0) + goto out_err; + + for (; i < nr; i++) { + struct perf_data_file *file = &index[i]; + + if (asprintf((char **) &file->path, "%s.dir/perf.data.%d", + data->file.path, i) < 0) + goto out_err; + + ret = open(file->path, O_RDWR|O_CREAT|O_TRUNC, S_IRUSR|S_IWUSR); + if (ret < 0) + goto out_err; + + file->fd = ret; + } + + return 0; + +out_err: + clean_index(data, index, i); + return ret; +} diff --git a/tools/perf/util/data.h b/tools/perf/util/data.h index 4828f7feea89..33b62c30b053 100644 --- a/tools/perf/util/data.h +++ b/tools/perf/util/data.h @@ -20,6 +20,8 @@ struct perf_data { bool force; unsigned long size; enum perf_data_mode mode; + struct perf_data_file *index; + int index_nr; }; static inline bool perf_data__is_read(struct perf_data *data) @@ -63,4 +65,7 @@ ssize_t perf_data_file__write(struct perf_data_file *file, int perf_data__switch(struct perf_data *data, const char *postfix, size_t pos, bool at_exit); +int perf_data__create_index(struct perf_data *data, + int nr); +void perf_data__clean_index(struct perf_data *data); #endif /* __PERF_DATA_H */ -- 2.13.6