2  * Driver for the ADB controller in the Mac I/O (Hydra) chip.
 
   5 #include <linux/types.h>
 
   6 #include <linux/errno.h>
 
   7 #include <linux/kernel.h>
 
   8 #include <linux/delay.h>
 
   9 #include <linux/spinlock.h>
 
  10 #include <linux/interrupt.h>
 
  12 #include <linux/adb.h>
 
  14 #include <asm/pgtable.h>
 
  15 #include <asm/hydra.h>
 
  17 #include <asm/system.h>
 
  18 #include <linux/init.h>
 
  19 #include <linux/ioport.h>
 
  34         struct preg active_hi;
 
  35         struct preg active_lo;
 
  39 /* Bits in intr and intr_enb registers */
 
  40 #define DFB     1               /* data from bus */
 
  41 #define TAG     2               /* transfer access grant */
 
  43 /* Bits in dcount register */
 
  44 #define HMB     0x0f            /* how many bytes */
 
  45 #define APD     0x10            /* auto-poll data */
 
  47 /* Bits in error register */
 
  48 #define NRE     1               /* no response error */
 
  49 #define DLE     2               /* data lost error */
 
  51 /* Bits in ctrl register */
 
  52 #define TAR     1               /* transfer access request */
 
  53 #define DTB     2               /* data to bus */
 
  54 #define CRE     4               /* command response expected */
 
  55 #define ADB_RST 8               /* ADB reset */
 
  57 /* Bits in autopoll register */
 
  58 #define APE     1               /* autopoll enable */
 
  60 static volatile struct adb_regs __iomem *adb;
 
  61 static struct adb_request *current_req, *last_req;
 
  62 static DEFINE_SPINLOCK(macio_lock);
 
  64 static int macio_probe(void);
 
  65 static int macio_init(void);
 
  66 static irqreturn_t macio_adb_interrupt(int irq, void *arg);
 
  67 static int macio_send_request(struct adb_request *req, int sync);
 
  68 static int macio_adb_autopoll(int devs);
 
  69 static void macio_adb_poll(void);
 
  70 static int macio_adb_reset_bus(void);
 
  72 struct adb_driver macio_adb_driver = {
 
  85         return find_compatible_devices("adb", "chrp,adb0")? 0: -ENODEV;
 
  90         struct device_node *adbs;
 
  94         adbs = find_compatible_devices("adb", "chrp,adb0");
 
  98         if (of_address_to_resource(adbs, 0, &r))
 
 100         adb = ioremap(r.start, sizeof(struct adb_regs));
 
 102         out_8(&adb->ctrl.r, 0);
 
 103         out_8(&adb->intr.r, 0);
 
 104         out_8(&adb->error.r, 0);
 
 105         out_8(&adb->active_hi.r, 0xff); /* for now, set all devices active */
 
 106         out_8(&adb->active_lo.r, 0xff);
 
 107         out_8(&adb->autopoll.r, APE);
 
 109         irq = irq_of_parse_and_map(adbs, 0);
 
 110         if (request_irq(irq, macio_adb_interrupt, 0, "ADB", (void *)0)) {
 
 111                 printk(KERN_ERR "ADB: can't get irq %d\n", irq);
 
 114         out_8(&adb->intr_enb.r, DFB | TAG);
 
 116         printk("adb: mac-io driver 1.0 for unified ADB\n");
 
 121 static int macio_adb_autopoll(int devs)
 
 125         spin_lock_irqsave(&macio_lock, flags);
 
 126         out_8(&adb->active_hi.r, devs >> 8);
 
 127         out_8(&adb->active_lo.r, devs);
 
 128         out_8(&adb->autopoll.r, devs? APE: 0);
 
 129         spin_unlock_irqrestore(&macio_lock, flags);
 
 133 static int macio_adb_reset_bus(void)
 
 136         int timeout = 1000000;
 
 138         /* Hrm... we may want to not lock interrupts for so
 
 139          * long ... oh well, who uses that chip anyway ? :)
 
 140          * That function will be seldomly used during boot
 
 141          * on rare machines, so...
 
 143         spin_lock_irqsave(&macio_lock, flags);
 
 144         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | ADB_RST);
 
 145         while ((in_8(&adb->ctrl.r) & ADB_RST) != 0) {
 
 146                 if (--timeout == 0) {
 
 147                         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) & ~ADB_RST);
 
 151         spin_unlock_irqrestore(&macio_lock, flags);
 
 155 /* Send an ADB command */
 
 156 static int macio_send_request(struct adb_request *req, int sync)
 
 161         if (req->data[0] != ADB_PACKET)
 
 164         for (i = 0; i < req->nbytes - 1; ++i)
 
 165                 req->data[i] = req->data[i+1];
 
 173         spin_lock_irqsave(&macio_lock, flags);
 
 174         if (current_req != 0) {
 
 175                 last_req->next = req;
 
 178                 current_req = last_req = req;
 
 179                 out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 181         spin_unlock_irqrestore(&macio_lock, flags);
 
 184                 while (!req->complete)
 
 191 static irqreturn_t macio_adb_interrupt(int irq, void *arg)
 
 194         struct adb_request *req = NULL;
 
 195         unsigned char ibuf[16];
 
 201         spin_lock(&macio_lock);
 
 202         if (in_8(&adb->intr.r) & TAG) {
 
 204                 if ((req = current_req) != 0) {
 
 205                         /* put the current request in */
 
 206                         for (i = 0; i < req->nbytes; ++i)
 
 207                                 out_8(&adb->data[i].r, req->data[i]);
 
 208                         out_8(&adb->dcount.r, req->nbytes & HMB);
 
 210                         if (req->reply_expected) {
 
 211                                 out_8(&adb->ctrl.r, DTB + CRE);
 
 213                                 out_8(&adb->ctrl.r, DTB);
 
 214                                 current_req = req->next;
 
 217                                         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 220                 out_8(&adb->intr.r, 0);
 
 223         if (in_8(&adb->intr.r) & DFB) {
 
 225                 err = in_8(&adb->error.r);
 
 226                 if (current_req && current_req->sent) {
 
 227                         /* this is the response to a command */
 
 230                                 req->reply_len = in_8(&adb->dcount.r) & HMB;
 
 231                                 for (i = 0; i < req->reply_len; ++i)
 
 232                                         req->reply[i] = in_8(&adb->data[i].r);
 
 234                         current_req = req->next;
 
 237                                 out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 238                 } else if (err == 0) {
 
 240                         n = in_8(&adb->dcount.r) & HMB;
 
 241                         for (i = 0; i < n; ++i)
 
 242                                 ibuf[i] = in_8(&adb->data[i].r);
 
 244                         autopoll = (in_8(&adb->dcount.r) & APD) != 0;
 
 246                 out_8(&adb->error.r, 0);
 
 247                 out_8(&adb->intr.r, 0);
 
 249         spin_unlock(&macio_lock);
 
 250         if (complete && req) {
 
 251             void (*done)(struct adb_request *) = req->done;
 
 254             /* Here, we assume that if the request has a done member, the
 
 255              * struct request will survive to setting req->complete to 1
 
 261                 adb_input(ibuf, ibuf_len, autopoll);
 
 263         return IRQ_RETVAL(handled);
 
 266 static void macio_adb_poll(void)
 
 270         local_irq_save(flags);
 
 271         if (in_8(&adb->intr.r) != 0)
 
 272                 macio_adb_interrupt(0, NULL);
 
 273         local_irq_restore(flags);