Received: by 2002:a25:e74b:0:0:0:0:0 with SMTP id e72csp1947457ybh; Fri, 24 Jul 2020 00:01:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzCWWiCVRy8sTsHDo/FVBJUBnuJuihflEEl7iFlsZp2jlEd3XrAAFU0geTnFPw7dcG9UbLk X-Received: by 2002:a17:907:405e:: with SMTP id ns22mr7771929ejb.6.1595574073491; Fri, 24 Jul 2020 00:01:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1595574073; cv=none; d=google.com; s=arc-20160816; b=fMXm095MwqbnvU8+CqN/C+6wzlsmE+z14zz8Yetd9Mt9f32iLKWO8F/I+ezdPGtg/e pwU/9n7j9TW2RZrqqYbf99IB7ydFViEbGfBmon34t/7dxjYP/nHy/mEDiD+Jev2FLhxu O9KdK5gxiJz83pNZZZ96z8uNFB3dLbqwk5xg6mvcopahQho1ovNdxE1t1xS9ehNNaLIT UaLp8rkniEHjOg5jDMXYDo0BzDnRle8WcMpfts9qTO3akfnQYSkZybjPpKjJy0Hs/qji wKPAMOfpU/Dpq+BVeWTzTekJdHE+MaiGeDNbm92yA+ldCrQqnqRBbPzuSVcc166uF8uv dG7g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:from:subject:references :mime-version:message-id:in-reply-to:date:dkim-signature; bh=ROSpznE7uIV54LbFh2Cka7vTr1SComFhGsjc+g8qPz8=; b=c5EO4K9uSJ5wWRmde+QbYNT7UWMW6lvJvctg4HP6qVRpNQo1DCp5EC3QSpCu39N6c6 W/BUiOXmKzwfHSkceXrZdoKieLzT2zSOI1rTRsJjQDUh+uWCrYffnMlb1K/GynJn1vl1 FAATZDB5dTcbcmOFbFWyEzeKfp4RvipIyxF8V7XsGSqeID+RqovemWmSTL1aNZUE9QkB CaAZhuYY1fHupgZjQ3psQdnWyr0y1/UP7+IvzsvPCGqdGNOk1MRss1gCKKbNN0VxtqMZ 2fe3qLBgfonn1AeAZ+FSE9vLo4Fw/L+/nO31to0nKwEkCICXHa3USiwiWiYiATT89nWp W0mw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=utBhLhz3; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id se13si51671ejb.718.2020.07.24.00.00.51; Fri, 24 Jul 2020 00:01:13 -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=@google.com header.s=20161025 header.b=utBhLhz3; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726957AbgGXHAc (ORCPT + 99 others); Fri, 24 Jul 2020 03:00:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33478 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726878AbgGXHAa (ORCPT ); Fri, 24 Jul 2020 03:00:30 -0400 Received: from mail-qv1-xf49.google.com (mail-qv1-xf49.google.com [IPv6:2607:f8b0:4864:20::f49]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2A105C0619D3 for ; Fri, 24 Jul 2020 00:00:30 -0700 (PDT) Received: by mail-qv1-xf49.google.com with SMTP id y7so2534260qvj.11 for ; Fri, 24 Jul 2020 00:00:30 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=ROSpznE7uIV54LbFh2Cka7vTr1SComFhGsjc+g8qPz8=; b=utBhLhz3IuEbZPYCAASa4TiiCIGcqNyvrjQPgTsEQoR+sdOQGOenTw19TlehFH6aT0 Vx0rBn3h2JjlTCyGiL+BEYfmeZ4ZrMO4jcgljXFe1jXOAMA9tPhPOqa0JkkgBfduX6/l aUdhpxcmuhjquy3qFiW3odpSvS3kPuUgq8ur914YAhVEzbmwHo1NAj1+tVa6llDAJbwQ 6udGxxqa8kXqdnxs6IxifD7BbRli256RNYwgqPSFO7x5x89RN10V5vgfvb9TmJWrXdUC 2muznV/iYpADkWSwqFqNVn9Q+Nw6wbJDbRkpesxMiqUyfXDTpj9nyzavmIG39MURM4q3 COkA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=ROSpznE7uIV54LbFh2Cka7vTr1SComFhGsjc+g8qPz8=; b=HdAwq7ZWDN7L3LI79xO2STzDuz/kNIune7iS+isw0Urg+EFy3cWCFUehBxSaifj5Ri hUxoZPX1GXvV0khkk3aSY+5S7bLt9SS5EBEz60CWx4aLVzvHwQxU9Kupn75YDqeNGHXN divNcT0+ER+J2/mypgA4fzD7Us40bM6dg/c8N/29ruZlp+y8FsckMKKBsEFqWCsZ5LJj Ao4MiPnhMFfs+hYLZWatIHaMq2B/4sezKjksL7bYH8ku5EBMu/TGdoPHgnqJ4GlM0X03 IumHfGQH+TEvTphkSAsE+MNRclkW3XuDGzd9NyQzY6piGvgVOlXZnNNqTT/lMAGX5VFK +38g== X-Gm-Message-State: AOAM532tFJWjY2p8wcOfsGi+mokW4ZWJ0f3Gbjk3UJXb6RTmeHHcUi3n 8NzOz2zONdcdmdpwp4fv73GcLLDM7Q== X-Received: by 2002:a0c:e78e:: with SMTP id x14mr8617576qvn.65.1595574029293; Fri, 24 Jul 2020 00:00:29 -0700 (PDT) Date: Fri, 24 Jul 2020 09:00:03 +0200 In-Reply-To: <20200724070008.1389205-1-elver@google.com> Message-Id: <20200724070008.1389205-4-elver@google.com> Mime-Version: 1.0 References: <20200724070008.1389205-1-elver@google.com> X-Mailer: git-send-email 2.28.0.rc0.142.g3c755180ce-goog Subject: [PATCH v2 3/8] kcsan: Skew delay to be longer for certain access types From: Marco Elver To: elver@google.com, paulmck@kernel.org Cc: will@kernel.org, peterz@infradead.org, arnd@arndb.de, mark.rutland@arm.com, dvyukov@google.com, glider@google.com, kasan-dev@googlegroups.com, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For compound instrumentation and assert accesses, skew the watchpoint delay to be longer if randomized. This is useful to improve race detection for such accesses. For compound accesses we should increase the delay as we've aggregated both read and write instrumentation. By giving up 1 call into the runtime, we're less likely to set up a watchpoint and thus less likely to detect a race. We can balance this by increasing the watchpoint delay. For assert accesses, we know these are of increased interest, and we wish to increase our chances of detecting races for such checks. Note that, kcsan_udelay_{task,interrupt} define the upper bound delays. When randomized, delays are uniformly distributed between [0, delay]. Skewing the delay does not break this promise as long as the defined upper bounds are still adhered to. The current skew results in delays uniformly distributed between [delay/2, delay]. Signed-off-by: Marco Elver --- v2: * Commit message rewording. --- kernel/kcsan/core.c | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/kernel/kcsan/core.c b/kernel/kcsan/core.c index fb52de2facf3..4633baebf84e 100644 --- a/kernel/kcsan/core.c +++ b/kernel/kcsan/core.c @@ -283,11 +283,15 @@ static __always_inline bool kcsan_is_enabled(void) return READ_ONCE(kcsan_enabled) && get_ctx()->disable_count == 0; } -static inline unsigned int get_delay(void) +static inline unsigned int get_delay(int type) { unsigned int delay = in_task() ? kcsan_udelay_task : kcsan_udelay_interrupt; + /* For certain access types, skew the random delay to be longer. */ + unsigned int skew_delay_order = + (type & (KCSAN_ACCESS_COMPOUND | KCSAN_ACCESS_ASSERT)) ? 1 : 0; + return delay - (IS_ENABLED(CONFIG_KCSAN_DELAY_RANDOMIZE) ? - prandom_u32_max(delay) : + prandom_u32_max(delay >> skew_delay_order) : 0); } @@ -449,7 +453,7 @@ kcsan_setup_watchpoint(const volatile void *ptr, size_t size, int type) * Delay this thread, to increase probability of observing a racy * conflicting access. */ - udelay(get_delay()); + udelay(get_delay(type)); /* * Re-read value, and check if it is as expected; if not, we infer a -- 2.28.0.rc0.142.g3c755180ce-goog