Received: by 2002:a05:6a10:c604:0:0:0:0 with SMTP id y4csp2640412pxt; Mon, 9 Aug 2021 05:38:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz/ByjtgbNabj7kth3ck1eglz43Zs9NTEoQUQ8vt/j4Hih2IQ4M9Che26zqaXam9POhA1cq X-Received: by 2002:a05:6402:1202:: with SMTP id c2mr29224169edw.216.1628512722719; Mon, 09 Aug 2021 05:38:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1628512722; cv=none; d=google.com; s=arc-20160816; b=El8Up7tvzYFN7tdkDWQfXU0ZDv7QjuVl3efIxAM3rhEhTPMFkiDCh+nw/1kcoUnbYU dKBYKbvlTVXTFpyNyxhiNkghGrMuoH1l3ejtMRmPriKRRTCeKIsNHgX2MbH3ReekREfO HZwo6xDr8UEjPW4SofxjpZwu9kAOB13FcWvQiI54/fyDSiLpjQ4ng5H2ceC9zB5/MH2D QjMTxVyyrDwZcdBfY2q8cL672hZVu1oEVWDVKClRHmKkHjFqdmt6UQcj/zsCKSXggeJN NQgMhIDEqE0TxZKpC82ib6KdJbDj4eBrEk1HkTr8xaUW0qHCaVdqfcV7Q9Y+M/RCkkMy gElQ== 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=mUfdU9WBYmi8/NBmndyLWLFFhQ6mqBUwjCh/GuP5qb8=; b=S85gwbMpCbYrfC1rCY/B3pr3Kf6DiP4vlq4ch6vS1VsQt0z6rUScJ2J8ZVC6D7QJyG SaCmzdYW38gvYVR9kS3HbC+T5YhOsy3eVnAvaCoSudr56et55IZTsEFQwWYiWDqNp1YZ 1iV6YBeS6i6wl5BaEKqy2bB3oO7I8OtC2LwO/SevxPFZYF1ziXHZ9/rpGEJuUD2OAN8w Yhx+mYb6nYlFQcXMNavpC2w9ch/aurMS5i0O3/vVO8LCx6JjH5jCE9xsYiPkF5P2cwZH kckNsjpS3shdWK7ybapXHb5r6GqrqGx8I7bt92f7owAEr1UwUjxXfqtkxVf19zGM6KCj IwKA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=qpdVxW5a; 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 a7si18005496edt.36.2021.08.09.05.38.18; Mon, 09 Aug 2021 05:38:42 -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=qpdVxW5a; 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 S234970AbhHILPl (ORCPT + 99 others); Mon, 9 Aug 2021 07:15:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57038 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234920AbhHILPk (ORCPT ); Mon, 9 Aug 2021 07:15:40 -0400 Received: from mail-pl1-x62e.google.com (mail-pl1-x62e.google.com [IPv6:2607:f8b0:4864:20::62e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 76E1CC061796 for ; Mon, 9 Aug 2021 04:15:20 -0700 (PDT) Received: by mail-pl1-x62e.google.com with SMTP id c16so15967842plh.7 for ; Mon, 09 Aug 2021 04:15:20 -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=mUfdU9WBYmi8/NBmndyLWLFFhQ6mqBUwjCh/GuP5qb8=; b=qpdVxW5apeotrdM2TF06hZw08s65z4QwLumvU9xv/1WhAR9sgk2/cegXSUJAq5nd4z td9kmETmFcktCDgTZxPCkDSJN6YY1kAaofoZC+aMUG+r6j5hl2gFFJrrXA2dvq78eizO 0uDjrQalWkQzu2N0/KVrfSHpa1MUGr04hBRaTN50+g/22xftdVxSfiQRLcbQfeLYmJ1o nvGA41UTpDKNXPh4t743VyFNgURK2k0H70kDUz8cKfqoarcH7wHGvtRPqMGzlZxL/fQ/ YurX1u9V3i1s202T4XOfeWwVXlnXd72hrMnJ4AQ5Ob6sBo9wD4xXUrJf/RJci26N+MDy Qohg== 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=mUfdU9WBYmi8/NBmndyLWLFFhQ6mqBUwjCh/GuP5qb8=; b=FfF8KL/BeSzmfLiysGtkwoXMVx8UqNKiW4KSOFJl6z80exx2WAhxBA4wCJmDUT4ADf lgmwVlenJ3mgUq5KQi9BfplSF7QwmFGGoX9QLaco/lLsxjM5fij3WgcHu6xQZ4hq1s74 q/GcVs/TVr37JujTqpulc/YhBe99OtwXrk05NEd21frFrglP1d/BTounREqI5TdYyp9G HKzZD8nt7bT/k2Z8p7vddzFqWpbzgzt0D3o7uMj9UGYO1Mr6WIbaML4tzK11xM7ZRo+s 1vt932Wzp7dUy+/VMOwHY6BpYPfmfpmhpGob1lm1Tb591s5Ne2g13/FwVqkTnhY14Npb FneQ== X-Gm-Message-State: AOAM530Ot39UFeNYU9peZpL5BUGJnW3v7amQN+3yzDK5w5DcXqtZa2rx L7lYNPabpHKGc+RdAEP0qAZeuA== X-Received: by 2002:a17:903:22c7:b029:12c:4621:a2fd with SMTP id y7-20020a17090322c7b029012c4621a2fdmr9050245plg.61.1628507719959; Mon, 09 Aug 2021 04:15:19 -0700 (PDT) Received: from localhost ([210.0.159.74]) by smtp.gmail.com with ESMTPSA id v15sm17844635pja.53.2021.08.09.04.15.19 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 Aug 2021 04:15:19 -0700 (PDT) From: Leo Yan To: Arnaldo Carvalho de Melo , Peter Zijlstra , Adrian Hunter , Ingo Molnar , Mark Rutland , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Thomas Gleixner , Borislav Petkov , "H. Peter Anvin" , Mathieu Poirier , Suzuki K Poulose , Mike Leach , Michael Petlan , "Frank Ch. Eigler" , Song Liu , x86@kernel.org, =?UTF-8?q?Daniel=20D=C3=ADaz?= , Andrii Nakryiko , Alexei Starovoitov , Sedat Dilek , Andi Kleen , linux-perf-users@vger.kernel.org, linux-kernel@vger.kernel.org, coresight@lists.linaro.org Cc: Leo Yan Subject: [PATCH v5 1/9] perf/ring_buffer: Add comment for barriers on AUX ring buffer Date: Mon, 9 Aug 2021 19:13:59 +0800 Message-Id: <20210809111407.596077-2-leo.yan@linaro.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210809111407.596077-1-leo.yan@linaro.org> References: <20210809111407.596077-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 AUX ring buffer applies almost the same barriers as perf ring buffer, but there has an exception for ordering between writing the AUX trace data and updating user_page::aux_head. This patch adds comment for how to use the barriers on AUX ring buffer, and gives comment to ask the drivers to flush the trace data into AUX ring buffer prior to updating user_page::aux_head. Signed-off-by: Leo Yan Acked-by: Peter Zijlstra (Intel) --- kernel/events/ring_buffer.c | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/kernel/events/ring_buffer.c b/kernel/events/ring_buffer.c index 52868716ec35..5cf6579be05e 100644 --- a/kernel/events/ring_buffer.c +++ b/kernel/events/ring_buffer.c @@ -509,6 +509,15 @@ void perf_aux_output_end(struct perf_output_handle *handle, unsigned long size) perf_event_aux_event(handle->event, aux_head, size, handle->aux_flags); + /* + * See perf_output_put_handle(), AUX ring buffer applies the same + * barrier pairing as the perf ring buffer; except for B, since + * AUX ring buffer is written by hardware trace, we cannot simply + * use the generic memory barrier (like smp_wmb()) prior to update + * user_page::aux_head, the hardware trace driver takes the + * responsibility to ensure the trace data has been flushed into + * the AUX buffer before calling perf_aux_output_end(). + */ WRITE_ONCE(rb->user_page->aux_head, rb->aux_head); if (rb_need_aux_wakeup(rb)) wakeup = true; -- 2.25.1