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/sched.h>
 
  10 #include <linux/spinlock.h>
 
  11 #include <linux/interrupt.h>
 
  13 #include <linux/adb.h>
 
  15 #include <asm/pgtable.h>
 
  16 #include <asm/hydra.h>
 
  18 #include <asm/system.h>
 
  19 #include <linux/init.h>
 
  20 #include <linux/ioport.h>
 
  35         struct preg active_hi;
 
  36         struct preg active_lo;
 
  40 /* Bits in intr and intr_enb registers */
 
  41 #define DFB     1               /* data from bus */
 
  42 #define TAG     2               /* transfer access grant */
 
  44 /* Bits in dcount register */
 
  45 #define HMB     0x0f            /* how many bytes */
 
  46 #define APD     0x10            /* auto-poll data */
 
  48 /* Bits in error register */
 
  49 #define NRE     1               /* no response error */
 
  50 #define DLE     2               /* data lost error */
 
  52 /* Bits in ctrl register */
 
  53 #define TAR     1               /* transfer access request */
 
  54 #define DTB     2               /* data to bus */
 
  55 #define CRE     4               /* command response expected */
 
  56 #define ADB_RST 8               /* ADB reset */
 
  58 /* Bits in autopoll register */
 
  59 #define APE     1               /* autopoll enable */
 
  61 static volatile struct adb_regs __iomem *adb;
 
  62 static struct adb_request *current_req, *last_req;
 
  63 static DEFINE_SPINLOCK(macio_lock);
 
  65 static int macio_probe(void);
 
  66 static int macio_init(void);
 
  67 static irqreturn_t macio_adb_interrupt(int irq, void *arg);
 
  68 static int macio_send_request(struct adb_request *req, int sync);
 
  69 static int macio_adb_autopoll(int devs);
 
  70 static void macio_adb_poll(void);
 
  71 static int macio_adb_reset_bus(void);
 
  73 struct adb_driver macio_adb_driver = {
 
  86         return find_compatible_devices("adb", "chrp,adb0")? 0: -ENODEV;
 
  91         struct device_node *adbs;
 
  95         adbs = find_compatible_devices("adb", "chrp,adb0");
 
  99         if (of_address_to_resource(adbs, 0, &r))
 
 101         adb = ioremap(r.start, sizeof(struct adb_regs));
 
 103         out_8(&adb->ctrl.r, 0);
 
 104         out_8(&adb->intr.r, 0);
 
 105         out_8(&adb->error.r, 0);
 
 106         out_8(&adb->active_hi.r, 0xff); /* for now, set all devices active */
 
 107         out_8(&adb->active_lo.r, 0xff);
 
 108         out_8(&adb->autopoll.r, APE);
 
 110         irq = irq_of_parse_and_map(adbs, 0);
 
 111         if (request_irq(irq, macio_adb_interrupt, 0, "ADB", (void *)0)) {
 
 112                 printk(KERN_ERR "ADB: can't get irq %d\n", irq);
 
 115         out_8(&adb->intr_enb.r, DFB | TAG);
 
 117         printk("adb: mac-io driver 1.0 for unified ADB\n");
 
 122 static int macio_adb_autopoll(int devs)
 
 126         spin_lock_irqsave(&macio_lock, flags);
 
 127         out_8(&adb->active_hi.r, devs >> 8);
 
 128         out_8(&adb->active_lo.r, devs);
 
 129         out_8(&adb->autopoll.r, devs? APE: 0);
 
 130         spin_unlock_irqrestore(&macio_lock, flags);
 
 134 static int macio_adb_reset_bus(void)
 
 137         int timeout = 1000000;
 
 139         /* Hrm... we may want to not lock interrupts for so
 
 140          * long ... oh well, who uses that chip anyway ? :)
 
 141          * That function will be seldomly used during boot
 
 142          * on rare machines, so...
 
 144         spin_lock_irqsave(&macio_lock, flags);
 
 145         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | ADB_RST);
 
 146         while ((in_8(&adb->ctrl.r) & ADB_RST) != 0) {
 
 147                 if (--timeout == 0) {
 
 148                         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) & ~ADB_RST);
 
 152         spin_unlock_irqrestore(&macio_lock, flags);
 
 156 /* Send an ADB command */
 
 157 static int macio_send_request(struct adb_request *req, int sync)
 
 162         if (req->data[0] != ADB_PACKET)
 
 165         for (i = 0; i < req->nbytes - 1; ++i)
 
 166                 req->data[i] = req->data[i+1];
 
 174         spin_lock_irqsave(&macio_lock, flags);
 
 175         if (current_req != 0) {
 
 176                 last_req->next = req;
 
 179                 current_req = last_req = req;
 
 180                 out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 182         spin_unlock_irqrestore(&macio_lock, flags);
 
 185                 while (!req->complete)
 
 192 static irqreturn_t macio_adb_interrupt(int irq, void *arg)
 
 195         struct adb_request *req = NULL;
 
 196         unsigned char ibuf[16];
 
 202         spin_lock(&macio_lock);
 
 203         if (in_8(&adb->intr.r) & TAG) {
 
 205                 if ((req = current_req) != 0) {
 
 206                         /* put the current request in */
 
 207                         for (i = 0; i < req->nbytes; ++i)
 
 208                                 out_8(&adb->data[i].r, req->data[i]);
 
 209                         out_8(&adb->dcount.r, req->nbytes & HMB);
 
 211                         if (req->reply_expected) {
 
 212                                 out_8(&adb->ctrl.r, DTB + CRE);
 
 214                                 out_8(&adb->ctrl.r, DTB);
 
 215                                 current_req = req->next;
 
 218                                         out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 221                 out_8(&adb->intr.r, 0);
 
 224         if (in_8(&adb->intr.r) & DFB) {
 
 226                 err = in_8(&adb->error.r);
 
 227                 if (current_req && current_req->sent) {
 
 228                         /* this is the response to a command */
 
 231                                 req->reply_len = in_8(&adb->dcount.r) & HMB;
 
 232                                 for (i = 0; i < req->reply_len; ++i)
 
 233                                         req->reply[i] = in_8(&adb->data[i].r);
 
 235                         current_req = req->next;
 
 238                                 out_8(&adb->ctrl.r, in_8(&adb->ctrl.r) | TAR);
 
 239                 } else if (err == 0) {
 
 241                         n = in_8(&adb->dcount.r) & HMB;
 
 242                         for (i = 0; i < n; ++i)
 
 243                                 ibuf[i] = in_8(&adb->data[i].r);
 
 245                         autopoll = (in_8(&adb->dcount.r) & APD) != 0;
 
 247                 out_8(&adb->error.r, 0);
 
 248                 out_8(&adb->intr.r, 0);
 
 250         spin_unlock(&macio_lock);
 
 251         if (complete && req) {
 
 252             void (*done)(struct adb_request *) = req->done;
 
 255             /* Here, we assume that if the request has a done member, the
 
 256              * struct request will survive to setting req->complete to 1
 
 262                 adb_input(ibuf, ibuf_len, autopoll);
 
 264         return IRQ_RETVAL(handled);
 
 267 static void macio_adb_poll(void)
 
 271         local_irq_save(flags);
 
 272         if (in_8(&adb->intr.r) != 0)
 
 273                 macio_adb_interrupt(0, NULL);
 
 274         local_irq_restore(flags);