Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp723404pxf; Wed, 31 Mar 2021 14:35:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyieQe8lNJMGVModFGW25qK3v7s1UpJjAUr9uQKIYWkwkE0pKrxAHcSmZ9L2cykBbb7DAKS X-Received: by 2002:a17:906:9501:: with SMTP id u1mr5956460ejx.324.1617226534457; Wed, 31 Mar 2021 14:35:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617226534; cv=none; d=google.com; s=arc-20160816; b=N9aAr+AO3oTFDaJJKgR8MmjCqkbI5di5/6PlOfUUeAbZzuY5kuno29C21YQyZHkNsi WVC1SCzW0PLuHPE9hNfMnNUOiYiXjRflGXoWmX+MunwQ40zDEYqn7rzmD58b4l+i8kOO K4MvLnEh8LOiFMLmtcT0/rD6RvCEPCtRgQ1sk824YknlruWsWtddgSCuLYhJqW5FQm8l 3E2HCq+w5EWUdpX7YazAcXV/28nMzAV4bGucKaBZ0El73SKBX4OEXnFyBnYhznB9Vc1a wb5KZkOeWSjdzADYIINo3CBaTyWee4Re9d8v+bPaJcY5DCdgOh7FRPkPW6L8ifGKzPqp Ayyg== 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=w0Ob8x2IVOI0uzzuSsD4k6M727ovkcvMuqyZX5oqc8o=; b=XJUOlzzcSu//w5ZgI44eBXn8waCzHHYYlO4LaujJLPDC2PkRbx8nZJtVlmHZFJdU2q ApPasP9xG3W1ipkJIu1/4bgv1HtOMiXKQznW3CYzsIzQa+8odDPBqsktFwiVJf/DL3HS kXsytZavMFrUwIl2wuZZ69sWCNlX67uNyGADilFaq0l8Ba1gmuQc1BBKFQ2YS85ztgB5 Z8cCZlXF/2fMdpYSn58dct+/iawiJpT+DsSOMq7ji9O0Z2SuPVpOh41nksJzVvMFc7u+ IgBDBMjcilXDxlQbN9EINnBvl2VLdJV83vPtip3HeloJUcAUEHUMA/RCN3mVSNdPg1XG xhTA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=nI+ENEyW; 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 h28si2980132edj.546.2021.03.31.14.35.06; Wed, 31 Mar 2021 14:35:34 -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=nI+ENEyW; 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 S233076AbhCaV2i (ORCPT + 99 others); Wed, 31 Mar 2021 17:28:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51764 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232585AbhCaV1h (ORCPT ); Wed, 31 Mar 2021 17:27:37 -0400 Received: from mail-qk1-x74a.google.com (mail-qk1-x74a.google.com [IPv6:2607:f8b0:4864:20::74a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 52D41C061574 for ; Wed, 31 Mar 2021 14:27:36 -0700 (PDT) Received: by mail-qk1-x74a.google.com with SMTP id y22so2346284qkb.23 for ; Wed, 31 Mar 2021 14:27:36 -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=w0Ob8x2IVOI0uzzuSsD4k6M727ovkcvMuqyZX5oqc8o=; b=nI+ENEyWz/rNq3xP8nhiHUSZWps3bzcuJMrVtvPjR+rwBVB/lrPv3BQxv4E6KMlKot N2LsEQni14VlVAHF8qnHU7viK/ziWMDnF+LjsDhRC5aIyL3jNfHcFkfBZOz7gp9DHK/O 0JRF/cYTuekKimF/7nWHkbZejho/mozDnjz14/sUDrLrCY52H9gqZiseo5bvX4tsLE3n UInjiRYKcOH12CVIEai20isk8gmvkqMy8DVUqR4KnBFv6jve3oIB8g21fppaRejyMB3V etjDn4nUdij5fV9SBqoW9glwdBH2VxhLNg9QBaiZB4SRwbU9iQX2g4S5jS1L/Ej7xHUS tYmQ== 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=w0Ob8x2IVOI0uzzuSsD4k6M727ovkcvMuqyZX5oqc8o=; b=QQRfrZcOSjkPr3or/vtsjQBZ+UmaUXcoeDszzMEc9UScaz4JaP885t5DyLuvtojU3k zHRGAZPldLn4kcQZBqbA25PRtgJwvHsk1XyBjzvN7j4zO1XdLwjw5EU202MLc4E5SBCF R6gJzpNxRgRDoY0fYWSzxozmgE/e0TXWs4Pg66XK3cYYPwU8s0dPw3vII3fSyrUMJau9 d2uToKm7etvzteAEs1QSkvKzZl53Czj+sRHkXHyqKVOzFAjSaK79qJKFdJI/rTDGkfK7 OytCVmmROmuE3cEYbQzl7fNY7JKdRQRQjqmLlwO2qhd5xvJfCBxanHTw/4DRdK3e69Zk F+1Q== X-Gm-Message-State: AOAM531NjPMdbfVwlAN8woBeG4u+BPftrmeFsixzTfFWNdos8DSDSNah B0eWlJx+P1ugBbkqd5N3qGbeyAWrT4ilnnb5E8A= X-Received: from samitolvanen1.mtv.corp.google.com ([2620:15c:201:2:7933:7015:a5d5:3835]) (user=samitolvanen job=sendgmr) by 2002:a0c:cb0c:: with SMTP id o12mr5070670qvk.54.1617226055502; Wed, 31 Mar 2021 14:27:35 -0700 (PDT) Date: Wed, 31 Mar 2021 14:27:10 -0700 In-Reply-To: <20210331212722.2746212-1-samitolvanen@google.com> Message-Id: <20210331212722.2746212-7-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 06/17] kthread: 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 __kthread_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 != ktead_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/kthread.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/kernel/kthread.c b/kernel/kthread.c index 1578973c5740..a1972eba2917 100644 --- a/kernel/kthread.c +++ b/kernel/kthread.c @@ -963,7 +963,8 @@ static void __kthread_queue_delayed_work(struct kthread_worker *worker, struct timer_list *timer = &dwork->timer; struct kthread_work *work = &dwork->work; - WARN_ON_ONCE(timer->function != kthread_delayed_work_timer_fn); + WARN_ON_FUNCTION_MISMATCH(timer->function, + kthread_delayed_work_timer_fn); /* * If @delay is 0, queue @dwork->work immediately. This is for -- 2.31.0.291.g576ba9dcdaf-goog