Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp3374901pxy; Tue, 4 May 2021 00:07:27 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy50fetoCfvumXBvjF/v53srT6ayme70nXvSvd9W+6Z9M9Qp0dCbeXY7aR0wat7ZKdFuHma X-Received: by 2002:a17:90a:7783:: with SMTP id v3mr25337186pjk.161.1620112046951; Tue, 04 May 2021 00:07:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620112046; cv=none; d=google.com; s=arc-20160816; b=JhTltze/68iQ8GEEkQuMdmE+nSYgrA6Jc4oQ8purhS/SuxiAytc56NLYdtsZ4dznVT phjDzVvGJ1rmbwIqeLUKAHRjfwiSwInHDv1ceSit2n1xwyIvqE7g3radDQpGi2xSiCvc UVFmRXbkVaa5oXj61cVGX+bAT38TJkTUKyD0wkfna5n8NosIPZ1VHx0Cs0sMRMdhlxL0 ar6GE3BQ8ZVWWtLBkANF4kCe0jVCK2NH0y2pZuFQ/ElzGvXBFjQ2WuIfLUr019PFKdtH UJDMQTLGTfGMTXtvq7QKXqNuMzED1vanb6ZlPuLb5eylm52iAWDBNMoujdKt4QWePaYh Infw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :ironport-sdr:ironport-sdr; bh=f5qfRbx+C/g2RRIXwWmarRdTUi/O9vj+0m09f6OZYMs=; b=tMh/TEI6kdn1NmOyEgNXTvRdJzwI338roDA0/MnjPI+JiBBJO5UdPaSHR1m03MaQDI 5okz8+9fHdyIVSv/hbs6EekazOGZHoo//fN/bTS06F1o/BMdXHDF0G1xx5zKWQ6ipKML mgMF8PHX+zUoTLSl6FzH2dk617LGOZU5epgFzDiAFSur4Dz1G5A1Du0EhB1Qg+YRMQNz ttzde2CosahwSLFi4NBa6k27vgY3lLmZXEh6kFNatgTa/QTySqJderXpr+VA+QsjX/lc BUh6eUALTEvEOSbpROTzhnlUJTbBr6ug+rsG5YaiP8Ob4mUoVGWxj1NEjwJFgBOCPE8E 7OMQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bi3si2587348plb.43.2021.05.04.00.07.14; Tue, 04 May 2021 00:07:26 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230083AbhEDHHc (ORCPT + 99 others); Tue, 4 May 2021 03:07:32 -0400 Received: from mga17.intel.com ([192.55.52.151]:43393 "EHLO mga17.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229894AbhEDHHQ (ORCPT ); Tue, 4 May 2021 03:07:16 -0400 IronPort-SDR: FHHUCZFUerJlFmbrH/Gu6fEXIgbtpeoNANM4jjvSpqYeZbkBeKeNzJHnuBIzlVcVwlsmY3YQ4T 95h8dVp16jYA== X-IronPort-AV: E=McAfee;i="6200,9189,9973"; a="178130019" X-IronPort-AV: E=Sophos;i="5.82,271,1613462400"; d="scan'208";a="178130019" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by fmsmga107.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 04 May 2021 00:06:17 -0700 IronPort-SDR: xgsXLDZNTc5h5ZUeV3ZvobFhgW35t1nt8b75gcOMhb9GQtl0ATmNp3w6tQndDnx93VxIF7r4Mq lquYogsu2pbw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.82,271,1613462400"; d="scan'208";a="450895734" Received: from nntpat99-84.inn.intel.com ([10.125.99.84]) by fmsmga004.fm.intel.com with ESMTP; 04 May 2021 00:06:08 -0700 From: Alexey Bayduraev To: Arnaldo Carvalho de Melo Cc: Jiri Olsa , Namhyung Kim , Alexander Shishkin , Peter Zijlstra , Ingo Molnar , linux-kernel , Andi Kleen , Adrian Hunter , Alexander Antonov , Alexei Budankov Subject: [PATCH v5 16/20] perf session: introduce decompressor into trace reader object Date: Tue, 4 May 2021 10:04:51 +0300 Message-Id: <6c7daad7126a5ca7c06b7916d71a2d6cf4b28b03.1619781188.git.alexey.v.bayduraev@linux.intel.com> X-Mailer: git-send-email 2.19.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Introduce decompressor into trace reader object so that decompression could be executed on per data file basis separately for every data file located in data directory. Signed-off-by: Alexey Bayduraev --- tools/perf/util/session.c | 51 +++++++++++++++++++++++++++++---------- tools/perf/util/session.h | 1 + 2 files changed, 39 insertions(+), 13 deletions(-) diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 65ce798eb27d..81214052b2e3 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c @@ -72,6 +72,9 @@ struct reader { u64 data_size; u64 data_offset; reader_cb_t process; + struct zstd_data zstd_data; + struct decomp *decomp; + struct decomp *decomp_last; struct reader_state state; }; @@ -84,7 +87,10 @@ static int perf_session__process_compressed_event(struct perf_session *session, size_t decomp_size, src_size; u64 decomp_last_rem = 0; size_t mmap_len, decomp_len = session->header.env.comp_mmap_len; - struct decomp *decomp, *decomp_last = session->decomp_last; + struct decomp *decomp, *decomp_last = session->active_reader ? + session->active_reader->decomp_last : session->decomp_last; + struct zstd_data *zstd_data = session->active_reader ? + &session->active_reader->zstd_data : &session->zstd_data; if (decomp_last) { decomp_last_rem = decomp_last->size - decomp_last->head; @@ -112,7 +118,7 @@ static int perf_session__process_compressed_event(struct perf_session *session, src = (void *)event + sizeof(struct perf_record_compressed); src_size = event->pack.header.size - sizeof(struct perf_record_compressed); - decomp_size = zstd_decompress_stream(&(session->zstd_data), src, src_size, + decomp_size = zstd_decompress_stream(zstd_data, src, src_size, &(decomp->data[decomp_last_rem]), decomp_len - decomp_last_rem); if (!decomp_size) { munmap(decomp, mmap_len); @@ -122,12 +128,22 @@ static int perf_session__process_compressed_event(struct perf_session *session, decomp->size += decomp_size; - if (session->decomp == NULL) { - session->decomp = decomp; - session->decomp_last = decomp; + if (session->active_reader) { + if (session->active_reader->decomp == NULL) { + session->active_reader->decomp = decomp; + session->active_reader->decomp_last = decomp; + } else { + session->active_reader->decomp_last->next = decomp; + session->active_reader->decomp_last = decomp; + } } else { - session->decomp_last->next = decomp; - session->decomp_last = decomp; + if (session->decomp == NULL) { + session->decomp = decomp; + session->decomp_last = decomp; + } else { + session->decomp_last->next = decomp; + session->decomp_last = decomp; + } } pr_debug("decomp (B): %zd to %zd\n", src_size, decomp_size); @@ -318,11 +334,10 @@ static void perf_session__delete_threads(struct perf_session *session) machine__delete_threads(&session->machines.host); } -static void perf_session__release_decomp_events(struct perf_session *session) +static void perf_decomp__release_events(struct decomp *next) { - struct decomp *next, *decomp; + struct decomp *decomp; size_t mmap_len; - next = session->decomp; do { decomp = next; if (decomp == NULL) @@ -335,6 +350,8 @@ static void perf_session__release_decomp_events(struct perf_session *session) void perf_session__delete(struct perf_session *session) { + int r; + if (session == NULL) return; auxtrace__free(session); @@ -342,10 +359,12 @@ void perf_session__delete(struct perf_session *session) perf_session__destroy_kernel_maps(session); perf_session__delete_threads(session); if (session->readers) { + for (r = 0; r < session->nr_readers; r++) + perf_decomp__release_events(session->readers[r].decomp); zfree(&session->readers); session->nr_readers = 0; } - perf_session__release_decomp_events(session); + perf_decomp__release_events(session->decomp); perf_env__exit(&session->header.env); machines__exit(&session->machines); if (session->data) @@ -2156,7 +2175,8 @@ static int __perf_session__process_decomp_events(struct perf_session *session) { s64 skip; u64 size; - struct decomp *decomp = session->decomp_last; + struct decomp *decomp = session->active_reader ? + session->active_reader->decomp_last : session->decomp_last; if (!decomp) return 0; @@ -2213,6 +2233,9 @@ reader__process_events(struct reader *rd, struct perf_session *session, memset(mmaps, 0, sizeof(st->mmaps)); + if (zstd_init(&rd->zstd_data, 0)) + return -1; + mmap_prot = PROT_READ; mmap_flags = MAP_SHARED; @@ -2254,12 +2277,13 @@ reader__process_events(struct reader *rd, struct perf_session *session, goto remap; } + session->active_reader = rd; size = event->header.size; skip = -EINVAL; if (size < sizeof(struct perf_event_header) || - (skip = rd->process(session, event, st->file_pos, rd->path)) < 0) { + (skip = perf_session__process_event(session, event, st->file_pos, rd->path)) < 0) { pr_err("%#" PRIx64 " [%s] [%#x]: failed to process type: %d [%s]\n", st->file_offset + st->head, rd->path, event->header.size, event->header.type, strerror(-skip)); @@ -2286,6 +2310,7 @@ reader__process_events(struct reader *rd, struct perf_session *session, goto more; out: + session->active_reader = NULL; return err; } diff --git a/tools/perf/util/session.h b/tools/perf/util/session.h index 2815d00b5467..e0a8712f8770 100644 --- a/tools/perf/util/session.h +++ b/tools/perf/util/session.h @@ -44,6 +44,7 @@ struct perf_session { struct decomp *decomp_last; struct reader *readers; int nr_readers; + struct reader *active_reader; }; struct decomp { -- 2.19.0