Received: by 2002:ac0:a5a7:0:0:0:0:0 with SMTP id m36-v6csp2566546imm; Thu, 9 Aug 2018 15:36:59 -0700 (PDT) X-Google-Smtp-Source: AA+uWPxkX23m4ggW3MFhaZWBJ5dR22dWQue7ZRDIAIdK5GpLGFRyZq0vMN5HfetCcKpCaLCQWs23 X-Received: by 2002:a17:902:aa07:: with SMTP id be7-v6mr3582934plb.109.1533854219734; Thu, 09 Aug 2018 15:36:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1533854219; cv=none; d=google.com; s=arc-20160816; b=TWXOwSE0/u6ZloTlE8cVdqcivyYaQZIjaeySX9P2/8m8st/SrX8Viqwh878axZGEm5 YPCZbcxHGQQH4Fwr2XMtuhyrtlTowTDR5etCSMeR5emJHBJr9Xue3jDZNhOpqtWd89yw SkQII7HCmRyJSsGHsp77Arob4YMdlp4Y3w4QOTmn1BvWi/2PbQlK9szKuBB6o3OsMTNI EcSFFkS8V5/YQpiXe296xlgLdtY7a2as3wFFTKs/3Ihx5uhYac6uD2TS5BD9ryI5MAR8 4bngv5ARRwxTijWQMe0KuUfFt72ThWoziNrabwY8gh4ZHiEPI7mpuorem+rhO4h+vhS9 oLGg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:from:cc:references:in-reply-to :message-id:date:subject:dkim-signature:arc-authentication-results; bh=o4H4JUA/I/YuFlf4T8T0G4dpIKpDacxMwA900eev+NM=; b=CjEftiuJJmpvbPWFhi9qFMv7I/aQXNlLxZr5R5Xc4m0Q5zaft1CnNtSmbQxMawTMG5 fGfW5W4Go/PaSg8KB7RC76UqAieFJKtmu21TTFHz2le2DRdvzxLnMh6rKXulGkr0lvZf AC5INGeNCQQDT6wve9IRuLm8LAuo2lZ8NuDG8FcJMF0zGzZ5PnQSYR7l66MyL9dqNAP4 MN+Z4sd1BsVilHVKTqsEwUkLWsOGA4IC20bOZm6eW6gg2ApPfgBbIII17pcVQPx1CH36 0xwT4YCA/GnUid2v3hDqijXsMbTQ3Fh+t5x/Z1nXH9KklLik06WdI7T9T8e57YJKAc4W 4BRA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@sifive.com header.s=google header.b=ZLKfodpE; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j193-v6si8223777pge.689.2018.08.09.15.36.45; Thu, 09 Aug 2018 15:36:59 -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=@sifive.com header.s=google header.b=ZLKfodpE; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727631AbeHJBB2 (ORCPT + 99 others); Thu, 9 Aug 2018 21:01:28 -0400 Received: from mail-pf1-f196.google.com ([209.85.210.196]:34738 "EHLO mail-pf1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727599AbeHJBB1 (ORCPT ); Thu, 9 Aug 2018 21:01:27 -0400 Received: by mail-pf1-f196.google.com with SMTP id k19-v6so3533144pfi.1 for ; Thu, 09 Aug 2018 15:34:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=subject:date:message-id:in-reply-to:references:cc:from:to; bh=o4H4JUA/I/YuFlf4T8T0G4dpIKpDacxMwA900eev+NM=; b=ZLKfodpEU8crr1rla7YQ1KfYGztUL6jqaimhknSMMdLwSEWECK4a00S93Bd1K5lM3+ Py9XbwIOw3/aMwy2GIFGZZKaiuJcfji9bHMf7CwW8c85IHu+38H/dUdKcXZwtVd9e4zD N7KiIe1PVOnzYdVH/HA+LCcpF7Gz+qUlRxXtfH4fmTHY2Hi8tMQvM2EjjzwsMRGh89mQ 7oSqR+az7+gEe/NeB9cIbGGlmh/OvGhCM6Et59yQHyQz/VELs7IFYMvRY53hLeYms8hg vL8o3HwxQyQsT4Ti0DWJ0dRB+66zUXmqyrHO9o/vUnWfDqD7KINip+Sk5hYFKLZIaZHO ELeA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:date:message-id:in-reply-to:references :cc:from:to; bh=o4H4JUA/I/YuFlf4T8T0G4dpIKpDacxMwA900eev+NM=; b=ubSGPYe80/f3ksf3dFwWbrfHJ6+U2cLSoY5aZkbiPZeYoVZfW+p8KjGoe67OLmbFh1 fIyZi6GpEaJgQxS3d2zOBueBSM592GCI5Ty8eFpXEG9GToGqa0UCqN98obfAPVi5zcSU 0zEc8flnSHUKUdDEUUTDHdGtCx1w1iI1KST/UT1pX43eBNuw2+vpkH7BgcENYfWWfZZp oU8YyVFO5AMYrTTNx5EIUHAQuwdSUOYSLnVr5GmGC6qt938oo9uifGUP6AX/OpknEUB0 CzYIoW6oYXBCAHJYtOsmspELkRFEpkyWcLkbHQim+D6rKEoeZjc36Mb5qnsk4lJNH5DL +8Eg== X-Gm-Message-State: AOUpUlEX3MoLgeQ6KbbsiPhxFg3zgRL12404CoXjNr9WzWTRpUCSb9WC nXa8pRNB72DfdbLhPE22N28IhQ== X-Received: by 2002:a62:4704:: with SMTP id u4-v6mr4210867pfa.76.1533854071081; Thu, 09 Aug 2018 15:34:31 -0700 (PDT) Received: from localhost ([12.206.222.5]) by smtp.gmail.com with ESMTPSA id l84-v6sm13585357pfg.3.2018.08.09.15.34.29 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 09 Aug 2018 15:34:30 -0700 (PDT) Subject: [PATCH v3 1/2] RISC-V: Define sys_riscv_flush_icache when SMP=n Date: Thu, 9 Aug 2018 15:19:51 -0700 Message-Id: <20180809221952.24260-2-palmer@sifive.com> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20180809221952.24260-1-palmer@sifive.com> References: <20180809221952.24260-1-palmer@sifive.com> Cc: Palmer Dabbelt , aou@eecs.berkeley.edu, tklauser@distanz.ch, Arnd Bergmann , Andrew Waterman , linux@dominikbrodowski.net, dan.carpenter@oracle.com, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org, Christoph Hellwig From: Palmer Dabbelt To: Christoph Hellwig , linux@roeck-us.net Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This would be necessary to make non-SMP builds work, but there is another error in the implementation of our syscall linkage that actually just causes sys_riscv_flush_icache to never build. I've build tested this on allnoconfig and allnoconfig+SMP=y, as well as defconfig like normal. CC: Christoph Hellwig CC: Guenter Roeck In-Reply-To: <20180809055830.GA17533@infradead.org> In-Reply-To: <20180809132612.GA31058@roeck-us.net> Signed-off-by: Palmer Dabbelt --- arch/riscv/include/asm/vdso.h | 2 -- arch/riscv/kernel/sys_riscv.c | 12 ++++++++++-- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/arch/riscv/include/asm/vdso.h b/arch/riscv/include/asm/vdso.h index 541544d64c33..ec6180a4b55d 100644 --- a/arch/riscv/include/asm/vdso.h +++ b/arch/riscv/include/asm/vdso.h @@ -38,8 +38,6 @@ struct vdso_data { (void __user *)((unsigned long)(base) + __vdso_##name); \ }) -#ifdef CONFIG_SMP asmlinkage long sys_riscv_flush_icache(uintptr_t, uintptr_t, uintptr_t); -#endif #endif /* _ASM_RISCV_VDSO_H */ diff --git a/arch/riscv/kernel/sys_riscv.c b/arch/riscv/kernel/sys_riscv.c index f7181ed8aafc..568026ccf6e8 100644 --- a/arch/riscv/kernel/sys_riscv.c +++ b/arch/riscv/kernel/sys_riscv.c @@ -48,7 +48,6 @@ SYSCALL_DEFINE6(mmap2, unsigned long, addr, unsigned long, len, } #endif /* !CONFIG_64BIT */ -#ifdef CONFIG_SMP /* * Allows the instruction cache to be flushed from userspace. Despite RISC-V * having a direct 'fence.i' instruction available to userspace (which we @@ -66,15 +65,24 @@ SYSCALL_DEFINE6(mmap2, unsigned long, addr, unsigned long, len, SYSCALL_DEFINE3(riscv_flush_icache, uintptr_t, start, uintptr_t, end, uintptr_t, flags) { +#ifdef CONFIG_SMP struct mm_struct *mm = current->mm; bool local = (flags & SYS_RISCV_FLUSH_ICACHE_LOCAL) != 0; +#endif /* Check the reserved flags. */ if (unlikely(flags & ~SYS_RISCV_FLUSH_ICACHE_ALL)) return -EINVAL; + /* + * Without CONFIG_SMP flush_icache_mm is a just a flush_icache_all(), + * which generates unused variable warnings all over this function. + */ +#ifdef CONFIG_SMP flush_icache_mm(mm, local); +#else + flush_icache_all(); +#endif return 0; } -#endif -- 2.16.4