Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp723266pxf; Wed, 31 Mar 2021 14:35:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxXQPnWRycpoboc7yWt1CYyKkJgAcHEuHkR+j4nQ2tCk1tpXut4G2fII1Qg2RZZr5/f+/xl X-Received: by 2002:a17:906:cc89:: with SMTP id oq9mr5750322ejb.258.1617226516844; Wed, 31 Mar 2021 14:35:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617226516; cv=none; d=google.com; s=arc-20160816; b=EOTEEJK/33dDNS1klTp9k865zyY+5J2ES+TFusAmz/YTdnX2hyf0BWLnuPo2c79wNa DurMc6LW4wAjmPzyGouwK3D3K+kf+Ztd+uUrbY9HjIOYceFKt1X+i6bLuvtDyoJ5myN3 pD5q9CqolYUl0ayCFy41wH1GH2d5VzkqRnbg0tAciHq0vYJikFm70OknFPzXouVOFzWe hPsolAHoHR7M6EjRg6LH2cAZjROvOHRBt0bLXnOE/DsVS8/hHNXsXAa/2+4cgrFV8GzM TChovyPDUw/DC/91Jmn7P7BsFcqZf4sNA6q6K5M5CXZNn6OCXllZSML4RkXjsH2COgsl ZkhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=83qC35j0sT8ux3EecZ4JSXTBbnC5lT5vvU8jPpy+oIo=; b=gEcGApZg18GVEq5k5DdqbBBRB3O1f+xSvXiAVA9QBCP9MF02wsHYTTs/W+wsWyHH7M auKWDXKsAwSHeDxtOJiIHRP7t7RVp6iGpYepDEOQgGlwZIj4yrAUIhi2Emuqdy3esthr PobzrmEjGBbekwdzvxzeFHq0X+0RXOYfnxVNEHQHVehYZ8GYgNqFG31z61jW+yLPAtGX roFbqtemBoJILfgOUaSqucNvqpKTHKB5OcI/f5so4vEPvFvh+8AA4AJyXS0TE/GPnXwl 3Y9SF2Ozwb0U2sjm9laaaRVQTCsu8bsvRPUl4e7moH8D0p57nKzm7SDE/YmPuCDik9bG y/Fg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=qW9htz+1; 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 n1si2681631edv.538.2021.03.31.14.34.54; Wed, 31 Mar 2021 14:35:16 -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=qW9htz+1; 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 S232774AbhCaV22 (ORCPT + 99 others); Wed, 31 Mar 2021 17:28:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51778 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232540AbhCaV1f (ORCPT ); Wed, 31 Mar 2021 17:27:35 -0400 Received: from mail-yb1-xb4a.google.com (mail-yb1-xb4a.google.com [IPv6:2607:f8b0:4864:20::b4a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 43838C0613DB for ; Wed, 31 Mar 2021 14:27:34 -0700 (PDT) Received: by mail-yb1-xb4a.google.com with SMTP id a19so3691780ybg.10 for ; Wed, 31 Mar 2021 14:27:34 -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=83qC35j0sT8ux3EecZ4JSXTBbnC5lT5vvU8jPpy+oIo=; b=qW9htz+1Xajlr5ZlOCWPOGJSyd0/TSkn9e+fyiCr0KHqJua+AlwezhJkvGAUtb8Uus /S4mbwz/r+yDh70gtjVoZeS/Cd8Df/jmcs1PuDY46slrmp+4SqG+psUv2O+ksbCIJsku dIjxKPRi0/bBYhrdnimd0IFEXoBehXd1rxYwYKk6jnrMrv5BJOu5sLPElKsXeAOfL2IR FSzBya2A/E7j+p3qdkcoVeUbSlTHPrCr/FWByGn48UAf6x3/qZaErXzEP1jQigQ+9zTl SKBo2HTMUqAJmQOe4IT5KuTYEDd90h1ZV8EwZpReysv+MJnRxHy6JXArwTScE9I12WVL 7/4Q== 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=83qC35j0sT8ux3EecZ4JSXTBbnC5lT5vvU8jPpy+oIo=; b=g3j5Jr/CvonPKceO+Ent4MyiPA9BdB5bgEmo+7odw1R0fXf+M9TdFdm3rI0okpRHNw jYw5RME/R+HsNAZS3z4dNKMx3lj8IgNuikt/HwAuUXuwgEekeQ+R2+ZuRX4MF3AL6DtD qlB4qToUMGWEtV9mGpPzDLMmPe9Ds/JPXEU2AsrD5yIs3MjHoas2K4gPFc1gn8EY4hya 9C5HmUTfaaQTkh5W2CV3fI1AyDKbtVh6xaQgICXHXkOPgzEwVyyOihzVLn4UQ3C+S+09 bpwnJjKvsbq+ZW6yotJfFNTp4uHDKogvSn9KPQIDrMSL/VAOTM1BQDb51Osk3nzqqErm N4mA== X-Gm-Message-State: AOAM533ab8M35Eke3QvLM4S+JaFNBbCNNPgnGr9vZ+j6wxfODHhcYzoD EF7yLviD4VMgGm9FARQ+hpsbVwNpn8CeRH2WBdg= X-Received: from samitolvanen1.mtv.corp.google.com ([2620:15c:201:2:7933:7015:a5d5:3835]) (user=samitolvanen job=sendgmr) by 2002:a25:3801:: with SMTP id f1mr7850920yba.353.1617226053546; Wed, 31 Mar 2021 14:27:33 -0700 (PDT) Date: Wed, 31 Mar 2021 14:27:09 -0700 In-Reply-To: <20210331212722.2746212-1-samitolvanen@google.com> Message-Id: <20210331212722.2746212-6-samitolvanen@google.com> Mime-Version: 1.0 References: <20210331212722.2746212-1-samitolvanen@google.com> X-Mailer: git-send-email 2.31.0.291.g576ba9dcdaf-goog Subject: [PATCH v4 05/17] workqueue: use WARN_ON_FUNCTION_MISMATCH From: Sami Tolvanen To: Kees Cook Cc: Nathan Chancellor , Nick Desaulniers , Masahiro Yamada , Will Deacon , Jessica Yu , Arnd Bergmann , Tejun Heo , "Paul E. McKenney" , Christoph Hellwig , Peter Zijlstra , Sedat Dilek , bpf@vger.kernel.org, linux-hardening@vger.kernel.org, linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kbuild@vger.kernel.org, linux-pci@vger.kernel.org, linux-kernel@vger.kernel.org, clang-built-linux@googlegroups.com, Sami Tolvanen Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org With CONFIG_CFI_CLANG, a callback function passed to __queue_delayed_work from a module points to a jump table entry defined in the module instead of the one used in the core kernel, which breaks function address equality in this check: WARN_ON_ONCE(timer->function != delayed_work_timer_fn); Use WARN_ON_FUNCTION_MISMATCH() instead to disable the warning when CFI and modules are both enabled. Signed-off-by: Sami Tolvanen Reviewed-by: Kees Cook --- kernel/workqueue.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/kernel/workqueue.c b/kernel/workqueue.c index 0d150da252e8..03fe07d2f39f 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c @@ -1630,7 +1630,7 @@ static void __queue_delayed_work(int cpu, struct workqueue_struct *wq, struct work_struct *work = &dwork->work; WARN_ON_ONCE(!wq); - WARN_ON_ONCE(timer->function != delayed_work_timer_fn); + WARN_ON_FUNCTION_MISMATCH(timer->function, delayed_work_timer_fn); WARN_ON_ONCE(timer_pending(timer)); WARN_ON_ONCE(!list_empty(&work->entry)); -- 2.31.0.291.g576ba9dcdaf-goog