Commit 68a64357 authored by Benjamin Herrenschmidt's avatar Benjamin Herrenschmidt Committed by Paul Mackerras

[POWERPC] Merge 32 and 64 bits asm-powerpc/io.h

powerpc: Merge 32 and 64 bits asm-powerpc/io.h

The rework on io.h done for the new hookable accessors made it easier,
so I just finished the work and merged 32 and 64 bits io.h for arch/powerpc.

arch/ppc still uses the old version in asm-ppc, there is just too much gunk
in there that I really can't be bothered trying to cleanup.
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent 3d1ea8e8
...@@ -72,7 +72,7 @@ obj-$(CONFIG_AUDIT) += audit.o ...@@ -72,7 +72,7 @@ obj-$(CONFIG_AUDIT) += audit.o
obj64-$(CONFIG_AUDIT) += compat_audit.o obj64-$(CONFIG_AUDIT) += compat_audit.o
ifneq ($(CONFIG_PPC_INDIRECT_IO),y) ifneq ($(CONFIG_PPC_INDIRECT_IO),y)
pci64-$(CONFIG_PPC64) += iomap.o obj-y += iomap.o
endif endif
ifeq ($(CONFIG_PPC_ISERIES),y) ifeq ($(CONFIG_PPC_ISERIES),y)
......
...@@ -117,3 +117,90 @@ void _outsl_ns(volatile u32 __iomem *port, const void *buf, long count) ...@@ -117,3 +117,90 @@ void _outsl_ns(volatile u32 __iomem *port, const void *buf, long count)
asm volatile("sync"); asm volatile("sync");
} }
EXPORT_SYMBOL(_outsl_ns); EXPORT_SYMBOL(_outsl_ns);
#define IO_CHECK_ALIGN(v,a) ((((unsigned long)(v)) & ((a) - 1)) == 0)
void _memset_io(volatile void __iomem *addr, int c, unsigned long n)
{
void *p = (void __force *)addr;
u32 lc = c;
lc |= lc << 8;
lc |= lc << 16;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && !IO_CHECK_ALIGN(p, 4)) {
*((volatile u8 *)p) = c;
p++;
n--;
}
while(n >= 4) {
*((volatile u32 *)p) = lc;
p += 4;
n -= 4;
}
while(n) {
*((volatile u8 *)p) = c;
p++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
}
EXPORT_SYMBOL(_memset_io);
void _memcpy_fromio(void *dest, const volatile void __iomem *src,
unsigned long n)
{
void *vsrc = (void __force *) src;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && (!IO_CHECK_ALIGN(vsrc, 4) || !IO_CHECK_ALIGN(dest, 4))) {
*((u8 *)dest) = *((volatile u8 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc++;
dest++;
n--;
}
while(n > 4) {
*((u32 *)dest) = *((volatile u32 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc += 4;
dest += 4;
n -= 4;
}
while(n) {
*((u8 *)dest) = *((volatile u8 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc++;
dest++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
}
EXPORT_SYMBOL(_memcpy_fromio);
void _memcpy_toio(volatile void __iomem *dest, const void *src, unsigned long n)
{
void *vdest = (void __force *) dest;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && (!IO_CHECK_ALIGN(vdest, 4) || !IO_CHECK_ALIGN(src, 4))) {
*((volatile u8 *)vdest) = *((u8 *)src);
src++;
vdest++;
n--;
}
while(n > 4) {
*((volatile u32 *)vdest) = *((volatile u32 *)src);
src += 4;
vdest += 4;
n-=4;
}
while(n) {
*((volatile u8 *)vdest) = *((u8 *)src);
src++;
vdest++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
}
EXPORT_SYMBOL(_memcpy_toio);
...@@ -106,7 +106,7 @@ EXPORT_SYMBOL(iowrite32_rep); ...@@ -106,7 +106,7 @@ EXPORT_SYMBOL(iowrite32_rep);
void __iomem *ioport_map(unsigned long port, unsigned int len) void __iomem *ioport_map(unsigned long port, unsigned int len)
{ {
return (void __iomem *) (port+pci_io_base); return (void __iomem *) (port + _IO_BASE);
} }
void ioport_unmap(void __iomem *addr) void ioport_unmap(void __iomem *addr)
......
...@@ -1561,7 +1561,7 @@ static struct resource *__pci_mmap_make_offset(struct pci_dev *dev, ...@@ -1561,7 +1561,7 @@ static struct resource *__pci_mmap_make_offset(struct pci_dev *dev,
*offset += hose->pci_mem_offset; *offset += hose->pci_mem_offset;
res_bit = IORESOURCE_MEM; res_bit = IORESOURCE_MEM;
} else { } else {
io_offset = hose->io_base_virt - ___IO_BASE; io_offset = hose->io_base_virt - (void __iomem *)_IO_BASE;
*offset += io_offset; *offset += io_offset;
res_bit = IORESOURCE_IO; res_bit = IORESOURCE_IO;
} }
...@@ -1816,7 +1816,8 @@ void pci_resource_to_user(const struct pci_dev *dev, int bar, ...@@ -1816,7 +1816,8 @@ void pci_resource_to_user(const struct pci_dev *dev, int bar,
return; return;
if (rsrc->flags & IORESOURCE_IO) if (rsrc->flags & IORESOURCE_IO)
offset = ___IO_BASE - hose->io_base_virt + hose->io_base_phys; offset = (void __iomem *)_IO_BASE - hose->io_base_virt
+ hose->io_base_phys;
*start = rsrc->start + offset; *start = rsrc->start + offset;
*end = rsrc->end + offset; *end = rsrc->end + offset;
...@@ -1835,35 +1836,6 @@ pci_init_resource(struct resource *res, unsigned long start, unsigned long end, ...@@ -1835,35 +1836,6 @@ pci_init_resource(struct resource *res, unsigned long start, unsigned long end,
res->child = NULL; res->child = NULL;
} }
void __iomem *pci_iomap(struct pci_dev *dev, int bar, unsigned long max)
{
unsigned long start = pci_resource_start(dev, bar);
unsigned long len = pci_resource_len(dev, bar);
unsigned long flags = pci_resource_flags(dev, bar);
if (!len)
return NULL;
if (max && len > max)
len = max;
if (flags & IORESOURCE_IO)
return ioport_map(start, len);
if (flags & IORESOURCE_MEM)
/* Not checking IORESOURCE_CACHEABLE because PPC does
* not currently distinguish between ioremap and
* ioremap_nocache.
*/
return ioremap(start, len);
/* What? */
return NULL;
}
void pci_iounmap(struct pci_dev *dev, void __iomem *addr)
{
/* Nothing to do */
}
EXPORT_SYMBOL(pci_iomap);
EXPORT_SYMBOL(pci_iounmap);
unsigned long pci_address_to_pio(phys_addr_t address) unsigned long pci_address_to_pio(phys_addr_t address)
{ {
struct pci_controller* hose = hose_head; struct pci_controller* hose = hose_head;
......
...@@ -38,6 +38,7 @@ ...@@ -38,6 +38,7 @@
#include <asm/rtas.h> #include <asm/rtas.h>
#include <asm/mpic.h> #include <asm/mpic.h>
#include <asm/ppc-pci.h> #include <asm/ppc-pci.h>
#include <asm/eeh.h>
/* RTAS tokens */ /* RTAS tokens */
static int read_pci_config; static int read_pci_config;
......
...@@ -53,10 +53,6 @@ ...@@ -53,10 +53,6 @@
#endif #endif
#include <asm/kexec.h> #include <asm/kexec.h>
#ifdef CONFIG_PPC64 /* XXX */
#define _IO_BASE pci_io_base
#endif
#ifdef CONFIG_DEBUGGER #ifdef CONFIG_DEBUGGER
int (*__debugger)(struct pt_regs *regs); int (*__debugger)(struct pt_regs *regs);
int (*__debugger_ipi)(struct pt_regs *regs); int (*__debugger_ipi)(struct pt_regs *regs);
...@@ -241,7 +237,7 @@ void system_reset_exception(struct pt_regs *regs) ...@@ -241,7 +237,7 @@ void system_reset_exception(struct pt_regs *regs)
*/ */
static inline int check_io_access(struct pt_regs *regs) static inline int check_io_access(struct pt_regs *regs)
{ {
#if defined(CONFIG_PPC_PMAC) && defined(CONFIG_PPC32) #ifdef CONFIG_PPC32
unsigned long msr = regs->msr; unsigned long msr = regs->msr;
const struct exception_table_entry *entry; const struct exception_table_entry *entry;
unsigned int *nip = (unsigned int *)regs->nip; unsigned int *nip = (unsigned int *)regs->nip;
...@@ -274,7 +270,7 @@ static inline int check_io_access(struct pt_regs *regs) ...@@ -274,7 +270,7 @@ static inline int check_io_access(struct pt_regs *regs)
return 1; return 1;
} }
} }
#endif /* CONFIG_PPC_PMAC && CONFIG_PPC32 */ #endif /* CONFIG_PPC32 */
return 0; return 0;
} }
......
...@@ -148,6 +148,13 @@ ioremap(phys_addr_t addr, unsigned long size) ...@@ -148,6 +148,13 @@ ioremap(phys_addr_t addr, unsigned long size)
} }
EXPORT_SYMBOL(ioremap); EXPORT_SYMBOL(ioremap);
void __iomem *
ioremap_flags(phys_addr_t addr, unsigned long size, unsigned long flags)
{
return __ioremap(addr, size, flags);
}
EXPORT_SYMBOL(ioremap_flags);
void __iomem * void __iomem *
__ioremap(phys_addr_t addr, unsigned long size, unsigned long flags) __ioremap(phys_addr_t addr, unsigned long size, unsigned long flags)
{ {
...@@ -247,20 +254,7 @@ void iounmap(volatile void __iomem *addr) ...@@ -247,20 +254,7 @@ void iounmap(volatile void __iomem *addr)
} }
EXPORT_SYMBOL(iounmap); EXPORT_SYMBOL(iounmap);
void __iomem *ioport_map(unsigned long port, unsigned int len) int map_page(unsigned long va, phys_addr_t pa, int flags)
{
return (void __iomem *) (port + _IO_BASE);
}
void ioport_unmap(void __iomem *addr)
{
/* Nothing to do */
}
EXPORT_SYMBOL(ioport_map);
EXPORT_SYMBOL(ioport_unmap);
int
map_page(unsigned long va, phys_addr_t pa, int flags)
{ {
pmd_t *pd; pmd_t *pd;
pte_t *pg; pte_t *pg;
......
...@@ -113,7 +113,7 @@ static int map_io_page(unsigned long ea, unsigned long pa, int flags) ...@@ -113,7 +113,7 @@ static int map_io_page(unsigned long ea, unsigned long pa, int flags)
} }
static void __iomem * __ioremap_com(unsigned long addr, unsigned long pa, static void __iomem * __ioremap_com(phys_addr_t addr, unsigned long pa,
unsigned long ea, unsigned long size, unsigned long ea, unsigned long size,
unsigned long flags) unsigned long flags)
{ {
...@@ -129,7 +129,7 @@ static void __iomem * __ioremap_com(unsigned long addr, unsigned long pa, ...@@ -129,7 +129,7 @@ static void __iomem * __ioremap_com(unsigned long addr, unsigned long pa,
return (void __iomem *) (ea + (addr & ~PAGE_MASK)); return (void __iomem *) (ea + (addr & ~PAGE_MASK));
} }
void __iomem * __ioremap(unsigned long addr, unsigned long size, void __iomem * __ioremap(phys_addr_t addr, unsigned long size,
unsigned long flags) unsigned long flags)
{ {
unsigned long pa, ea; unsigned long pa, ea;
...@@ -169,7 +169,7 @@ void __iomem * __ioremap(unsigned long addr, unsigned long size, ...@@ -169,7 +169,7 @@ void __iomem * __ioremap(unsigned long addr, unsigned long size,
} }
void __iomem * ioremap(unsigned long addr, unsigned long size) void __iomem * ioremap(phys_addr_t addr, unsigned long size)
{ {
unsigned long flags = _PAGE_NO_CACHE | _PAGE_GUARDED; unsigned long flags = _PAGE_NO_CACHE | _PAGE_GUARDED;
...@@ -178,7 +178,7 @@ void __iomem * ioremap(unsigned long addr, unsigned long size) ...@@ -178,7 +178,7 @@ void __iomem * ioremap(unsigned long addr, unsigned long size)
return __ioremap(addr, size, flags); return __ioremap(addr, size, flags);
} }
void __iomem * ioremap_flags(unsigned long addr, unsigned long size, void __iomem * ioremap_flags(phys_addr_t addr, unsigned long size,
unsigned long flags) unsigned long flags)
{ {
if (ppc_md.ioremap) if (ppc_md.ioremap)
...@@ -189,7 +189,7 @@ void __iomem * ioremap_flags(unsigned long addr, unsigned long size, ...@@ -189,7 +189,7 @@ void __iomem * ioremap_flags(unsigned long addr, unsigned long size,
#define IS_PAGE_ALIGNED(_val) ((_val) == ((_val) & PAGE_MASK)) #define IS_PAGE_ALIGNED(_val) ((_val) == ((_val) & PAGE_MASK))
int __ioremap_explicit(unsigned long pa, unsigned long ea, int __ioremap_explicit(phys_addr_t pa, unsigned long ea,
unsigned long size, unsigned long flags) unsigned long size, unsigned long flags)
{ {
struct vm_struct *area; struct vm_struct *area;
...@@ -244,7 +244,7 @@ int __ioremap_explicit(unsigned long pa, unsigned long ea, ...@@ -244,7 +244,7 @@ int __ioremap_explicit(unsigned long pa, unsigned long ea,
* *
* XXX what about calls before mem_init_done (ie python_countermeasures()) * XXX what about calls before mem_init_done (ie python_countermeasures())
*/ */
void __iounmap(void __iomem *token) void __iounmap(volatile void __iomem *token)
{ {
void *addr; void *addr;
...@@ -256,7 +256,7 @@ void __iounmap(void __iomem *token) ...@@ -256,7 +256,7 @@ void __iounmap(void __iomem *token)
im_free(addr); im_free(addr);
} }
void iounmap(void __iomem *token) void iounmap(volatile void __iomem *token)
{ {
if (ppc_md.iounmap) if (ppc_md.iounmap)
ppc_md.iounmap(token); ppc_md.iounmap(token);
...@@ -282,7 +282,7 @@ static int iounmap_subset_regions(unsigned long addr, unsigned long size) ...@@ -282,7 +282,7 @@ static int iounmap_subset_regions(unsigned long addr, unsigned long size)
return 0; return 0;
} }
int __iounmap_explicit(void __iomem *start, unsigned long size) int __iounmap_explicit(volatile void __iomem *start, unsigned long size)
{ {
struct vm_struct *area; struct vm_struct *area;
unsigned long addr; unsigned long addr;
......
...@@ -588,7 +588,6 @@ static int __init chrp_probe(void) ...@@ -588,7 +588,6 @@ static int __init chrp_probe(void)
ISA_DMA_THRESHOLD = ~0L; ISA_DMA_THRESHOLD = ~0L;
DMA_MODE_READ = 0x44; DMA_MODE_READ = 0x44;
DMA_MODE_WRITE = 0x48; DMA_MODE_WRITE = 0x48;
isa_io_base = CHRP_ISA_IO_BASE; /* default value */
return 1; return 1;
} }
......
...@@ -617,13 +617,13 @@ static void iseries_dedicated_idle(void) ...@@ -617,13 +617,13 @@ static void iseries_dedicated_idle(void)
void __init iSeries_init_IRQ(void) { } void __init iSeries_init_IRQ(void) { }
#endif #endif
static void __iomem *iseries_ioremap(unsigned long address, unsigned long size, static void __iomem *iseries_ioremap(phys_addr_t address, unsigned long size,
unsigned long flags) unsigned long flags)
{ {
return (void __iomem *)address; return (void __iomem *)address;
} }
static void iseries_iounmap(void __iomem *token) static void iseries_iounmap(volatile void __iomem *token)
{ {
} }
......
...@@ -677,8 +677,6 @@ static int __init pmac_probe(void) ...@@ -677,8 +677,6 @@ static int __init pmac_probe(void)
#ifdef CONFIG_PPC32 #ifdef CONFIG_PPC32
/* isa_io_base gets set in pmac_pci_init */ /* isa_io_base gets set in pmac_pci_init */
isa_mem_base = PMAC_ISA_MEM_BASE;
pci_dram_offset = PMAC_PCI_DRAM_OFFSET;
ISA_DMA_THRESHOLD = ~0L; ISA_DMA_THRESHOLD = ~0L;
DMA_MODE_READ = 1; DMA_MODE_READ = 1;
DMA_MODE_WRITE = 2; DMA_MODE_WRITE = 2;
......
...@@ -169,104 +169,19 @@ static inline u64 eeh_readq_be(const volatile void __iomem *addr) ...@@ -169,104 +169,19 @@ static inline u64 eeh_readq_be(const volatile void __iomem *addr)
return val; return val;
} }
#define EEH_CHECK_ALIGN(v,a) \ static inline void eeh_memcpy_fromio(void *dest, const
((((unsigned long)(v)) & ((a) - 1)) == 0) volatile void __iomem *src,
static inline void eeh_memset_io(volatile void __iomem *addr, int c,
unsigned long n)
{
void *p = (void __force *)addr;
u32 lc = c;
lc |= lc << 8;
lc |= lc << 16;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && !EEH_CHECK_ALIGN(p, 4)) {
*((volatile u8 *)p) = c;
p++;
n--;
}
while(n >= 4) {
*((volatile u32 *)p) = lc;
p += 4;
n -= 4;
}
while(n) {
*((volatile u8 *)p) = c;
p++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
}
static inline void eeh_memcpy_fromio(void *dest, const volatile void __iomem *src,
unsigned long n) unsigned long n)
{ {
void *vsrc = (void __force *) src; _memcpy_fromio(dest, src, n);
void *destsave = dest;
unsigned long nsave = n;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && (!EEH_CHECK_ALIGN(vsrc, 4) || !EEH_CHECK_ALIGN(dest, 4))) {
*((u8 *)dest) = *((volatile u8 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc++;
dest++;
n--;
}
while(n > 4) {
*((u32 *)dest) = *((volatile u32 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc += 4;
dest += 4;
n -= 4;
}
while(n) {
*((u8 *)dest) = *((volatile u8 *)vsrc);
__asm__ __volatile__ ("eieio" : : : "memory");
vsrc++;
dest++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
/* Look for ffff's here at dest[n]. Assume that at least 4 bytes /* Look for ffff's here at dest[n]. Assume that at least 4 bytes
* were copied. Check all four bytes. * were copied. Check all four bytes.
*/ */
if ((nsave >= 4) && if (n >= 4 && EEH_POSSIBLE_ERROR(*((u32 *)(dest + n - 4)), u32))
(EEH_POSSIBLE_ERROR((*((u32 *) destsave+nsave-4)), u32))) { eeh_check_failure(src, *((u32 *)(dest + n - 4)));
eeh_check_failure(src, (*((u32 *) destsave+nsave-4)));
}
} }
static inline void eeh_memcpy_toio(volatile void __iomem *dest, const void *src,
unsigned long n)
{
void *vdest = (void __force *) dest;
__asm__ __volatile__ ("sync" : : : "memory");
while(n && (!EEH_CHECK_ALIGN(vdest, 4) || !EEH_CHECK_ALIGN(src, 4))) {
*((volatile u8 *)vdest) = *((u8 *)src);
src++;
vdest++;
n--;
}
while(n > 4) {
*((volatile u32 *)vdest) = *((volatile u32 *)src);
src += 4;
vdest += 4;
n-=4;
}
while(n) {
*((volatile u8 *)vdest) = *((u8 *)src);
src++;
vdest++;
n--;
}
__asm__ __volatile__ ("sync" : : : "memory");
}
#undef EEH_CHECK_ALIGN
/* in-string eeh macros */ /* in-string eeh macros */
static inline void eeh_readsb(const volatile void __iomem *addr, void * buf, static inline void eeh_readsb(const volatile void __iomem *addr, void * buf,
int ns) int ns)
......
...@@ -22,17 +22,10 @@ ...@@ -22,17 +22,10 @@
#endif #endif
#endif #endif
#ifdef __powerpc64__
#define __ide_mm_insw(p, a, c) readsw((void __iomem *)(p), (a), (c)) #define __ide_mm_insw(p, a, c) readsw((void __iomem *)(p), (a), (c))
#define __ide_mm_insl(p, a, c) readsl((void __iomem *)(p), (a), (c)) #define __ide_mm_insl(p, a, c) readsl((void __iomem *)(p), (a), (c))
#define __ide_mm_outsw(p, a, c) writesw((void __iomem *)(p), (a), (c)) #define __ide_mm_outsw(p, a, c) writesw((void __iomem *)(p), (a), (c))
#define __ide_mm_outsl(p, a, c) writesl((void __iomem *)(p), (a), (c)) #define __ide_mm_outsl(p, a, c) writesl((void __iomem *)(p), (a), (c))
#else
#define __ide_mm_insw(p, a, c) _insw_ns((volatile u16 __iomem *)(p), (a), (c))
#define __ide_mm_insl(p, a, c) _insl_ns((volatile u32 __iomem *)(p), (a), (c))
#define __ide_mm_outsw(p, a, c) _outsw_ns((volatile u16 __iomem *)(p), (a), (c))
#define __ide_mm_outsl(p, a, c) _outsl_ns((volatile u32 __iomem *)(p), (a), (c))
#endif
#ifndef __powerpc64__ #ifndef __powerpc64__
#include <linux/hdreg.h> #include <linux/hdreg.h>
......
...@@ -3,17 +3,20 @@ ...@@ -3,17 +3,20 @@
DEF_PCI_AC_RET(readb, u8, (const PCI_IO_ADDR addr), (addr)) DEF_PCI_AC_RET(readb, u8, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readw, u16, (const PCI_IO_ADDR addr), (addr)) DEF_PCI_AC_RET(readw, u16, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readl, u32, (const PCI_IO_ADDR addr), (addr)) DEF_PCI_AC_RET(readl, u32, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readq, u64, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readw_be, u16, (const PCI_IO_ADDR addr), (addr)) DEF_PCI_AC_RET(readw_be, u16, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readl_be, u32, (const PCI_IO_ADDR addr), (addr)) DEF_PCI_AC_RET(readl_be, u32, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readq_be, u64, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_NORET(writeb, (u8 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writeb, (u8 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writew, (u16 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writew, (u16 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writel, (u32 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writel, (u32 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writeq, (u64 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writew_be, (u16 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writew_be, (u16 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writel_be, (u32 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writel_be, (u32 val, PCI_IO_ADDR addr), (val, addr))
#ifdef __powerpc64__
DEF_PCI_AC_RET(readq, u64, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_RET(readq_be, u64, (const PCI_IO_ADDR addr), (addr))
DEF_PCI_AC_NORET(writeq, (u64 val, PCI_IO_ADDR addr), (val, addr))
DEF_PCI_AC_NORET(writeq_be, (u64 val, PCI_IO_ADDR addr), (val, addr)) DEF_PCI_AC_NORET(writeq_be, (u64 val, PCI_IO_ADDR addr), (val, addr))
#endif /* __powerpc64__ */
DEF_PCI_AC_RET(inb, u8, (unsigned long port), (port)) DEF_PCI_AC_RET(inb, u8, (unsigned long port), (port))
DEF_PCI_AC_RET(inw, u16, (unsigned long port), (port)) DEF_PCI_AC_RET(inw, u16, (unsigned long port), (port))
......
This diff is collapsed.
...@@ -88,9 +88,9 @@ struct machdep_calls { ...@@ -88,9 +88,9 @@ struct machdep_calls {
void (*pci_dma_dev_setup)(struct pci_dev *dev); void (*pci_dma_dev_setup)(struct pci_dev *dev);
void (*pci_dma_bus_setup)(struct pci_bus *bus); void (*pci_dma_bus_setup)(struct pci_bus *bus);
void __iomem * (*ioremap)(unsigned long addr, unsigned long size, void __iomem * (*ioremap)(phys_addr_t addr, unsigned long size,
unsigned long flags); unsigned long flags);
void (*iounmap)(void __iomem *token); void (*iounmap)(volatile void __iomem *token);
#endif /* CONFIG_PPC64 */ #endif /* CONFIG_PPC64 */
int (*probe)(void); int (*probe)(void);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment