Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp404123pxb; Tue, 9 Feb 2021 03:30:34 -0800 (PST) X-Google-Smtp-Source: ABdhPJwaVntcpfaZi4o5RQmcchEAVbpDeEX9kIpSku/fY8YPQYbD9CEK6cL1s0DBEJXxvoA98KoF X-Received: by 2002:a17:906:71d5:: with SMTP id i21mr11357283ejk.232.1612870234447; Tue, 09 Feb 2021 03:30:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612870234; cv=none; d=google.com; s=arc-20160816; b=lMQc62ajVWWv6wmn4Sx7RIgNiyFCFm1tUq0SF0XDRID1dPaGs1DZ+8gpiutiwuzG96 YvMHiSqqxTh3IAoFjXU+O5oTH2WHb3cLCvkZ+5IVJO/jg/xlEL1rrmND8RtizPKT3alC vJKLQyPH1+udwgyhw4wN8ba4LvmyqNAL5KfC3PwsiqFfbeFOWjwl7PNe+oaXuI7eKJDl 63tQpFz55FbIZ5A3CohVn9XVXGEzBEUaPpUz3KSqpwppVG3MSq4m2ef5mVsvyaBvxd/T tWMgk5ddQtIu50bumz3KL7XyDa6zM0ECkqCrHKcWNfK7hGTENdEOm+qZiqLe/iXYgYl+ 8Vcg== 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:mime-version:message-id:date :sender:dkim-signature; bh=A5PjxBocm6GkKPxXcYzX2e1AeHxW0gP+W7kFc8REg2E=; b=P4Op/8eVhiUdtfWI0HKXP65aRty15757ZhrVigj8g7gLGCZxvtwwOzBUWx9KZfi72W m3QyK4LKWOxciNB6KkKUQ9DzyFgIhChCbke0IQeph7SguPbWlykv6aB+AY8XMkb479fu kYpgmwfmNGNZL/tLRPy4OLgsovo+tAH368eDfRQzS9AQ02vS0ub1tI0ygHxSFE0uYAGv 8euOz3yzjq3/ETaCLbHUCK68fRp6WiGLlMNjXFxhg1E0IMotmaiJ3KqV7EEqsO6oeset pHooBGxf/rUluMqRg/s09/ukKN+CX21B/LZFmVxKrCtCTIVJMbxTHDVuF0MCgcegtJmL pTBQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=ofP339Bc; 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 s17si14085617edw.158.2021.02.09.03.30.10; Tue, 09 Feb 2021 03:30:34 -0800 (PST) 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=ofP339Bc; 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 S229705AbhBIL2q (ORCPT + 99 others); Tue, 9 Feb 2021 06:28:46 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58738 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229733AbhBIL1w (ORCPT ); Tue, 9 Feb 2021 06:27:52 -0500 Received: from mail-wm1-x34a.google.com (mail-wm1-x34a.google.com [IPv6:2a00:1450:4864:20::34a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2EB2FC06178A for ; Tue, 9 Feb 2021 03:27:12 -0800 (PST) Received: by mail-wm1-x34a.google.com with SMTP id n17so2145761wmk.3 for ; Tue, 09 Feb 2021 03:27:12 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=sender:date:message-id:mime-version:subject:from:to:cc; bh=A5PjxBocm6GkKPxXcYzX2e1AeHxW0gP+W7kFc8REg2E=; b=ofP339Bc5incCy4OVOMtxQ6ESTNMLP3Fc6EZ7VuXFsN0nYTCQuk3+Saa2UBlwztZ04 8ZfX/NKW7MwxFkaStBW0GBGHv5nyLJClX5a4HNKpwvY8aZKkDqS18qOB5fmuiBzgx1lx k9IKdZGVfB6c+hJ98cgN3nh35iDKtooVTgyWjrRxFLw76X9Yg3G93wWrLoIHORVj/wj0 9isSi7YjzfOrQGavjf96/f69AWde9QdwEmcAULfGVvVM90BSaujuIMkxeAzRh81H4aGE +n/UGB58fR+evj/4F7nqI10mVBlmJZ9H5/m2oUXnCrvGaHiaY6QFyMXllL0MV+R+pFrf 4vzw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:message-id:mime-version:subject:from :to:cc; bh=A5PjxBocm6GkKPxXcYzX2e1AeHxW0gP+W7kFc8REg2E=; b=EC79sWLOgKmZWiar4SKScu/NwVKyXLxRgcKR57uALB1Zm7cQwFn4oIQI3UMkixzJQe KKjZ/o2gPrIs8XcM0+e47T6aPROQ26lNSSQqGaqAbjUbc5quISHXcuKeF/A8Y5T6+Wyr xnX+LXsYKb9w3ab09eGTqtVl39XBre91aBcwlNU6YRsYHTkF0atM4elEAWfGmAQbuj8x kRv2J01Z5yeBed03hVT/tRGpM1TflMvYEwnlmoO2JWT8MEN+hvNLK375Bdb7M/X714y3 09hpsG7wZg73Ddl5cvDrAUV53xBP2eIDYe6TKMFkFJXnuF2FCQ7WsmTmiMvMQtIJqPMp gPRA== X-Gm-Message-State: AOAM531XOx77thVUHzdhVRgf4Z5PUl+4J+Fj0RIPBU5QJtdWTjc77pPb jknM6as4DKimlFTeLEKpzR4g0QsMEw== Sender: "elver via sendgmr" X-Received: from elver.muc.corp.google.com ([2a00:79e0:15:13:51c9:b9a4:3e29:2cd0]) (user=elver job=sendgmr) by 2002:a05:600c:35c9:: with SMTP id r9mr396002wmq.0.1612870029964; Tue, 09 Feb 2021 03:27:09 -0800 (PST) Date: Tue, 9 Feb 2021 12:27:01 +0100 Message-Id: <20210209112701.3341724-1-elver@google.com> Mime-Version: 1.0 X-Mailer: git-send-email 2.30.0.478.g8a0d178c01-goog Subject: [PATCH] bpf_lru_list: Read double-checked variable once without lock From: Marco Elver To: elver@google.com, ast@kernel.org, daniel@iogearbox.net, andrii@kernel.org, kafai@fb.com, songliubraving@fb.com, yhs@fb.com, john.fastabend@gmail.com, kpsingh@kernel.org, netdev@vger.kernel.org, bpf@vger.kernel.org, linux-kernel@vger.kernel.org Cc: kasan-dev@googlegroups.com, paulmck@kernel.org, dvyukov@google.com, syzbot+3536db46dfa58c573458@syzkaller.appspotmail.com, syzbot+516acdb03d3e27d91bcd@syzkaller.appspotmail.com Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org For double-checked locking in bpf_common_lru_push_free(), node->type is read outside the critical section and then re-checked under the lock. However, concurrent writes to node->type result in data races. For example, the following concurrent access was observed by KCSAN: write to 0xffff88801521bc22 of 1 bytes by task 10038 on cpu 1: __bpf_lru_node_move_in kernel/bpf/bpf_lru_list.c:91 __local_list_flush kernel/bpf/bpf_lru_list.c:298 ... read to 0xffff88801521bc22 of 1 bytes by task 10043 on cpu 0: bpf_common_lru_push_free kernel/bpf/bpf_lru_list.c:507 bpf_lru_push_free kernel/bpf/bpf_lru_list.c:555 ... Fix the data races where node->type is read outside the critical section (for double-checked locking) by marking the access with READ_ONCE() as well as ensuring the variable is only accessed once. Reported-by: syzbot+3536db46dfa58c573458@syzkaller.appspotmail.com Reported-by: syzbot+516acdb03d3e27d91bcd@syzkaller.appspotmail.com Signed-off-by: Marco Elver --- Detailed reports: https://groups.google.com/g/syzkaller-upstream-moderation/c/PwsoQ7bfi8k/m/NH9Ni2WxAQAJ https://groups.google.com/g/syzkaller-upstream-moderation/c/-fXQO9ehxSM/m/RmQEcI2oAQAJ --- kernel/bpf/bpf_lru_list.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/kernel/bpf/bpf_lru_list.c b/kernel/bpf/bpf_lru_list.c index 1b6b9349cb85..d99e89f113c4 100644 --- a/kernel/bpf/bpf_lru_list.c +++ b/kernel/bpf/bpf_lru_list.c @@ -502,13 +502,14 @@ struct bpf_lru_node *bpf_lru_pop_free(struct bpf_lru *lru, u32 hash) static void bpf_common_lru_push_free(struct bpf_lru *lru, struct bpf_lru_node *node) { + u8 node_type = READ_ONCE(node->type); unsigned long flags; - if (WARN_ON_ONCE(node->type == BPF_LRU_LIST_T_FREE) || - WARN_ON_ONCE(node->type == BPF_LRU_LOCAL_LIST_T_FREE)) + if (WARN_ON_ONCE(node_type == BPF_LRU_LIST_T_FREE) || + WARN_ON_ONCE(node_type == BPF_LRU_LOCAL_LIST_T_FREE)) return; - if (node->type == BPF_LRU_LOCAL_LIST_T_PENDING) { + if (node_type == BPF_LRU_LOCAL_LIST_T_PENDING) { struct bpf_lru_locallist *loc_l; loc_l = per_cpu_ptr(lru->common_lru.local_list, node->cpu); -- 2.30.0.478.g8a0d178c01-goog