Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp409711pxy; Wed, 28 Apr 2021 06:49:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz5Nj9iBBOe0ATX/1HcpCUsgwTg1SXjbj18veFui6w5vo4AwGdB+9/YdAPLXnwLoYoazUgT X-Received: by 2002:a17:90a:a505:: with SMTP id a5mr32704492pjq.58.1619617744082; Wed, 28 Apr 2021 06:49:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619617744; cv=none; d=google.com; s=arc-20160816; b=vcZ8hr/ufhm1JkC4Pkd+n+DL2ytyjpBxTf+mGa+89b9N0DdV+sF9C3iQJt7zgw5YmZ MV96tpQTHr3QN8p2gvaB0hsqqrn1llw/7S3RTwLGU4m6ZJI8NCHQUbaI5haXlHuhvoNk WWhMVoOduug4oRI/osHQTxdITWgH01JOpFxQIePbjHx8hsIAm9l844p2nKrnPbzli1YF TZjA8NEyEwtDN+LFgI8xYCEEHRWNqsNIiBa+S3pan+A0K/P1Zsy3nEZNyuUBxirCCede 7rJCQPjEonz8l/wi0JzmYIrPzyI5cKRWsLsXyuFRytPzV927W5yqeLCvO+nviDbzQKe+ lL8Q== 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 :dkim-signature; bh=9TYUGP32ELQ91eeKz1nQb+O8oINCtciccCgqAO5/P6s=; b=KMviNy8XrL69XQwecXwT0+ap5cabalQz2o4sa++TT75NyZ6/q22oBXE/CvLZRedEOw vHLfcYN1xnwNQM7UhYxQUgEvq8WutQ3hXwBKVvCX8pEQv0hTrUd2UxAfYMPLfkFBA5Nj gc8JfaIf+vss4qIc1LNGsVF2Cq/6zcPjFjext+04gtS9LeFLp8j9d0bJ2yYyG3MUdjDu U4emIL5ti2QrVnbvXUgJNFQHKfDn6bqc6C6AiVIlVWX68B3iwpJF2FJJuFg4a1YFAT6Y 4ODLGn9H9travLWl6EuGDYoUAnS8nzONwj6CCi8RxnBxCObnqdL5Whjm1EtgQrjUYuxe nzaA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=SwO1Cki2; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q11si3705061pgg.173.2021.04.28.06.48.50; Wed, 28 Apr 2021 06:49:04 -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; dkim=pass header.i=@linaro.org header.s=google header.b=SwO1Cki2; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232709AbhD1L7M (ORCPT + 99 others); Wed, 28 Apr 2021 07:59:12 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56418 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232052AbhD1L7D (ORCPT ); Wed, 28 Apr 2021 07:59:03 -0400 Received: from mail-pg1-x530.google.com (mail-pg1-x530.google.com [IPv6:2607:f8b0:4864:20::530]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0EC27C06138A for ; Wed, 28 Apr 2021 04:58:19 -0700 (PDT) Received: by mail-pg1-x530.google.com with SMTP id q10so44532654pgj.2 for ; Wed, 28 Apr 2021 04:58:19 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=9TYUGP32ELQ91eeKz1nQb+O8oINCtciccCgqAO5/P6s=; b=SwO1Cki2YHfxZwsKvbvXhnIEvBmM4MIBhk3Z/7NlhTA6KlpJWwtzGmYiC7PKL2wCa2 lX47hXVAzgGGalNSpJ+PxW0lY0ZdF0cmcNE8g8ayE7aypyyDIxPys5DC4OfUhaVwH/hW 83JgeEFscfhGF7HYZ6rw5RhvbjPxcCTXGhfDpULA3aaNw6S04Iy9f4H01YdU/e3WsiHb AnMN/wGIBRDG5myXktdz/sFFKWHhP2lBeInn3BY08qWLYLigxtaBDHfOw06N/nBSTdJ7 fW6oX9UZ2yiKi00kSNUHfo4QSyug+w6C6pcrhZZEiNK9aZTHTnRRjTmNGIbfTFYpNBH6 ANxA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=9TYUGP32ELQ91eeKz1nQb+O8oINCtciccCgqAO5/P6s=; b=KT1uBkyKYjp+I8KB9jdqA7tpaUkYdYUZjTkgOyEsEZIsBhPCqcilaupy5PPfDZjKny oo1Pw+SNJEzYiuLscR7mgbRPbrt1wX1N1QYCOwjANGJeqC2Hwdze/LqUsLv7kEpn0djQ rwyDqm+aQzeah4OQx5Ku6OH3MAV/hdWpw3qRxsqsO3jkc4HtiGFMjELPEbRGqru2msTl MYZ112TjmYKersGANHmQdRXWKCDXj69KW5nt0ajQV+JFhBophvz3ex9dShLNFiIeN7l2 d9NfyPsp7LbR3oD8e+0Uj2O+QO/i5oWnIKUSP13+KlPdogdbAW+GXwzFo+3U5hNGF2Re SYdg== X-Gm-Message-State: AOAM53173jrUWEcBlUMNtUlXzLBqfgo/6Mgst8RGTYxOsuPLmNq6m7M2 qhnMWFPk1Tw0Fb7R3ZFxKSmCeQ== X-Received: by 2002:a63:c111:: with SMTP id w17mr26090480pgf.127.1619611098543; Wed, 28 Apr 2021 04:58:18 -0700 (PDT) Received: from localhost (ec2-18-166-74-158.ap-east-1.compute.amazonaws.com. [18.166.74.158]) by smtp.gmail.com with ESMTPSA id b140sm5002800pfb.98.2021.04.28.04.58.17 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 28 Apr 2021 04:58:18 -0700 (PDT) From: Leo Yan To: Arnaldo Carvalho de Melo , Adrian Hunter , Peter Zijlstra , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Ian Rogers , Steve MacLean , Yonatan Goldschmidt , "Gustavo A. R. Silva" , Kan Liang , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Leo Yan Subject: [PATCH v2 2/4] perf jit: Let convert_timestamp() to be backwards-compatible Date: Wed, 28 Apr 2021 19:57:47 +0800 Message-Id: <20210428115749.5229-3-leo.yan@linaro.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210428115749.5229-1-leo.yan@linaro.org> References: <20210428115749.5229-1-leo.yan@linaro.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Commit d110162cafc8 ("perf tsc: Support cap_user_time_short for event TIME_CONV") supports the extended parameters for event TIME_CONV, but it broke the backwards compatibility, so any perf data file with old event format fails to convert timestamp. This patch introduces a helper event_contains() to checks if an event contains a specific member or not. For the backwards-compatibility, if the event size confirms the extended parameters are supported in the event TIME_CONV, then copies these parameters. Fixes: d110162cafc8 ("perf tsc: Support cap_user_time_short for event TIME_CONV") Signed-off-by: Leo Yan Acked-by: Adrian Hunter --- tools/lib/perf/include/perf/event.h | 2 ++ tools/perf/util/jitdump.c | 30 +++++++++++++++++++---------- 2 files changed, 22 insertions(+), 10 deletions(-) diff --git a/tools/lib/perf/include/perf/event.h b/tools/lib/perf/include/perf/event.h index 48583e441d9b..4d0c02ba3f7d 100644 --- a/tools/lib/perf/include/perf/event.h +++ b/tools/lib/perf/include/perf/event.h @@ -8,6 +8,8 @@ #include #include /* pid_t */ +#define event_contains(obj, mem) ((obj).header.size > offsetof(typeof(obj), mem)) + struct perf_record_mmap { struct perf_event_header header; __u32 pid, tid; diff --git a/tools/perf/util/jitdump.c b/tools/perf/util/jitdump.c index 9760d8e7b386..5d388622b7ac 100644 --- a/tools/perf/util/jitdump.c +++ b/tools/perf/util/jitdump.c @@ -396,21 +396,31 @@ static pid_t jr_entry_tid(struct jit_buf_desc *jd, union jr_entry *jr) static uint64_t convert_timestamp(struct jit_buf_desc *jd, uint64_t timestamp) { - struct perf_tsc_conversion tc; + struct perf_tsc_conversion tc = { 0 }; + struct perf_record_time_conv *time_conv = &jd->session->time_conv; if (!jd->use_arch_timestamp) return timestamp; - tc.time_shift = jd->session->time_conv.time_shift; - tc.time_mult = jd->session->time_conv.time_mult; - tc.time_zero = jd->session->time_conv.time_zero; - tc.time_cycles = jd->session->time_conv.time_cycles; - tc.time_mask = jd->session->time_conv.time_mask; - tc.cap_user_time_zero = jd->session->time_conv.cap_user_time_zero; - tc.cap_user_time_short = jd->session->time_conv.cap_user_time_short; + tc.time_shift = time_conv->time_shift; + tc.time_mult = time_conv->time_mult; + tc.time_zero = time_conv->time_zero; - if (!tc.cap_user_time_zero) - return 0; + /* + * The event TIME_CONV was extended for the fields from "time_cycles" + * when supported cap_user_time_short, for backward compatibility, + * checks the event size and assigns these extended fields if these + * fields are contained in the event. + */ + if (event_contains(*time_conv, time_cycles)) { + tc.time_cycles = time_conv->time_cycles; + tc.time_mask = time_conv->time_mask; + tc.cap_user_time_zero = time_conv->cap_user_time_zero; + tc.cap_user_time_short = time_conv->cap_user_time_short; + + if (!tc.cap_user_time_zero) + return 0; + } return tsc_to_perf_time(timestamp, &tc); } -- 2.25.1