Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp957076imm; Fri, 15 Jun 2018 08:53:25 -0700 (PDT) X-Google-Smtp-Source: ADUXVKLDxiJJc3CYDsu+AT3onf7Xz2xgpEgqqrIGYY+oQosijDvIw67cZgd+7MQrtdbhm4doq0pS X-Received: by 2002:a62:18a:: with SMTP id 132-v6mr2591500pfb.62.1529078005742; Fri, 15 Jun 2018 08:53:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529078005; cv=none; d=google.com; s=arc-20160816; b=l48vCg1ICGlHpBwsyW80+unw/+PdU341/qRKzgaFpTdP83mjwGU6FO9p1YMinZu6Dn Pw594XolM6t/b8v8HZUJtaCSrOoydfa4tjYMHEg0qPZSRl4thYRyF7M1Zz+Ca4pJmrGi 2L0lUeJV5musYTTqTQDOLyj3AIMfNGFC2bbMvYQO4gqYPODxB+yCxlHnKPj1/lDOU2J9 ezMtS9ycajFOzQrnVmM1u+s8YXOhMyFmp5BfEVYdSR9Gf192fgkj7V6a0y0RT6G3uNfG vBQW+sTKt5z8nSrUT+w/0DtKOSuQVGSW1llh3eLH+8/XlZn72iItT18LpL9p/m0mqAm6 9wcQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :arc-authentication-results; bh=UW7v4H7PQQIYLpZ1Wgjw/Npd4/55aBWqU7MisTEC2yM=; b=wFhg12dG7n6ikaltsy4ae/6NDIiO32ggjQmlmrEEU2gMZfrpHuT3VrOucFxEB9RZT7 EiyE49ScuxLIkGrIlwljEZ/SfiJ0x1eDWeZutPsRAew9H+sy9dgci60wV5r78JAyHPqf +VEVMeuoOX1dksMmPR58oX9k2tZGLVXKuWtfw+bDLSD/vR4mQ3ymnWK9LIHjRsRh/iHm 9UK4RIevR//DkaATvIQP3bm7Y/Xuoe7X9oKiOdARXcJL9dtaxh1rL0nMu5PE6fbqbXvv UIWFh8N6XjgbLYZHgK6CuvtkBR6OVj5LgteGn4zV9yqLLHa0XAuaXysJFnlwqlq0JO5z aKZQ== ARC-Authentication-Results: i=1; mx.google.com; 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 y34-v6si8247860plb.17.2018.06.15.08.53.11; Fri, 15 Jun 2018 08:53:25 -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; 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 S965939AbeFOPwm (ORCPT + 99 others); Fri, 15 Jun 2018 11:52:42 -0400 Received: from mail.bootlin.com ([62.4.15.54]:51786 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S964778AbeFOPwk (ORCPT ); Fri, 15 Jun 2018 11:52:40 -0400 Received: by mail.bootlin.com (Postfix, from userid 110) id 2AA302079D; Fri, 15 Jun 2018 17:52:39 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT, URIBL_BLOCKED shortcircuit=ham autolearn=disabled version=3.4.0 Received: from localhost (AAubervilliers-681-1-37-30.w90-88.abo.wanadoo.fr [90.88.156.30]) by mail.bootlin.com (Postfix) with ESMTPSA id EFB79206A0; Fri, 15 Jun 2018 17:52:38 +0200 (CEST) From: Thomas Petazzoni To: Yoshinori Sato , Rich Felker , linux-sh@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Thomas Petazzoni Subject: [PATCH] arch/sh: use slow path for get_user_pages_fast() on SMP Date: Fri, 15 Jun 2018 17:52:37 +0200 Message-Id: <20180615155237.8166-1-thomas.petazzoni@bootlin.com> X-Mailer: git-send-email 2.14.4 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The fast path of get_user_pages_fast() disables IRQs and then does: - gup_pud_range() - gup_pmd_range() - gup_pte_range() - flush_dcache_page() However, flush_dcache_page() makes a smp_call_function(), and using smp_call_function() when IRQs are disabled is not allowed. In order to work around this problem, this commit prevents the fast path from get_user_pages_fast() from being used on SMP, and directly uses the slow path, which doesn't disable interrupts. Fixes the following warning when get_futex_key() is called: WARNING: CPU: 1 PID: 410 at kernel/smp.c:416 smp_call_function_many+0x1fc/0x2ac Modules linked in: CPU: 1 PID: 410 Comm: wdc-pfmu-test Tainted: G O 4.13.0-00035-g0d3023c733a0-dirty #363 task: 97d9a120 task.stack: 97d2e000 PC is at smp_call_function_many+0x1fc/0x2ac PR is at smp_call_function_many+0x1e2/0x2ac PC : 88071fd4 SP : 97d2fcd4 SR : 400080f1 TEA : c06d6840 R0 : 000000f0 R1 : 00000002 R2 : 00000000 R3 : 8849c89c R4 : 886d62c4 R5 : 886d62c4 R6 : 886db928 R7 : 884a9dec R8 : 00000000 R9 : ffffffff R10 : 8844667c R11 : 29ee9000 R12 : 8844667c R13 : 00000001 R14 : 97d2fcd4 MACH: 000177e7 MACL: 0000018c GBR : 295742d0 PR : 88071fba Call trace: [<8800fe2c>] sh4_flush_dcache_page+0x0/0xa4 [<880720a2>] smp_call_function+0x1e/0x50 [<8800fe2c>] sh4_flush_dcache_page+0x0/0xa4 [<8800ecc0>] flush_dcache_page+0x34/0x74 [<88010d1c>] gup_pte_range+0xd0/0x140 [<88010e04>] gup_pmd_range+0x78/0xa8 [<88010c4c>] gup_pte_range+0x0/0x140 [<88011006>] get_user_pages_fast+0xda/0x130 [<8806f376>] get_futex_key+0x72/0x3a0 [<8806f6a4>] futex_wait_setup+0x0/0x10c [<88055a08>] __rcu_read_unlock+0x0/0x54 [<880559c8>] __rcu_read_lock+0x0/0x1c [<88010f2c>] get_user_pages_fast+0x0/0x130 [<8806f6de>] futex_wait_setup+0x3a/0x10c [<8806f6a4>] futex_wait_setup+0x0/0x10c [<8806f852>] futex_wait+0xa2/0x1b8 [<8806f6a4>] futex_wait_setup+0x0/0x10c [<88071c00>] smp_call_function_single+0xac/0x108 [<8800e908>] cache_noop+0x0/0xc [<8800e908>] cache_noop+0x0/0xc [<88071018>] do_futex+0x108/0x8f8 [<880bdfe4>] finish_fault+0x38/0x70 [<880bdff2>] finish_fault+0x46/0x70 [<880bf212>] handle_mm_fault+0x2f6/0x954 [<880bf21a>] handle_mm_fault+0x2fe/0x954 [<88030e64>] resched_curr+0x54/0x6c [<8832be9e>] _raw_spin_lock_irqsave+0xa/0x18 [<880718dc>] SyS_futex+0xd4/0x124 [<8801488e>] SyS_clone+0x16/0x24 [<8800727e>] syscall_call+0x18/0x1e [<88071808>] SyS_futex+0x0/0x124 Signed-off-by: Thomas Petazzoni --- Note: this is really a work around. Perhaps SuperH should use the generic GUP implementation from mm/gup.c ? Any other solution ? arch/sh/mm/gup.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/arch/sh/mm/gup.c b/arch/sh/mm/gup.c index 56c86ca98ecf..075c8efe6c1d 100644 --- a/arch/sh/mm/gup.c +++ b/arch/sh/mm/gup.c @@ -234,6 +234,9 @@ int get_user_pages_fast(unsigned long start, int nr_pages, int write, if (end < start) goto slow_irqon; + if (IS_ENABLED(CONFIG_SMP)) + goto slow_irqon; + local_irq_disable(); pgdp = pgd_offset(mm, addr); do { -- 2.14.4