|  | @@ -363,3 +363,59 @@ struct el_t2_frame_corrected {
 | 
	
		
			
				|  |  |  extern inline u8 t2_inb(unsigned long addr)
 | 
	
		
			
				|  |  |  {
 | 
	
		
			
				|  |  |  	long result = *(vip) ((addr << 5) + T2_IO + 0x00);
 | 
	
		
			
				|  |  | +	return __kernel_extbl(result, addr & 3);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +extern inline void t2_outb(u8 b, unsigned long addr)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	unsigned long w;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	w = __kernel_insbl(b, addr & 3);
 | 
	
		
			
				|  |  | +	*(vuip) ((addr << 5) + T2_IO + 0x00) = w;
 | 
	
		
			
				|  |  | +	mb();
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +extern inline u16 t2_inw(unsigned long addr)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	long result = *(vip) ((addr << 5) + T2_IO + 0x08);
 | 
	
		
			
				|  |  | +	return __kernel_extwl(result, addr & 3);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +extern inline void t2_outw(u16 b, unsigned long addr)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	unsigned long w;
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +	w = __kernel_inswl(b, addr & 3);
 | 
	
		
			
				|  |  | +	*(vuip) ((addr << 5) + T2_IO + 0x08) = w;
 | 
	
		
			
				|  |  | +	mb();
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +extern inline u32 t2_inl(unsigned long addr)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	return *(vuip) ((addr << 5) + T2_IO + 0x18);
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +extern inline void t2_outl(u32 b, unsigned long addr)
 | 
	
		
			
				|  |  | +{
 | 
	
		
			
				|  |  | +	*(vuip) ((addr << 5) + T2_IO + 0x18) = b;
 | 
	
		
			
				|  |  | +	mb();
 | 
	
		
			
				|  |  | +}
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +/*
 | 
	
		
			
				|  |  | + * Memory functions.
 | 
	
		
			
				|  |  | + *
 | 
	
		
			
				|  |  | + * For reading and writing 8 and 16 bit quantities we need to
 | 
	
		
			
				|  |  | + * go through one of the three sparse address mapping regions
 | 
	
		
			
				|  |  | + * and use the HAE_MEM CSR to provide some bits of the address.
 | 
	
		
			
				|  |  | + * The following few routines use only sparse address region 1
 | 
	
		
			
				|  |  | + * which gives 1Gbyte of accessible space which relates exactly
 | 
	
		
			
				|  |  | + * to the amount of PCI memory mapping *into* system address space.
 | 
	
		
			
				|  |  | + * See p 6-17 of the specification but it looks something like this:
 | 
	
		
			
				|  |  | + *
 | 
	
		
			
				|  |  | + * 21164 Address:
 | 
	
		
			
				|  |  | + *
 | 
	
		
			
				|  |  | + *          3         2         1
 | 
	
		
			
				|  |  | + * 9876543210987654321098765432109876543210
 | 
	
		
			
				|  |  | + * 1ZZZZ0.PCI.QW.Address............BBLL
 | 
	
		
			
				|  |  | + *
 |