/* * S390 version * Copyright IBM Corp. 1999 * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com) * * Derived from "include/asm-i386/io.h" */ #ifndef _S390_IO_H #define _S390_IO_H #include #include #include /* * Change virtual addresses to physical addresses and vv. * These are pretty trivial */ static inline unsigned long virt_to_phys(volatile void * address) { unsigned long real_address; asm volatile( " lra %0,0(%1)\n" " jz 0f\n" " la %0,0\n" "0:" : "=a" (real_address) : "a" (address) : "cc"); return real_address; } #define virt_to_phys virt_to_phys static inline void * phys_to_virt(unsigned long address) { return (void *) address; } void *xlate_dev_mem_ptr(unsigned long phys); void unxlate_dev_mem_ptr(unsigned long phys, void *addr); /* * Convert a virtual cached pointer to an uncached pointer */ #define xlate_dev_kmem_ptr(p) p #define IO_SPACE_LIMIT 0 #ifdef CONFIG_PCI #define ioremap_nocache(addr, size) ioremap(addr, size) #define ioremap_wc ioremap_nocache /* TODO: s390 cannot support io_remap_pfn_range... */ #define io_remap_pfn_range(vma, vaddr, pfn, size, prot) \ remap_pfn_range(vma, vaddr, pfn, size, prot) static inline void __iomem *ioremap(unsigned long offset, unsigned long size) { return (void __iomem *) offset; } static inline void iounmap(volatile void __iomem *addr) { } /* * s390 needs a private implementation of pci_iomap since ioremap with its * offset parameter isn't sufficient. That's because BAR spaces are not * disjunctive on s390 so we need the bar parameter of pci_iomap to find * the corresponding device and create the mapping cookie. */ #define pci_iomap pci_iomap #define pci_iounmap pci_iounmap #define memcpy_fromio(dst, src, count) zpci_memcpy_fromio(dst, src, count) #define memcpy_toio(dst, src, count) zpci_memcpy_toio(dst, src, count) #define memset_io(dst, val, count) zpci_memset_io(dst, val, count) #define __raw_readb zpci_read_u8 #define __raw_readw zpci_read_u16 #define __raw_readl zpci_read_u32 #define __raw_readq zpci_read_u64 #define __raw_writeb zpci_write_u8 #define __raw_writew zpci_write_u16 #define __raw_writel zpci_write_u32 #define __raw_writeq zpci_write_u64 #define readb_relaxed readb #define readw_relaxed readw #define readl_relaxed readl #define readq_relaxed readq #endif /* CONFIG_PCI */ #include #endif