2  * arch/sh/boards/se/73180/io.c
 
   4  * Copyright (C) 2003 YOSHII Takashi <yoshii-takashi@hitachi-ul.co.jp>
 
   5  * Based on arch/sh/boards/se/7300/io.c
 
   7  * I/O routine for SH-Mobile3 73180 SolutionEngine.
 
  11 #include <linux/config.h>
 
  12 #include <linux/kernel.h>
 
  13 #include <asm/mach/se73180.h>
 
  16 #define badio(fn, a) panic("bad i/o operation %s for %08lx.", #fn, a)
 
  19         unsigned long start, end;
 
  21         struct iop *(*check) (struct iop * p, unsigned long port);
 
  22         unsigned char (*inb) (struct iop * p, unsigned long port);
 
  23         unsigned short (*inw) (struct iop * p, unsigned long port);
 
  24         void (*outb) (struct iop * p, unsigned char value, unsigned long port);
 
  25         void (*outw) (struct iop * p, unsigned short value, unsigned long port);
 
  29 simple_check(struct iop *p, unsigned long port)
 
  31         if ((p->start <= port) && (port <= p->end))
 
  38 ide_check(struct iop *p, unsigned long port)
 
  40         if (((0x1f0 <= port) && (port <= 0x1f7)) || (port == 0x3f7))
 
  46 simple_inb(struct iop *p, unsigned long port)
 
  48         return *(unsigned char *) (p->base + port);
 
  52 simple_inw(struct iop *p, unsigned long port)
 
  54         return *(unsigned short *) (p->base + port);
 
  58 simple_outb(struct iop *p, unsigned char value, unsigned long port)
 
  60         *(unsigned char *) (p->base + port) = value;
 
  64 simple_outw(struct iop *p, unsigned short value, unsigned long port)
 
  66         *(unsigned short *) (p->base + port) = value;
 
  70 pcc_inb(struct iop *p, unsigned long port)
 
  72         unsigned long addr = p->base + port + 0x40000;
 
  77         v = *(volatile unsigned char *) addr;
 
  82 pcc_outb(struct iop *p, unsigned char value, unsigned long port)
 
  84         unsigned long addr = p->base + port + 0x40000;
 
  88         *(volatile unsigned char *) addr = value;
 
  92 bad_inb(struct iop *p, unsigned long port)
 
  98 bad_outb(struct iop *p, unsigned char value, unsigned long port)
 
 103 /* MSTLANEX01 LAN at 0xb400:0000 */
 
 104 static struct iop laniop = {
 
 108         .check = simple_check,
 
 115 /* NE2000 pc card NIC */
 
 116 static struct iop neiop = {
 
 119         .base = 0xb0600000 + 0x80,      /* soft 0x280 -> hard 0x300 */
 
 120         .check = simple_check,
 
 128 static struct iop cfiop = {
 
 137 static __inline__ struct iop *
 
 138 port2iop(unsigned long port)
 
 141 #if defined(CONFIG_SMC91111)
 
 142         else if (laniop.check(&laniop, port))
 
 145 #if defined(CONFIG_NE2000)
 
 146         else if (neiop.check(&neiop, port))
 
 149 #if defined(CONFIG_IDE)
 
 150         else if (cfiop.check(&cfiop, port))
 
 154                 return &neiop;  /* fallback */
 
 160         ctrl_inw(0xac000000);
 
 161         ctrl_inw(0xac000000);
 
 165 sh73180se_inb(unsigned long port)
 
 167         struct iop *p = port2iop(port);
 
 168         return (p->inb) (p, port);
 
 172 sh73180se_inb_p(unsigned long port)
 
 174         unsigned char v = sh73180se_inb(port);
 
 180 sh73180se_inw(unsigned long port)
 
 182         struct iop *p = port2iop(port);
 
 183         return (p->inw) (p, port);
 
 187 sh73180se_inl(unsigned long port)
 
 193 sh73180se_outb(unsigned char value, unsigned long port)
 
 195         struct iop *p = port2iop(port);
 
 196         (p->outb) (p, value, port);
 
 200 sh73180se_outb_p(unsigned char value, unsigned long port)
 
 202         sh73180se_outb(value, port);
 
 207 sh73180se_outw(unsigned short value, unsigned long port)
 
 209         struct iop *p = port2iop(port);
 
 210         (p->outw) (p, value, port);
 
 214 sh73180se_outl(unsigned int value, unsigned long port)
 
 220 sh73180se_insb(unsigned long port, void *addr, unsigned long count)
 
 222         unsigned char *a = addr;
 
 223         struct iop *p = port2iop(port);
 
 225                 *a++ = (p->inb) (p, port);
 
 229 sh73180se_insw(unsigned long port, void *addr, unsigned long count)
 
 231         unsigned short *a = addr;
 
 232         struct iop *p = port2iop(port);
 
 234                 *a++ = (p->inw) (p, port);
 
 238 sh73180se_insl(unsigned long port, void *addr, unsigned long count)
 
 244 sh73180se_outsb(unsigned long port, const void *addr, unsigned long count)
 
 246         unsigned char *a = (unsigned char *) addr;
 
 247         struct iop *p = port2iop(port);
 
 249                 (p->outb) (p, *a++, port);
 
 253 sh73180se_outsw(unsigned long port, const void *addr, unsigned long count)
 
 255         unsigned short *a = (unsigned short *) addr;
 
 256         struct iop *p = port2iop(port);
 
 258                 (p->outw) (p, *a++, port);
 
 262 sh73180se_outsl(unsigned long port, const void *addr, unsigned long count)