Received: by 10.223.185.116 with SMTP id b49csp3365749wrg; Tue, 13 Feb 2018 01:13:16 -0800 (PST) X-Google-Smtp-Source: AH8x227MA/bcPLmnWEOHy0jsK9Wyve1ebG3QsWU9VnGzhmsVeymcqRfrAuNhkNcZqcDjNKt+U2il X-Received: by 10.99.116.25 with SMTP id p25mr471036pgc.109.1518513196380; Tue, 13 Feb 2018 01:13:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518513196; cv=none; d=google.com; s=arc-20160816; b=vr550Sz+C7dFLCbbW9i/MLyOnYOEkq+ANjlMyZLEoIjbWPQ3vSNuzgPnbPvlGkQaH6 rCaqH0KIuGtLTehwdxSECoeSwcgXhV6AGufUzPK6FQryo+z0gTvFY90Z0lpsV4b+CfB3 9fhewqiuIE6s6qD+49P3esuALYNrvzQwcPfrcpxPC0/p3j39l1W2u6hAftRTmJpni7G8 epG01PSqVBDawJgc0SPFVg2L+s690WSVGsgz4DvbUoKEx1V+wTYw3D9WcW4uLSNI3wrA nLYynVNSTgn2ohptlzcg0EX9LLGLMqoLY/VdB08Ja0nVSQF7B2QymG/eoWR5IUKvR/pr 1Z/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature :arc-authentication-results; bh=zVDEEZYW5642IoICkYbIVdLryWivzYIj+OtHOh9R/Ms=; b=ZooGUO234vm84SVaZKE9haDPb3Om+OdOjWc+s5aQAzY4SZ7OXFUakCXBKLWGaVvJkN gzaJ2RfbW3+s5sHe235hOEdjNyWyrCgyx3LdH1n/6xe9qs1KwbE2MokOTmAJtO45X8gf D0jOc9M2T08TGYj8ia93TSD5K/AK9LLNqc6lsFZzHUdTISAC6aSbMH7wAnQpwoTFPc2/ b3jsVhAsmFrBMmzUifj9h+9QIFaLD7c2eRFMHb49Kgp6LkWi2G+0Vfv0/OaafqfSJpPK tlcMci/KVzkWaU3rBSl8QRGtYSIJajgYQc1Pk1B3qD9HTAepkc8vrSFjVYK36CrZAuiG Qfgg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=G63oB89u; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id s22-v6si1016227plk.550.2018.02.13.01.13.01; Tue, 13 Feb 2018 01:13:16 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=G63oB89u; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934241AbeBMJL6 (ORCPT + 99 others); Tue, 13 Feb 2018 04:11:58 -0500 Received: from mail-pg0-f67.google.com ([74.125.83.67]:33363 "EHLO mail-pg0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933925AbeBMJLx (ORCPT ); Tue, 13 Feb 2018 04:11:53 -0500 Received: by mail-pg0-f67.google.com with SMTP id g12so1072235pgs.0; Tue, 13 Feb 2018 01:11:52 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :in-reply-to:references; bh=zVDEEZYW5642IoICkYbIVdLryWivzYIj+OtHOh9R/Ms=; b=G63oB89uQKd9BaRauD/dQfEbriUpPLx0iZ+WUfGN5rCZpvAWtiB0qoE3q29OViNn2q uKgzN3GiXySioama2s9ebiS6ewkYdf08TUMxHHV2+bu1RziXi6ArgVFj9ycksVLBve2w bDSPSxbjJc5sg6GvA3+26no3Vah6jLuYFzU52N0L96RZRYiRSqkICOciyZcAzNOfb2QJ e9TkDmtOagLzyXW5AASWEF9KnxPJREJH7eX1/TmNKnif78ZanGCcz7xRjTmReZfmduvW 0hoQRB2okRMX3qNTdxuUiRY50Y0j6RjdhUYqn2HySqgg5Yw104UVTOXsP5IGsZg26nPA EDdg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:in-reply-to:references; bh=zVDEEZYW5642IoICkYbIVdLryWivzYIj+OtHOh9R/Ms=; b=Ht+NG7yTKPP8jnXWuwbPEVUuvFqvjrkygygA3AouDeGwFTAN1rzuLMSz1lAXl9Birc FKzDI+YGAj5I55Z7vLCevetQzlJV4E0Sa4ZXjngnpGrHA57moL8rAALLYh6osgjlbVsf 0gqJOozpsLVjT/8oJG9YkyBBbG9NAdXWdQ3NisfFZ8HtDe+JOn/7WuI85OX4lbb3NmOJ OK2FUgptEnUFpo9ZnSCKp/ZuNExehfL4W+Zg/OCOjKEcVQjfRRoNhZJJUBhpY7f/VWCN 2gS+Og8Km8G28Uw1MKJdUVA/DrdwCKy/y8vmzIE7D0rcn68IWajYh5N/25/A93COoXhQ Uvmg== X-Gm-Message-State: APf1xPDyWNsH0/2voQj51ikRIyNgnzZ9o5e1LhhKOnmW/e/7HcgDlZyz YnHRhpMVZZ+iVxrAnZh5uwQ= X-Received: by 10.99.111.71 with SMTP id k68mr456272pgc.360.1518513112235; Tue, 13 Feb 2018 01:11:52 -0800 (PST) Received: from app09.andestech.com ([118.163.51.199]) by smtp.gmail.com with ESMTPSA id q20sm31434692pfh.178.2018.02.13.01.11.47 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 13 Feb 2018 01:11:51 -0800 (PST) From: Greentime Hu X-Google-Original-From: Greentime Hu To: greentime@andestech.com, linux-kernel@vger.kernel.org, arnd@arndb.de, linux-arch@vger.kernel.org, tglx@linutronix.de, jason@lakedaemon.net, marc.zyngier@arm.com, robh+dt@kernel.org, netdev@vger.kernel.org, deanbo422@gmail.com, devicetree@vger.kernel.org, viro@zeniv.linux.org.uk, dhowells@redhat.com, will.deacon@arm.com, daniel.lezcano@linaro.org, linux-serial@vger.kernel.org, geert.uytterhoeven@gmail.com, linus.walleij@linaro.org, mark.rutland@arm.com, greg@kroah.com, ren_guo@c-sky.com, rdunlap@infradead.org, davem@davemloft.net, jonas@southpole.se, stefan.kristiansson@saunalahti.fi, shorne@gmail.com Cc: green.hu@gmail.com, Vincent Chen Subject: [PATCH v7 15/37] nds32: Atomic operations Date: Tue, 13 Feb 2018 17:09:19 +0800 Message-Id: X-Mailer: git-send-email 2.16.1 In-Reply-To: References: In-Reply-To: References: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch includes the atomic and futex operations. Many atomic operations use the load-lock word(llw) and store-condition word(scw) operations. Signed-off-by: Vincent Chen Signed-off-by: Greentime Hu Acked-by: Arnd Bergmann --- arch/nds32/include/asm/barrier.h | 15 ++++++ arch/nds32/include/asm/futex.h | 103 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 118 insertions(+) create mode 100644 arch/nds32/include/asm/barrier.h create mode 100644 arch/nds32/include/asm/futex.h diff --git a/arch/nds32/include/asm/barrier.h b/arch/nds32/include/asm/barrier.h new file mode 100644 index 000000000000..faafc373ea6c --- /dev/null +++ b/arch/nds32/include/asm/barrier.h @@ -0,0 +1,15 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2005-2017 Andes Technology Corporation + +#ifndef __NDS32_ASM_BARRIER_H +#define __NDS32_ASM_BARRIER_H + +#ifndef __ASSEMBLY__ +#define mb() asm volatile("msync all":::"memory") +#define rmb() asm volatile("msync all":::"memory") +#define wmb() asm volatile("msync store":::"memory") +#include + +#endif /* __ASSEMBLY__ */ + +#endif /* __NDS32_ASM_BARRIER_H */ diff --git a/arch/nds32/include/asm/futex.h b/arch/nds32/include/asm/futex.h new file mode 100644 index 000000000000..eab5e84bd991 --- /dev/null +++ b/arch/nds32/include/asm/futex.h @@ -0,0 +1,103 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2005-2017 Andes Technology Corporation + +#ifndef __NDS32_FUTEX_H__ +#define __NDS32_FUTEX_H__ + +#include +#include +#include + +#define __futex_atomic_ex_table(err_reg) \ + " .pushsection __ex_table,\"a\"\n" \ + " .align 3\n" \ + " .long 1b, 4f\n" \ + " .long 2b, 4f\n" \ + " .popsection\n" \ + " .pushsection .fixup,\"ax\"\n" \ + "4: move %0, " err_reg "\n" \ + " j 3b\n" \ + " .popsection" + +#define __futex_atomic_op(insn, ret, oldval, tmp, uaddr, oparg) \ + smp_mb(); \ + asm volatile( \ + " movi $ta, #0\n" \ + "1: llw %1, [%2+$ta]\n" \ + " " insn "\n" \ + "2: scw %0, [%2+$ta]\n" \ + " beqz %0, 1b\n" \ + " movi %0, #0\n" \ + "3:\n" \ + __futex_atomic_ex_table("%4") \ + : "=&r" (ret), "=&r" (oldval) \ + : "r" (uaddr), "r" (oparg), "i" (-EFAULT) \ + : "cc", "memory") +static inline int +futex_atomic_cmpxchg_inatomic(u32 * uval, u32 __user * uaddr, + u32 oldval, u32 newval) +{ + int ret = 0; + u32 val, tmp, flags; + + if (!access_ok(VERIFY_WRITE, uaddr, sizeof(u32))) + return -EFAULT; + + smp_mb(); + asm volatile (" movi $ta, #0\n" + "1: llw %1, [%6 + $ta]\n" + " sub %3, %1, %4\n" + " cmovz %2, %5, %3\n" + " cmovn %2, %1, %3\n" + "2: scw %2, [%6 + $ta]\n" + " beqz %2, 1b\n" + "3:\n " __futex_atomic_ex_table("%7") + :"+&r"(ret), "=&r"(val), "=&r"(tmp), "=&r"(flags) + :"r"(oldval), "r"(newval), "r"(uaddr), "i"(-EFAULT) + :"$ta", "memory"); + smp_mb(); + + *uval = val; + return ret; +} + +static inline int +arch_futex_atomic_op_inuser(int op, int oparg, int *oval, u32 __user *uaddr) +{ + int oldval = 0, ret; + + + pagefault_disable(); + switch (op) { + case FUTEX_OP_SET: + __futex_atomic_op("move %0, %3", ret, oldval, tmp, uaddr, + oparg); + break; + case FUTEX_OP_ADD: + __futex_atomic_op("add %0, %1, %3", ret, oldval, tmp, uaddr, + oparg); + break; + case FUTEX_OP_OR: + __futex_atomic_op("or %0, %1, %3", ret, oldval, tmp, uaddr, + oparg); + break; + case FUTEX_OP_ANDN: + __futex_atomic_op("and %0, %1, %3", ret, oldval, tmp, uaddr, + ~oparg); + break; + case FUTEX_OP_XOR: + __futex_atomic_op("xor %0, %1, %3", ret, oldval, tmp, uaddr, + oparg); + break; + default: + ret = -ENOSYS; + } + + pagefault_enable(); + + if (!ret) + *oval = oldval; + + return ret; +} +#endif /* __NDS32_FUTEX_H__ */ -- 2.16.1