mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-26 08:59:47 +00:00 
			
		
		
		
	 b66c1a3919
			
		
	
	
		b66c1a3919
		
	
	
	
	
		
			
			This introduces a few changes in the way that the I/O routines are defined on SH, specifically so that things like the iomap API properly wrap through the machvec for board-specific quirks. In addition to this, the old p3_ioremap() work is converted to a more generic __ioremap() that will map through the PMB if it's available, or fall back on page tables for everything else. An alpha-like IO_CONCAT is also added so we can start to clean up the board-specific io.h mess, which will be handled in board update patches.. Signed-off-by: Paul Mundt <lethal@linux-sh.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
		
			
				
	
	
		
			50 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			50 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Trivial I/O routine definitions, intentionally meant to be included
 | |
|  * multiple times. Ugly I/O routine concatenation helpers taken from
 | |
|  * alpha. Must be included _before_ io.h to avoid preprocessor-induced
 | |
|  * routine mismatch.
 | |
|  */
 | |
| #define IO_CONCAT(a,b)	_IO_CONCAT(a,b)
 | |
| #define _IO_CONCAT(a,b)	a ## _ ## b
 | |
| 
 | |
| #ifndef __IO_PREFIX
 | |
| #error "Don't include this header without a valid system prefix"
 | |
| #endif
 | |
| 
 | |
| u8 IO_CONCAT(__IO_PREFIX,inb)(unsigned long);
 | |
| u16 IO_CONCAT(__IO_PREFIX,inw)(unsigned long);
 | |
| u32 IO_CONCAT(__IO_PREFIX,inl)(unsigned long);
 | |
| 
 | |
| void IO_CONCAT(__IO_PREFIX,outb)(u8, unsigned long);
 | |
| void IO_CONCAT(__IO_PREFIX,outw)(u16, unsigned long);
 | |
| void IO_CONCAT(__IO_PREFIX,outl)(u32, unsigned long);
 | |
| 
 | |
| u8 IO_CONCAT(__IO_PREFIX,inb_p)(unsigned long);
 | |
| u16 IO_CONCAT(__IO_PREFIX,inw_p)(unsigned long);
 | |
| u32 IO_CONCAT(__IO_PREFIX,inl_p)(unsigned long);
 | |
| void IO_CONCAT(__IO_PREFIX,outb_p)(u8, unsigned long);
 | |
| void IO_CONCAT(__IO_PREFIX,outw_p)(u16, unsigned long);
 | |
| void IO_CONCAT(__IO_PREFIX,outl_p)(u32, unsigned long);
 | |
| 
 | |
| void IO_CONCAT(__IO_PREFIX,insb)(unsigned long, void *dst, unsigned long count);
 | |
| void IO_CONCAT(__IO_PREFIX,insw)(unsigned long, void *dst, unsigned long count);
 | |
| void IO_CONCAT(__IO_PREFIX,insl)(unsigned long, void *dst, unsigned long count);
 | |
| void IO_CONCAT(__IO_PREFIX,outsb)(unsigned long, const void *src, unsigned long count);
 | |
| void IO_CONCAT(__IO_PREFIX,outsw)(unsigned long, const void *src, unsigned long count);
 | |
| void IO_CONCAT(__IO_PREFIX,outsl)(unsigned long, const void *src, unsigned long count);
 | |
| 
 | |
| u8 IO_CONCAT(__IO_PREFIX,readb)(void __iomem *);
 | |
| u16 IO_CONCAT(__IO_PREFIX,readw)(void __iomem *);
 | |
| u32 IO_CONCAT(__IO_PREFIX,readl)(void __iomem *);
 | |
| void IO_CONCAT(__IO_PREFIX,writeb)(u8, void __iomem *);
 | |
| void IO_CONCAT(__IO_PREFIX,writew)(u16, void __iomem *);
 | |
| void IO_CONCAT(__IO_PREFIX,writel)(u32, void __iomem *);
 | |
| 
 | |
| void *IO_CONCAT(__IO_PREFIX,ioremap)(unsigned long offset, unsigned long size);
 | |
| void IO_CONCAT(__IO_PREFIX,iounmap)(void *addr);
 | |
| 
 | |
| void __iomem *IO_CONCAT(__IO_PREFIX,ioport_map)(unsigned long addr, unsigned int size);
 | |
| void IO_CONCAT(__IO_PREFIX,ioport_unmap)(void __iomem *addr);
 | |
| 
 | |
| #undef __IO_PREFIX
 |