Received: by 2002:ab2:687:0:b0:1f4:6588:b3a7 with SMTP id s7csp90942lqe; Tue, 9 Apr 2024 15:55:56 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUeL/eTtgclcA+7moWVruAWvUIke9p8QQRKFbetQFzibI29cjU9b9VIWwpM+9bkFm00tDvKazpHtd/3+ayE6J1FThMLa2qi3gsMPaj/uQ== X-Google-Smtp-Source: AGHT+IFmrBW0ann2redCVZosEYSPimj/Lw5RBQnvTTxTEMCyFdNFYrAitnHXLH430rptvCIRh8Qe X-Received: by 2002:a17:90a:101:b0:29b:ccb4:a250 with SMTP id b1-20020a17090a010100b0029bccb4a250mr1006326pjb.16.1712703355767; Tue, 09 Apr 2024 15:55:55 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1712703355; cv=pass; d=google.com; s=arc-20160816; b=HLAXKFpBfOff0DWLtpvX808sbI5yDoDFhWL1uFZwj6yKVbIttpqf6SqXNwg76/k2e9 VsFocgraHV2AVqEEOyypTIafcEEZcc0i++QaWsE1dZExgv4c2Ex+r/m8IImZTE7x11BC 31N/tbdoxSa16/VlziLaYcicfMPxDmnVyO57084PnTu9MidQKSGS9RsyvWqIYrpMH94d qeoDLaSFQ7wkz5EQMCsjwv/HlNWlcacx60MzFsMVFSgMZ0Zkza1OaXH/NugcaqnDHYkI 4WFolC1Hw2cTcOExSeBfWmGWvtVoR9vLSVRdZfJbA9AIUnlkB1w7h4b6guh9nZQkd6mc iK+g== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:message-id:date:subject:cc:to :from:dkim-signature; bh=ARgksq94JO4WsJO5y2SP1QsBo45TQFwA4MyINC37KWc=; fh=ZAVUR+X4DGfW14HNb8oI9vW9cysNo23swaomtVJKAp4=; b=iu5gTWh6UOtqsf1W0YvfXM6GsdG6uOs5sAKeFJ3HHZhr/HJSrWvXtQG+ywzhCsPHxl UjDcnEq34Uqk0/EEUMsnBR/SzsMk7WpQA7RSmhCrJ+UMJvQ0oLHnqGqNPh4B4HOWdebY AkTXgzj26EM32zl4fXOuM1jMBfaWCxFzfPCgBtXGlAN9ohwtoJFBTBXgUAuITaxNffkk zd5AUS4c8XEf+SPVjbgnNnUyBLeZq7s8FRTnVROn5DcYmuPKVR6laejmTXpghyr6ks49 irXtuu+XTZakTJMOxdTB+aY7l559Kcgu7vjWVQlK0YB35Kml6ZSQJVCX8rY3SRwj8mXU zHug==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=QNVhCnQD; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-137678-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-137678-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id ds4-20020a17090b08c400b002a4a629ded5si209772pjb.124.2024.04.09.15.55.55 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 09 Apr 2024 15:55:55 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-137678-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=QNVhCnQD; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-137678-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-137678-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id 7561E284147 for ; Tue, 9 Apr 2024 22:55:55 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 5B4F3158DA4; Tue, 9 Apr 2024 22:55:45 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="QNVhCnQD" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7381B757F6; Tue, 9 Apr 2024 22:55:44 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712703344; cv=none; b=fuiE/9QcqlOrSTR3s13vH3zo9UUVHOI65JN5x5kINj4zDU4WxgijXqJsEd3wyFn6XfHPbMdO+fAkvprjzRL4X7tqN5W1duN44InVsjZyDv5wCZxHH8OrEKMWtAAvO/OO7QTh0L3+yx/+IpCF8Bue2MeKel6SzTY2/h+iKasboyk= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1712703344; c=relaxed/simple; bh=AFB5JJxzNK0ssWsl0dAByIzKSEq22BTDirPDWg2fGr0=; h=From:To:Cc:Subject:Date:Message-ID:MIME-Version; b=WFDG+G6rlOtGkVq7rkS8KG+fNYnO6b1uF8FHf3XFhMntpu6zYqyXRJTYOgncymZPqUQIDzKJ7X5C8lMA72oEMAGKU0r02JnPsR4V3OhFR14KBVGEycVW5XI0GL6iUUrp6b//hus5SqSGSw94gS3maao+fLlbLib5NZh1YNkl3R8= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=QNVhCnQD; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 7F749C433F1; Tue, 9 Apr 2024 22:55:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1712703343; bh=AFB5JJxzNK0ssWsl0dAByIzKSEq22BTDirPDWg2fGr0=; h=From:To:Cc:Subject:Date:From; b=QNVhCnQDb33aAtFoSRkz5s4jbUOSu7zxI1O24mEXGmmBsCG5SmrWgvwL1v1X1dtYo m1xjrrleKCM9BINwTdfNiyjfBLIzbUqFLuvELnPjLGoknpEXUlPez+XkxNLN+xsb/A m/pnRojoDuXa+RYvfQnH9o194L+rBXzwqBUGE7HWKu+STfL4F7xzv9iaK/B5upu6m6 GkRAJ4RrDE9y1Z4eruIUydEFIC7CTyXUlI0vFPFhlzjOiUlsTcLQj86nQa0mI6u6+9 eEhVesQnv13FB9b9MQ/Cuy57LoFkRBABQtCkV8ijQCuoctfV/OtO40Whw7FFCEKxQ0 eAw22zzJc9ahw== From: Namhyung Kim To: Arnaldo Carvalho de Melo , Ian Rogers , Kan Liang Cc: Jiri Olsa , Adrian Hunter , Peter Zijlstra , Ingo Molnar , LKML , linux-perf-users@vger.kernel.org, Arnaldo Carvalho de Melo , Song Liu , bpf@vger.kernel.org Subject: [PATCH v2] perf lock contention: Add a missing NULL check Date: Tue, 9 Apr 2024 15:55:42 -0700 Message-ID: <20240409225542.1870999-1-namhyung@kernel.org> X-Mailer: git-send-email 2.44.0.478.gd926399ef9-goog Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit I got a report for a failure in BPF verifier on a recent kernel with perf lock contention command. It checks task->sighand->siglock without checking if sighand is NULL or not. Let's add one. ; if (&curr->sighand->siglock == (void *)lock) 265: (79) r1 = *(u64 *)(r0 +2624) ; frame1: R0_w=trusted_ptr_task_struct(off=0,imm=0) ; R1_w=rcu_ptr_or_null_sighand_struct(off=0,imm=0) 266: (b7) r2 = 0 ; frame1: R2_w=0 267: (0f) r1 += r2 R1 pointer arithmetic on rcu_ptr_or_null_ prohibited, null-check it first processed 164 insns (limit 1000000) max_states_per_insn 1 total_states 15 peak_states 15 mark_read 5 -- END PROG LOAD LOG -- libbpf: prog 'contention_end': failed to load: -13 libbpf: failed to load object 'lock_contention_bpf' libbpf: failed to load BPF skeleton 'lock_contention_bpf': -13 Failed to load lock-contention BPF skeleton lock contention BPF setup failed lock contention did not detect any lock contention Fixes: 1811e82767dcc ("perf lock contention: Track and show siglock with address") Reviewed-by: Ian Rogers Acked-by: Arnaldo Carvalho de Melo Cc: Song Liu Cc: bpf@vger.kernel.org Signed-off-by: Namhyung Kim --- tools/perf/util/bpf_skel/lock_contention.bpf.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/tools/perf/util/bpf_skel/lock_contention.bpf.c b/tools/perf/util/bpf_skel/lock_contention.bpf.c index fb54bd38e7d0..d931a898c434 100644 --- a/tools/perf/util/bpf_skel/lock_contention.bpf.c +++ b/tools/perf/util/bpf_skel/lock_contention.bpf.c @@ -284,6 +284,7 @@ static inline __u32 check_lock_type(__u64 lock, __u32 flags) struct task_struct *curr; struct mm_struct___old *mm_old; struct mm_struct___new *mm_new; + struct sighand_struct *sighand; switch (flags) { case LCB_F_READ: /* rwsem */ @@ -305,7 +306,9 @@ static inline __u32 check_lock_type(__u64 lock, __u32 flags) break; case LCB_F_SPIN: /* spinlock */ curr = bpf_get_current_task_btf(); - if (&curr->sighand->siglock == (void *)lock) + sighand = curr->sighand; + + if (sighand && &sighand->siglock == (void *)lock) return LCD_F_SIGHAND_LOCK; break; default: -- 2.44.0.478.gd926399ef9-goog