Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp1213496ybb; Fri, 10 Apr 2020 20:50:53 -0700 (PDT) X-Google-Smtp-Source: APiQypKR8pIGmE5G/30E1gIfxrVq2/kXywgX0YSb2zy6J/UP4bty78Z+71nso1mBA54KCj/f4mDd X-Received: by 2002:a0c:f8c4:: with SMTP id h4mr621245qvo.179.1586577052985; Fri, 10 Apr 2020 20:50:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1586577052; cv=none; d=google.com; s=arc-20160816; b=KKA+S4KnTw9GQwDDKmIB4EUZaCpEwBG1QqpNO0sHqGV4dQg8kk7p+dYlEp5q4KXy4Q DNqtiMNo+dReYHNOwa+RL8BK5tWufYcC3PlU1rgSeB0kQDci6Y9yw7NQ3ARoRAJDl3Rt 0FF2y90Ft9PvVn8PEJgeRvG/EWTlhhoeT0/nidWBa5g9zCzL+//FPJyhSHEAGNInPaIp Ai590ISlCBojeIWWvmCqYHg8Lit/1BV+6uSbMmK4zV+y37+1upbXyknYOBhiXpkL6tMd yprXLqH7ZOLYSaYGr7VwxnysPh0FCnZ4kiJBrMg//OoiLIb4vYT5X+QmUrBdxjK4lL1Y tctA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=QHW72W7RuhbPobSDE07KeyPd/KjygLRzQj6peYexX34=; b=ZIFzW8Zb1eVAK2ChCz7rsCzeAmZNhnzyfun7MUCbJwYaDyS2YOHOGwOHnnBaXTqixL DTM686IAr4kBAjYmat21m0jVDi2nipyGPiLfbHMTpoIsRi4Bi+zeyI4MlUN2BaQ/30P1 BkFjtak8mXmlg3bi2SQluxjsn5rLdZp110LgyyQSN7g0+qQVTeYitvtVaPICv52+iAQ9 CNTK2quK3cJbuYAIP7PWFRzwUd6Ksg5ZGna+Er8e03IUprgNpCQHUvdDlHJkP6VpRjwh 2xXk9uFhxR3R9F0r6pUhpWQHzG3/5qlKSq61FV0zoNtQl+bB3o3A1RDRkL4xFlrmyUSg QrWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BkElBRyv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a17si2317682qkk.177.2020.04.10.20.50.37; Fri, 10 Apr 2020 20:50:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=BkElBRyv; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726679AbgDKDou (ORCPT + 99 others); Fri, 10 Apr 2020 23:44:50 -0400 Received: from mail.kernel.org ([198.145.29.99]:58934 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726659AbgDKDot (ORCPT ); Fri, 10 Apr 2020 23:44:49 -0400 Received: from mail-lf1-f46.google.com (mail-lf1-f46.google.com [209.85.167.46]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id CEC8620708 for ; Sat, 11 Apr 2020 03:44:48 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1586576689; bh=OS2a3zaCRGwhNUfft3nAzcgG17YLWHOXyNtOi4N1dbg=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=BkElBRyvAVAIX0BdvVGYTItGfcjjFA68k+yCMQklskkVFX7lfCyrF6Db6dJoq3DMr XLcaqZWxNiwbDGWaHhQgSgcLzkJa1g6lwNSk9YbIK/yZbZQFLEcCn5Z2uM6rtE9l6h 7AGqdOCAvD9X0reRUIDbJLVmeGT9ToCJLsupLAYM= Received: by mail-lf1-f46.google.com with SMTP id h6so2656327lfc.0 for ; Fri, 10 Apr 2020 20:44:48 -0700 (PDT) X-Gm-Message-State: AGi0PubZ1A3aI87EUwDqpCZlJdZGhZIikRfb6nWsje2PIaUyI4MlXnSD /i26JUPeyyInk6RxMlD6pWySZk3IJqizEHWcYDg= X-Received: by 2002:ac2:5607:: with SMTP id v7mr4293181lfd.212.1586576686950; Fri, 10 Apr 2020 20:44:46 -0700 (PDT) MIME-Version: 1.0 References: <20200410032634.57511-1-zong.li@sifive.com> In-Reply-To: <20200410032634.57511-1-zong.li@sifive.com> From: Guo Ren Date: Sat, 11 Apr 2020 11:44:35 +0800 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH] riscv: remove the assert of lock for cpu_running To: Zong Li Cc: Palmer Dabbelt , Paul Walmsley , Albert Ou , linux-riscv , Linux Kernel Mailing List Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Acked-by: Guo Ren Haha, are you working on lockdep ? Me too, here is my patch, not finished. It's still warning at begin, I've no time to debug, and it's similar to csky's: https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/arch/csky?id=000591f1ca3312d9a29e15a9e3fe5c4171f75586 If you are working on LOCKDEP, I'll wait your patch :) commit 096d7a4b26d21aa7c71c86f200241144569e697a (riscv-lockdep) Author: Guo Ren Date: Fri Apr 10 16:38:37 2020 +0800 riscv: Enable LOCKDEP_SUPPORT Lockdep is needed by proving the spinlocks and rwlocks. Signed-off-by: Guo Ren diff --git a/arch/riscv/Kconfig b/arch/riscv/Kconfig index 8672e77a5b7a..bfe76c76a107 100644 --- a/arch/riscv/Kconfig +++ b/arch/riscv/Kconfig @@ -163,6 +163,9 @@ config PGTABLE_LEVELS default 3 if 64BIT default 2 +config LOCKDEP_SUPPORT + def_bool y + source "arch/riscv/Kconfig.socs" menu "Platform type" diff --git a/arch/riscv/kernel/entry.S b/arch/riscv/kernel/entry.S index 208702d8c18e..41588ee74cb2 100644 --- a/arch/riscv/kernel/entry.S +++ b/arch/riscv/kernel/entry.S @@ -175,6 +175,24 @@ ENTRY(handle_exception) .option pop la ra, ret_from_exception +#ifdef CONFIG_TRACE_IRQFLAGS + call trace_hardirqs_off + la ra, ret_from_exception + REG_L s0, PT_SP(sp) + REG_L s1, PT_STATUS(sp) + REG_L s2, PT_EPC(sp) + REG_L s3, PT_BADADDR(sp) + REG_L s4, PT_CAUSE(sp) + REG_L s5, PT_TP(sp) + REG_L a0, PT_A0(sp) + REG_L a1, PT_A1(sp) + REG_L a2, PT_A2(sp) + REG_L a3, PT_A3(sp) + REG_L a4, PT_A4(sp) + REG_L a5, PT_A5(sp) + REG_L a6, PT_A6(sp) + REG_L a7, PT_A7(sp) +#endif /* * MSB of cause differentiates between * interrupts and exceptions @@ -191,6 +209,24 @@ ENTRY(handle_exception) */ andi t0, s1, SR_PIE beqz t0, 1f +#ifdef CONFIG_TRACE_IRQFLAGS + call trace_hardirqs_on + la ra, ret_from_exception + REG_L s0, PT_SP(sp) + REG_L s1, PT_STATUS(sp) + REG_L s2, PT_EPC(sp) + REG_L s3, PT_BADADDR(sp) + REG_L s4, PT_CAUSE(sp) + REG_L s5, PT_TP(sp) + REG_L a0, PT_A0(sp) + REG_L a1, PT_A1(sp) + REG_L a2, PT_A2(sp) + REG_L a3, PT_A3(sp) + REG_L a4, PT_A4(sp) + REG_L a5, PT_A5(sp) + REG_L a6, PT_A6(sp) + REG_L a7, PT_A7(sp) +#endif csrs CSR_STATUS, SR_IE 1: @@ -291,6 +327,31 @@ resume_userspace: csrw CSR_SCRATCH, tp restore_all: +#ifdef CONFIG_TRACE_IRQFLAGS + REG_L s1, PT_STATUS(sp) + andi t0, s1, SR_PIE + beqz t0, 1f + call trace_hardirqs_on + j 2f +1: + call trace_hardirqs_off +2: + la ra, ret_from_exception + REG_L s0, PT_SP(sp) + REG_L s1, PT_STATUS(sp) + REG_L s2, PT_EPC(sp) + REG_L s3, PT_BADADDR(sp) + REG_L s4, PT_CAUSE(sp) + REG_L s5, PT_TP(sp) + REG_L a0, PT_A0(sp) + REG_L a1, PT_A1(sp) + REG_L a2, PT_A2(sp) + REG_L a3, PT_A3(sp) + REG_L a4, PT_A4(sp) + REG_L a5, PT_A5(sp) + REG_L a6, PT_A6(sp) + REG_L a7, PT_A7(sp) +#endif RESTORE_ALL #ifdef CONFIG_RISCV_M_MODE mret diff --git a/arch/riscv/kernel/smpboot.c b/arch/riscv/kernel/smpboot.c index 8bc01f0ca73b..54fd70eb50bd 100644 --- a/arch/riscv/kernel/smpboot.c +++ b/arch/riscv/kernel/smpboot.c @@ -115,7 +115,7 @@ int __cpu_up(unsigned int cpu, struct task_struct *tidle) task_stack_page(tidle) + THREAD_SIZE); WRITE_ONCE(__cpu_up_task_pointer[hartid], tidle); - lockdep_assert_held(&cpu_running); +// lockdep_assert_held(&cpu_running); wait_for_completion_timeout(&cpu_running, msecs_to_jiffies(1000)); On Fri, Apr 10, 2020 at 11:26 AM Zong Li wrote: > > The cpu_running is not a lock-class, it lacks the dep_map member in > completion. It causes the error as follow: > > arch/riscv/kernel/smpboot.c: In function '__cpu_up': > ./include/linux/lockdep.h:364:52: error: 'struct completion' has no member named 'dep_map' > 364 | #define lockdep_is_held(lock) lock_is_held(&(lock)->dep_map) > | ^~ > ./include/asm-generic/bug.h:113:25: note: in definition of macro 'WARN_ON' > 113 | int __ret_warn_on = !!(condition); \ > | ^~~~~~~~~ > ./include/linux/lockdep.h:390:27: note: in expansion of macro 'lockdep_is_held' > 390 | WARN_ON(debug_locks && !lockdep_is_held(l)); \ > | ^~~~~~~~~~~~~~~ > arch/riscv/kernel/smpboot.c:118:2: note: in expansion of macro 'lockdep_assert_held' > 118 | lockdep_assert_held(&cpu_running); > > Signed-off-by: Zong Li > --- > arch/riscv/kernel/smpboot.c | 1 - > 1 file changed, 1 deletion(-) > > diff --git a/arch/riscv/kernel/smpboot.c b/arch/riscv/kernel/smpboot.c > index 8bc01f0ca73b..bbc1baa2d90c 100644 > --- a/arch/riscv/kernel/smpboot.c > +++ b/arch/riscv/kernel/smpboot.c > @@ -115,7 +115,6 @@ int __cpu_up(unsigned int cpu, struct task_struct *tidle) > task_stack_page(tidle) + THREAD_SIZE); > WRITE_ONCE(__cpu_up_task_pointer[hartid], tidle); > > - lockdep_assert_held(&cpu_running); > wait_for_completion_timeout(&cpu_running, > msecs_to_jiffies(1000)); > > -- > 2.26.0 > > -- Best Regards Guo Ren ML: https://lore.kernel.org/linux-csky/