Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp230502rwn; Thu, 8 Sep 2022 00:08:43 -0700 (PDT) X-Google-Smtp-Source: AA6agR6K5OwH4DrBReHxbyHsFtgBDTa/dDlwd6NyEL34tNmHWJ4v97SVO0qU8zk0HRqRqRSPLs2k X-Received: by 2002:a05:6402:400e:b0:44f:1b9d:9556 with SMTP id d14-20020a056402400e00b0044f1b9d9556mr4737574eda.208.1662620923248; Thu, 08 Sep 2022 00:08:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1662620923; cv=none; d=google.com; s=arc-20160816; b=P4qZ9iwyhP+12g+cJVtz0D2mUv7hYQnuNkoTCctOLmWq6BnuFrb08oVtoSg3/onWPB XA9WMgAEtcYtZDfPEIAVUHSZc+WQHApWOEmvv8mhg5OEm75Ss274e61jkKlZKjDWGN3u 4njTxoBYI4v+tzflo0oMQ81jIaI8g+PrCrgkQhJGT9zKcAclx8fCMGk4DI+rT3+0225/ 6tVcrk4dGzlY5cgua4gBL5UOTGDK79CZjCvBCOROAnUPKUc0JDD19ZzADTQjZc1NnaJX Eiy0xhO2ST4BO8tQ46qLZzHY81AzvnZ0CKXewvFgDp5lx8udcsA7CmMgCUwKIWB0Lq+u Pvng== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=lJYRFzwH4JLePemhbCSx0zq48/URDmByv8p7ogaW1eM=; b=XNrLcXxg6Dr9zm+COb1AqOSTblxfbdI8muy6UP33j40NWb9sj1MZMz4GkMYqHI7RLU Sfrjcf+Uee1kO0hvbbLLsoErPhjAO4qhdto/IvHLg4UgMfwXpNhF3Kgd6Mcbv69YUnqD g8a3oSUSqSaCHVZ/7gA80orFvV8qUmTtq9T0r/ec8In5nutuzWePNbbOlhJw/k7XIzhh 407s8snQbULfAFNPjONqvzWCk6UH7qJAq3FnThJ41ciZVG4fNxUYlo9eKwNmbF2tz0mn o9nCYIp3vTuW3dMmzFoRpOeTErHZfqTjoITJHHBpq5dK3L8+K24gqMMPvghummIc/ury T2jw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=dxgOW659; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s20-20020aa7d794000000b0043e8b2ed68esi6418866edq.605.2022.09.08.00.08.18; Thu, 08 Sep 2022 00:08:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=dxgOW659; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S230168AbiIHGF5 (ORCPT + 99 others); Thu, 8 Sep 2022 02:05:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44504 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230147AbiIHGFz (ORCPT ); Thu, 8 Sep 2022 02:05:55 -0400 Received: from mail-yw1-x112a.google.com (mail-yw1-x112a.google.com [IPv6:2607:f8b0:4864:20::112a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BDEC822B20 for ; Wed, 7 Sep 2022 23:05:54 -0700 (PDT) Received: by mail-yw1-x112a.google.com with SMTP id 00721157ae682-344fc86d87cso138474377b3.3 for ; Wed, 07 Sep 2022 23:05:54 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date; bh=lJYRFzwH4JLePemhbCSx0zq48/URDmByv8p7ogaW1eM=; b=dxgOW659IivH6ld+oycZtkdr3gYSMaf5uDZRsDYUvQ185actGdsTWmmMsrrWLgybri AkY83nwjwwlVNWRdb6P3iQ1jcISGCuuCYVVz8tORRQuLq3P7H30d8+3dUx8chekDvaUX 1q/Lv+J0p7TDE5qNJqtLPLTyPlKRaaQ2XoOkT0bbM1dsym6ePdy8yT6jrpVR/ad6kBJI lQIwyjMS1rQb8G2PPW+xSuI8oH532YZCPnArrFpBAV8ZBgin2MSD2kyMxHGMUd9c/+vt iUraNSxXT2Mckc/uF3lJbsywOxUJB3MFM2DelphAU4bEt9wrs7twwgyEglRDr4Be+N4K bAHw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date; bh=lJYRFzwH4JLePemhbCSx0zq48/URDmByv8p7ogaW1eM=; b=Ub0aGF7iQDVdwdi8K677atY8xQs11YBtc+8U+HqXDm83jE+aYxogW4FWknORUjLxag 6dEnP7FCyTYPXiGgUE/vrBlTxs/o/cD6LG/HIOnE+m4BZ1vslczYEAFowVSe4QEtWnau ffN5eYS9r8vFwnj41zlv16B2oMI8aaPkpW5xaVbf16ebJ+bYdQtsbfPt/KUI7uJDzpmK mp3/J5rd+E55IWOGDn0CGeffw0tNM9scz5vo14G37ylCQooCjNnkhBCwBp+vGd7aQl9e rXPb3GUH0zmItnbJfzQiOcJWZ+z1kJsGC9xQW5SjvzQlD1YNQf92LPxcBmixCzIXV178 0J8g== X-Gm-Message-State: ACgBeo2mzZm5K8GunLsz8Y1JzHShkLgEIyq8gPBo1vlkdtDr2Ls/jw+W VprsPhwpbBo4SwSQoo19lngjb4NMbGzyAWNa5DJxcg== X-Received: by 2002:a81:bb41:0:b0:328:fd1b:5713 with SMTP id a1-20020a81bb41000000b00328fd1b5713mr6423586ywl.238.1662617153642; Wed, 07 Sep 2022 23:05:53 -0700 (PDT) MIME-Version: 1.0 References: <20220907173903.2268161-1-elver@google.com> In-Reply-To: <20220907173903.2268161-1-elver@google.com> From: Marco Elver Date: Thu, 8 Sep 2022 08:05:17 +0200 Message-ID: Subject: Re: [PATCH 1/2] kcsan: Instrument memcpy/memset/memmove with newer Clang To: elver@google.com, "Paul E. McKenney" Cc: Mark Rutland , Dmitry Vyukov , Alexander Potapenko , Boqun Feng , kasan-dev@googlegroups.com, linux-kernel@vger.kernel.org, Nathan Chancellor , Nick Desaulniers , llvm@lists.linux.dev, stable@vger.kernel.org Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-17.6 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF, ENV_AND_HDR_SPF_MATCH,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,USER_IN_DEF_DKIM_WL,USER_IN_DEF_SPF_WL autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 7 Sept 2022 at 19:39, Marco Elver wrote: > > With Clang version 16+, -fsanitize=thread will turn > memcpy/memset/memmove calls in instrumented functions into > __tsan_memcpy/__tsan_memset/__tsan_memmove calls respectively. > > Add these functions to the core KCSAN runtime, so that we (a) catch data > races with mem* functions, and (b) won't run into linker errors with > such newer compilers. > > Cc: stable@vger.kernel.org # v5.10+ > Signed-off-by: Marco Elver > --- > kernel/kcsan/core.c | 27 +++++++++++++++++++++++++++ > 1 file changed, 27 insertions(+) > > diff --git a/kernel/kcsan/core.c b/kernel/kcsan/core.c > index fe12dfe254ec..66ef48aa86e0 100644 > --- a/kernel/kcsan/core.c > +++ b/kernel/kcsan/core.c > @@ -18,6 +18,7 @@ > #include > #include > #include > +#include > #include > > #include "encoding.h" > @@ -1308,3 +1309,29 @@ noinline void __tsan_atomic_signal_fence(int memorder) > } > } > EXPORT_SYMBOL(__tsan_atomic_signal_fence); > + > +void *__tsan_memset(void *s, int c, size_t count); > +noinline void *__tsan_memset(void *s, int c, size_t count) > +{ > + check_access(s, count, KCSAN_ACCESS_WRITE, _RET_IP_); > + return __memset(s, c, count); > +} > +EXPORT_SYMBOL(__tsan_memset); > + > +void *__tsan_memmove(void *dst, const void *src, size_t len); > +noinline void *__tsan_memmove(void *dst, const void *src, size_t len) > +{ > + check_access(dst, len, KCSAN_ACCESS_WRITE, _RET_IP_); > + check_access(src, len, 0, _RET_IP_); > + return __memmove(dst, src, len); > +} > +EXPORT_SYMBOL(__tsan_memmove); > + > +void *__tsan_memcpy(void *dst, const void *src, size_t len); > +noinline void *__tsan_memcpy(void *dst, const void *src, size_t len) > +{ > + check_access(dst, len, KCSAN_ACCESS_WRITE, _RET_IP_); > + check_access(src, len, 0, _RET_IP_); > + return __memcpy(dst, src, len); > +} > +EXPORT_SYMBOL(__tsan_memcpy); I missed that s390 doesn't have arch memcpy variants, so this fails: >> kernel/kcsan/core.c:1316:16: error: implicit declaration of function '__memset'; did you mean '__memset64'? [-Werror=implicit-function-declaration] I'll send a v2 where __tsan_mem* is aliased to generic versions if the arch doesn't have mem*() functions. > -- > 2.37.2.789.g6183377224-goog >