Received: by 10.223.185.116 with SMTP id b49csp3408169wrg; Tue, 13 Feb 2018 01:59:12 -0800 (PST) X-Google-Smtp-Source: AH8x227Ar9FQjQOVDkUurG/8dz5ZkTUecP+tBKeRiSRygxu3OZXtvJpTmIfzdQ9HPu30ZATEs3Om X-Received: by 10.99.96.146 with SMTP id u140mr551776pgb.211.1518515952717; Tue, 13 Feb 2018 01:59:12 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518515952; cv=none; d=google.com; s=arc-20160816; b=Mh4LiGuR77g7c53A2dGm8Ef713Vw+WCMdF3mGJJ05Ax/VmGCmRTsU9mOmRObpxiGrs ELr3faQ1iwJaZhCTQ61frPluEjh1sOkxLNfLiqiuzNxS83qOqTaUb3qt6TBtQVj4wH43 cEXmw4gOvt+fBz/x0XzUMk2KEJGlCPgZ40TkAYhocMqkgp8pAOv3WIoK82DH8A55nVys 1nB4FFx4t3UZ256kHHKZfxu+tHe0/xsDZJsMWzSt77KkbkwQXlYK79AKRa4U2DNJz0r4 jvULb6EDcup0u48cDuvV2WmRT+I0wvLwrPIS3rbuaxB1R5uvPGBHbM9YwXirFl1ecg5o zX/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=xgHzkhJWBoJv/Fl/sRwkdRpdpsVaXVMq6WjRbtStb2U=; b=tMcSnMPtpVppdHWh5nUzR2Xhk6E+OG8wJXzZPqIA1HKoeDBl86ZXsldqLgzuIUWJcE /u2HpdVE3JPYxQgS5fGY/o4CB7EBrf66GqhUZ2mQuvNxVng5RLVSD3rr1Gd2SPf83gue dqfnsG8/pprSYgiYRM7ueL5NHsfuI9gHWHXwp2UrYfJFnCQ2amvm8Kh0e2XvV4XWsf2P w6JkFGiFiHBozGWFiL4vLG+rZHtztLDMirDtC+Eq9eeCnGcPB7dQSo/MyAVIaEXG3XOX i5tXfZIvUzp/+cw7Kwr5bfxeVURki4SoqIgLug3Derbe9ITMRfDpF/A+Jr/htVfefodT bI7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=O5E/vD6a; 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 c23-v6si867079plk.567.2018.02.13.01.58.58; Tue, 13 Feb 2018 01:59:12 -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=O5E/vD6a; 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 S934779AbeBMJ6E (ORCPT + 99 others); Tue, 13 Feb 2018 04:58:04 -0500 Received: from mail-pl0-f65.google.com ([209.85.160.65]:43100 "EHLO mail-pl0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S934101AbeBMJL5 (ORCPT ); Tue, 13 Feb 2018 04:11:57 -0500 Received: by mail-pl0-f65.google.com with SMTP id f4so6348983plr.10; Tue, 13 Feb 2018 01:11:57 -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=xgHzkhJWBoJv/Fl/sRwkdRpdpsVaXVMq6WjRbtStb2U=; b=O5E/vD6aIAy2Kg8FOqH/QZGmVqFt6tFpAsT70T06i4GPX26bJ5CC1XUyOCXrXP7KZ/ aXji5pbdQ8nk9y0gg0fWLQj+fFBXM/ROJX9LxuiqJgflFFHNNvc9+C7dAJ2oY6BC+Jac DAgOUd248/n030rxHtlQ9wnzwhymsfZ21iE3akoxCE6P1pj0gAd/dSz3LWhUCihrsID0 81IOjz+MacE50wyt1e1BBwGQn5kjWkd5kb3+OYi7S5GCMmmpa7xmPOv5tlbySxSTOOwK UfWGQA14/bLrJnzQIRoofoYvbJq7mH05eGUXCTrRkCzIky7F0t7rBUz6XPhAYcpF2Pdf edzQ== 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=xgHzkhJWBoJv/Fl/sRwkdRpdpsVaXVMq6WjRbtStb2U=; b=H6x0idIq1qmj8npzEAm5wEkoKtAUuQPg778b/bZ5I9cOY48dbjg4LoCcqXuTKIucjG tEz+P4UkwgMr+WyMNZ/vPTQcjbGqi6Sr4TZVyO45bBMG2RH5Ws/4N/rUJZgXW/OUCCKr ZgmXGaVFdgZbtH0dQSotfsXfVyG5l9Q/iLfDmtJWF97d7gwQ+y/gJASUTwA0rkeWQafC BttjTcDucZ0I4y3XD9vdD5liZrZdY4xVsF3sBWNInYiHrovF2SSTuysXHxZEPezzy7j8 r7Y0koa822JUeoBlXrV5q2PyJ10MRuPhNB8ecQ9stSr/YXaDCQWn1DmGuNTUidk27kry W45w== X-Gm-Message-State: APf1xPD5poGhFnrLz+IDviiI1nr+O3O4yW7XdmJzGm5vl/sfQ1PZdPcj 4LhvBC3Kty43FvaCnGxi8mA= X-Received: by 2002:a17:902:5501:: with SMTP id f1-v6mr287657pli.50.1518513116950; Tue, 13 Feb 2018 01:11:56 -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.52 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Tue, 13 Feb 2018 01:11:56 -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 16/37] nds32: Device specific operations Date: Tue, 13 Feb 2018 17:09:20 +0800 Message-Id: <7e158934acdeac150645a303de21b7ed9c75e4ff.1518505384.git.greentime@andestech.com> 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 introduces ioremap implementations. Signed-off-by: Vincent Chen Signed-off-by: Greentime Hu Acked-by: Arnd Bergmann --- arch/nds32/include/asm/io.h | 83 +++++++++++++++++++++++++++++++++++++++++++++ arch/nds32/mm/ioremap.c | 62 +++++++++++++++++++++++++++++++++ 2 files changed, 145 insertions(+) create mode 100644 arch/nds32/include/asm/io.h create mode 100644 arch/nds32/mm/ioremap.c diff --git a/arch/nds32/include/asm/io.h b/arch/nds32/include/asm/io.h new file mode 100644 index 000000000000..966e71b3c960 --- /dev/null +++ b/arch/nds32/include/asm/io.h @@ -0,0 +1,83 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2005-2017 Andes Technology Corporation + +#ifndef __ASM_NDS32_IO_H +#define __ASM_NDS32_IO_H + +extern void iounmap(volatile void __iomem *addr); +#define __raw_writeb __raw_writeb +static inline void __raw_writeb(u8 val, volatile void __iomem *addr) +{ + asm volatile("sbi %0, [%1]" : : "r" (val), "r" (addr)); +} + +#define __raw_writew __raw_writew +static inline void __raw_writew(u16 val, volatile void __iomem *addr) +{ + asm volatile("shi %0, [%1]" : : "r" (val), "r" (addr)); +} + +#define __raw_writel __raw_writel +static inline void __raw_writel(u32 val, volatile void __iomem *addr) +{ + asm volatile("swi %0, [%1]" : : "r" (val), "r" (addr)); +} + +#define __raw_readb __raw_readb +static inline u8 __raw_readb(const volatile void __iomem *addr) +{ + u8 val; + + asm volatile("lbi %0, [%1]" : "=r" (val) : "r" (addr)); + return val; +} + +#define __raw_readw __raw_readw +static inline u16 __raw_readw(const volatile void __iomem *addr) +{ + u16 val; + + asm volatile("lhi %0, [%1]" : "=r" (val) : "r" (addr)); + return val; +} + +#define __raw_readl __raw_readl +static inline u32 __raw_readl(const volatile void __iomem *addr) +{ + u32 val; + + asm volatile("lwi %0, [%1]" : "=r" (val) : "r" (addr)); + return val; +} + +#define __iormb() rmb() +#define __iowmb() wmb() + +#define mmiowb() __asm__ __volatile__ ("msync all" : : : "memory"); + +/* + * {read,write}{b,w,l,q}_relaxed() are like the regular version, but + * are not guaranteed to provide ordering against spinlocks or memory + * accesses. + */ + +#define readb_relaxed(c) ({ u8 __v = __raw_readb(c); __v; }) +#define readw_relaxed(c) ({ u16 __v = le16_to_cpu((__force __le16)__raw_readw(c)); __v; }) +#define readl_relaxed(c) ({ u32 __v = le32_to_cpu((__force __le32)__raw_readl(c)); __v; }) +#define writeb_relaxed(v,c) ((void)__raw_writeb((v),(c))) +#define writew_relaxed(v,c) ((void)__raw_writew((__force u16)cpu_to_le16(v),(c))) +#define writel_relaxed(v,c) ((void)__raw_writel((__force u32)cpu_to_le32(v),(c))) + +/* + * {read,write}{b,w,l,q}() access little endian memory and return result in + * native endianness. + */ +#define readb(c) ({ u8 __v = readb_relaxed(c); __iormb(); __v; }) +#define readw(c) ({ u16 __v = readw_relaxed(c); __iormb(); __v; }) +#define readl(c) ({ u32 __v = readl_relaxed(c); __iormb(); __v; }) + +#define writeb(v,c) ({ __iowmb(); writeb_relaxed((v),(c)); }) +#define writew(v,c) ({ __iowmb(); writew_relaxed((v),(c)); }) +#define writel(v,c) ({ __iowmb(); writel_relaxed((v),(c)); }) +#include +#endif /* __ASM_NDS32_IO_H */ diff --git a/arch/nds32/mm/ioremap.c b/arch/nds32/mm/ioremap.c new file mode 100644 index 000000000000..690140bb23a2 --- /dev/null +++ b/arch/nds32/mm/ioremap.c @@ -0,0 +1,62 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2005-2017 Andes Technology Corporation + +#include +#include +#include +#include + +void __iomem *ioremap(phys_addr_t phys_addr, size_t size); + +static void __iomem *__ioremap_caller(phys_addr_t phys_addr, size_t size, + void *caller) +{ + struct vm_struct *area; + unsigned long addr, offset, last_addr; + pgprot_t prot; + + /* Don't allow wraparound or zero size */ + last_addr = phys_addr + size - 1; + if (!size || last_addr < phys_addr) + return NULL; + + /* + * Mappings have to be page-aligned + */ + offset = phys_addr & ~PAGE_MASK; + phys_addr &= PAGE_MASK; + size = PAGE_ALIGN(last_addr + 1) - phys_addr; + + /* + * Ok, go for it.. + */ + area = get_vm_area_caller(size, VM_IOREMAP, caller); + if (!area) + return NULL; + + area->phys_addr = phys_addr; + addr = (unsigned long)area->addr; + prot = __pgprot(_PAGE_V | _PAGE_M_KRW | _PAGE_D | + _PAGE_G | _PAGE_C_DEV); + if (ioremap_page_range(addr, addr + size, phys_addr, prot)) { + vunmap((void *)addr); + return NULL; + } + return (__force void __iomem *)(offset + (char *)addr); + +} + +void __iomem *ioremap(phys_addr_t phys_addr, size_t size) +{ + return __ioremap_caller(phys_addr, size, + __builtin_return_address(0)); +} + +EXPORT_SYMBOL(ioremap); + +void iounmap(volatile void __iomem * addr) +{ + vunmap((void *)(PAGE_MASK & (unsigned long)addr)); +} + +EXPORT_SYMBOL(iounmap); -- 2.16.1