Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3084091ybt; Mon, 29 Jun 2020 14:56:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzuaTXTAeGfEdIUdwLoTJWqD358wD0OwXH9GAKJFNsuS2st+FFKRunJPx2TeyKv2+X3TWci X-Received: by 2002:a05:6402:b79:: with SMTP id cb25mr490924edb.154.1593467814875; Mon, 29 Jun 2020 14:56:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593467814; cv=none; d=google.com; s=arc-20160816; b=WyOXmZQjIMO5OsOpWwyK1HffddfbIdo0pOVmj0XRtXzCyOtvGwfEt22yNKDZ30iyJ5 rAt4jixfIVbJ95hNgJD6xe3Yq0UCa4PCJ6pLN0ixEBgVjgR9TRQCcX7E9ypVaWTAyyz9 dvs/4ulx3+MCAro973CZnutLZRsQaQ6FrGY7xBvVUzes3n2J4f9bX4VYEjvYx6GW6m1/ R8+om4NySvvqZjv9mmP7g3WFcdc6CqGe8/eZgamtBZy/4eCy6KoKyTUjd5brDRhcmv45 mKrNyRH70gaRQdJnEtRFhQjIbOvqSFBNz65WkmlceuJoShaZRMszxvZQt24X7hFS1X2G H/aw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=RjHGnbkWs5nMU8QqB+2FIpoZQ7yzzMMV8OMSntDdf0U=; b=jdGdEUFiZkXn+LrR1a+MrvZUDCA0JExgfncXQaQgWR/jiB1cOz0Nfu0xcJDg7GPY8x TOQgMMUtmaMKZQz2Llr1blGZ9zX4DA4SMTaLjALTfFuKicZLEc6l428hcfbH/kJJaYvv s7Kd+ldGZCdWmW+Y1U2w7NyZWhRl6jeJM/xgLzXmn6xFMxg02koRCHUTeczmAgppeAJf ksYYdEnZKJTvSghSsaz7ewWW35IEJr/t+fQItdnoDydnXlN+Tm8eeMO5b/9I3YF9RYWn YWKYTkJTYe1TRifYvgVsXatUCSX5v8PRnayB5xc6RN59SsRqufuJ9mAhVn8Sf72qTLno /HxQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=NNJSXeW2; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dt4si661383ejc.34.2020.06.29.14.56.32; Mon, 29 Jun 2020 14:56:54 -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=@kernel.org header.s=default header.b=NNJSXeW2; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404439AbgF2VxO (ORCPT + 99 others); Mon, 29 Jun 2020 17:53:14 -0400 Received: from mail.kernel.org ([198.145.29.99]:56782 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726621AbgF2Sfj (ORCPT ); Mon, 29 Jun 2020 14:35:39 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 31E85247CE; Mon, 29 Jun 2020 15:22:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593444137; bh=HoRRQa7f66uwUXT0UY7W3ZAQC+5b3xGlFVDntubMczw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NNJSXeW2IweVS5psDPZHSaKM6PVSgjghyVSZDrPH2U6KefWofTRToGxO6nZChvF6z AOLYjj38fDnft/7+KuaxzMghl+1pc7lQ2V+VB0IPsjeYqJnNYa6IJ1skJBGe/LOduI +TIwxhmw00/8h+Ab3SA3tjAPD3ONgqCE/Sp2U3Oc= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: "Steven Rostedt (VMware)" , Ingo Molnar , Andrew Morton , Tom Zanussi , Julia Lawall , Greg Kroah-Hartman Subject: [PATCH 5.7 243/265] ring-buffer: Zero out time extend if it is nested and not absolute Date: Mon, 29 Jun 2020 11:17:56 -0400 Message-Id: <20200629151818.2493727-244-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629151818.2493727-1-sashal@kernel.org> References: <20200629151818.2493727-1-sashal@kernel.org> MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v5.x/stable-review/patch-5.7.7-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-5.7.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 5.7.7-rc1 X-KernelTest-Deadline: 2020-07-01T15:14+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: "Steven Rostedt (VMware)" commit 097350d1c6e1f5808cae142006f18a0bbc57018d upstream. Currently the ring buffer makes events that happen in interrupts that preempt another event have a delta of zero. (Hopefully we can change this soon). But this is to deal with the races of updating a global counter with lockless and nesting functions updating deltas. With the addition of absolute time stamps, the time extend didn't follow this rule. A time extend can happen if two events happen longer than 2^27 nanoseconds appart, as the delta time field in each event is only 27 bits. If that happens, then a time extend is injected with 2^59 bits of nanoseconds to use (18 years). But if the 2^27 nanoseconds happen between two events, and as it is writing the event, an interrupt triggers, it will see the 2^27 difference as well and inject a time extend of its own. But a recent change made the time extend logic not take into account the nesting, and this can cause two time extend deltas to happen moving the time stamp much further ahead than the current time. This gets all reset when the ring buffer moves to the next page, but that can cause time to appear to go backwards. This was observed in a trace-cmd recording, and since the data is saved in a file, with trace-cmd report --debug, it was possible to see that this indeed did happen! bash-52501 110d... 81778.908247: sched_switch: bash:52501 [120] S ==> swapper/110:0 [120] [12770284:0x2e8:64] -0 110d... 81778.908757: sched_switch: swapper/110:0 [120] R ==> bash:52501 [120] [509947:0x32c:64] TIME EXTEND: delta:306454770 length:0 bash-52501 110.... 81779.215212: sched_swap_numa: src_pid=52501 src_tgid=52388 src_ngid=52501 src_cpu=110 src_nid=2 dst_pid=52509 dst_tgid=52388 dst_ngid=52501 dst_cpu=49 dst_nid=1 [0:0x378:48] TIME EXTEND: delta:306458165 length:0 bash-52501 110dNh. 81779.521670: sched_wakeup: migration/110:565 [0] success=1 CPU:110 [0:0x3b4:40] and at the next page, caused the time to go backwards: bash-52504 110d... 81779.685411: sched_switch: bash:52504 [120] S ==> swapper/110:0 [120] [8347057:0xfb4:64] CPU:110 [SUBBUFFER START] [81779379165886:0x1320000] -0 110dN.. 81779.379166: sched_wakeup: bash:52504 [120] success=1 CPU:110 [0:0x10:40] -0 110d... 81779.379167: sched_switch: swapper/110:0 [120] R ==> bash:52504 [120] [1168:0x3c:64] Link: https://lkml.kernel.org/r/20200622151815.345d1bf5@oasis.local.home Cc: Ingo Molnar Cc: Andrew Morton Cc: Tom Zanussi Cc: stable@vger.kernel.org Fixes: dc4e2801d400b ("ring-buffer: Redefine the unimplemented RINGBUF_TYPE_TIME_STAMP") Reported-by: Julia Lawall Signed-off-by: Steven Rostedt (VMware) Signed-off-by: Greg Kroah-Hartman --- kernel/trace/ring_buffer.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/kernel/trace/ring_buffer.c b/kernel/trace/ring_buffer.c index b8e1ca48be50f..00867ff82412a 100644 --- a/kernel/trace/ring_buffer.c +++ b/kernel/trace/ring_buffer.c @@ -2427,7 +2427,7 @@ rb_update_event(struct ring_buffer_per_cpu *cpu_buffer, if (unlikely(info->add_timestamp)) { bool abs = ring_buffer_time_stamp_abs(cpu_buffer->buffer); - event = rb_add_time_stamp(event, info->delta, abs); + event = rb_add_time_stamp(event, abs ? info->delta : delta, abs); length -= RB_LEN_TIME_EXTEND; delta = 0; } -- 2.25.1