root/arch/arm/common/sa1111.c

/* [<][>][^][v][top][bottom][index][help] */

DEFINITIONS

This source file includes following definitions.
  1. sa1111_map_irq
  2. sa1111_handle_irqdomain
  3. sa1111_irq_handler
  4. sa1111_irqmask
  5. sa1111_irqbank
  6. sa1111_ack_irq
  7. sa1111_mask_irq
  8. sa1111_unmask_irq
  9. sa1111_retrigger_irq
  10. sa1111_type_irq
  11. sa1111_wake_irq
  12. sa1111_irqdomain_map
  13. sa1111_setup_irq
  14. sa1111_remove_irq
  15. gc_to_sa1111
  16. sa1111_gpio_map_reg
  17. sa1111_gpio_map_bit
  18. sa1111_gpio_modify
  19. sa1111_gpio_get_direction
  20. sa1111_gpio_direction_input
  21. sa1111_gpio_direction_output
  22. sa1111_gpio_get
  23. sa1111_gpio_set
  24. sa1111_gpio_set_multiple
  25. sa1111_gpio_to_irq
  26. sa1111_setup_gpios
  27. sa1111_wake
  28. sa1111_configure_smc
  29. sa1111_dev_release
  30. sa1111_init_one_child
  31. __sa1111_probe
  32. sa1111_remove_one
  33. __sa1111_remove
  34. sa1111_suspend_noirq
  35. sa1111_resume_noirq
  36. sa1111_probe
  37. sa1111_remove
  38. sa1111_chip_driver
  39. __sa1111_pll_clock
  40. sa1111_pll_clock
  41. sa1111_select_audio_mode
  42. sa1111_set_audio_rate
  43. sa1111_get_audio_rate
  44. sa1111_enable_device
  45. sa1111_disable_device
  46. sa1111_get_irq
  47. sa1111_match
  48. sa1111_bus_probe
  49. sa1111_bus_remove
  50. sa1111_driver_register
  51. sa1111_driver_unregister
  52. sa1111_needs_bounce
  53. sa1111_notifier_call
  54. sa1111_init
  55. sa1111_exit

   1 // SPDX-License-Identifier: GPL-2.0-only
   2 /*
   3  * linux/arch/arm/common/sa1111.c
   4  *
   5  * SA1111 support
   6  *
   7  * Original code by John Dorsey
   8  *
   9  * This file contains all generic SA1111 support.
  10  *
  11  * All initialization functions provided here are intended to be called
  12  * from machine specific code with proper arguments when required.
  13  */
  14 #include <linux/module.h>
  15 #include <linux/gpio/driver.h>
  16 #include <linux/init.h>
  17 #include <linux/irq.h>
  18 #include <linux/kernel.h>
  19 #include <linux/delay.h>
  20 #include <linux/errno.h>
  21 #include <linux/ioport.h>
  22 #include <linux/platform_device.h>
  23 #include <linux/slab.h>
  24 #include <linux/spinlock.h>
  25 #include <linux/dma-mapping.h>
  26 #include <linux/clk.h>
  27 #include <linux/io.h>
  28 
  29 #include <mach/hardware.h>
  30 #include <asm/mach/irq.h>
  31 #include <asm/mach-types.h>
  32 #include <linux/sizes.h>
  33 
  34 #include <asm/hardware/sa1111.h>
  35 
  36 /* SA1111 IRQs */
  37 #define IRQ_GPAIN0              (0)
  38 #define IRQ_GPAIN1              (1)
  39 #define IRQ_GPAIN2              (2)
  40 #define IRQ_GPAIN3              (3)
  41 #define IRQ_GPBIN0              (4)
  42 #define IRQ_GPBIN1              (5)
  43 #define IRQ_GPBIN2              (6)
  44 #define IRQ_GPBIN3              (7)
  45 #define IRQ_GPBIN4              (8)
  46 #define IRQ_GPBIN5              (9)
  47 #define IRQ_GPCIN0              (10)
  48 #define IRQ_GPCIN1              (11)
  49 #define IRQ_GPCIN2              (12)
  50 #define IRQ_GPCIN3              (13)
  51 #define IRQ_GPCIN4              (14)
  52 #define IRQ_GPCIN5              (15)
  53 #define IRQ_GPCIN6              (16)
  54 #define IRQ_GPCIN7              (17)
  55 #define IRQ_MSTXINT             (18)
  56 #define IRQ_MSRXINT             (19)
  57 #define IRQ_MSSTOPERRINT        (20)
  58 #define IRQ_TPTXINT             (21)
  59 #define IRQ_TPRXINT             (22)
  60 #define IRQ_TPSTOPERRINT        (23)
  61 #define SSPXMTINT               (24)
  62 #define SSPRCVINT               (25)
  63 #define SSPROR                  (26)
  64 #define AUDXMTDMADONEA          (32)
  65 #define AUDRCVDMADONEA          (33)
  66 #define AUDXMTDMADONEB          (34)
  67 #define AUDRCVDMADONEB          (35)
  68 #define AUDTFSR                 (36)
  69 #define AUDRFSR                 (37)
  70 #define AUDTUR                  (38)
  71 #define AUDROR                  (39)
  72 #define AUDDTS                  (40)
  73 #define AUDRDD                  (41)
  74 #define AUDSTO                  (42)
  75 #define IRQ_USBPWR              (43)
  76 #define IRQ_HCIM                (44)
  77 #define IRQ_HCIBUFFACC          (45)
  78 #define IRQ_HCIRMTWKP           (46)
  79 #define IRQ_NHCIMFCIR           (47)
  80 #define IRQ_USB_PORT_RESUME     (48)
  81 #define IRQ_S0_READY_NINT       (49)
  82 #define IRQ_S1_READY_NINT       (50)
  83 #define IRQ_S0_CD_VALID         (51)
  84 #define IRQ_S1_CD_VALID         (52)
  85 #define IRQ_S0_BVD1_STSCHG      (53)
  86 #define IRQ_S1_BVD1_STSCHG      (54)
  87 #define SA1111_IRQ_NR           (55)
  88 
  89 extern void sa1110_mb_enable(void);
  90 extern void sa1110_mb_disable(void);
  91 
  92 /*
  93  * We keep the following data for the overall SA1111.  Note that the
  94  * struct device and struct resource are "fake"; they should be supplied
  95  * by the bus above us.  However, in the interests of getting all SA1111
  96  * drivers converted over to the device model, we provide this as an
  97  * anchor point for all the other drivers.
  98  */
  99 struct sa1111 {
 100         struct device   *dev;
 101         struct clk      *clk;
 102         unsigned long   phys;
 103         int             irq;
 104         int             irq_base;       /* base for cascaded on-chip IRQs */
 105         spinlock_t      lock;
 106         void __iomem    *base;
 107         struct sa1111_platform_data *pdata;
 108         struct irq_domain *irqdomain;
 109         struct gpio_chip gc;
 110 #ifdef CONFIG_PM
 111         void            *saved_state;
 112 #endif
 113 };
 114 
 115 /*
 116  * We _really_ need to eliminate this.  Its only users
 117  * are the PWM and DMA checking code.
 118  */
 119 static struct sa1111 *g_sa1111;
 120 
 121 struct sa1111_dev_info {
 122         unsigned long   offset;
 123         unsigned long   skpcr_mask;
 124         bool            dma;
 125         unsigned int    devid;
 126         unsigned int    hwirq[6];
 127 };
 128 
 129 static struct sa1111_dev_info sa1111_devices[] = {
 130         {
 131                 .offset         = SA1111_USB,
 132                 .skpcr_mask     = SKPCR_UCLKEN,
 133                 .dma            = true,
 134                 .devid          = SA1111_DEVID_USB,
 135                 .hwirq = {
 136                         IRQ_USBPWR,
 137                         IRQ_HCIM,
 138                         IRQ_HCIBUFFACC,
 139                         IRQ_HCIRMTWKP,
 140                         IRQ_NHCIMFCIR,
 141                         IRQ_USB_PORT_RESUME
 142                 },
 143         },
 144         {
 145                 .offset         = 0x0600,
 146                 .skpcr_mask     = SKPCR_I2SCLKEN | SKPCR_L3CLKEN,
 147                 .dma            = true,
 148                 .devid          = SA1111_DEVID_SAC,
 149                 .hwirq = {
 150                         AUDXMTDMADONEA,
 151                         AUDXMTDMADONEB,
 152                         AUDRCVDMADONEA,
 153                         AUDRCVDMADONEB
 154                 },
 155         },
 156         {
 157                 .offset         = 0x0800,
 158                 .skpcr_mask     = SKPCR_SCLKEN,
 159                 .devid          = SA1111_DEVID_SSP,
 160         },
 161         {
 162                 .offset         = SA1111_KBD,
 163                 .skpcr_mask     = SKPCR_PTCLKEN,
 164                 .devid          = SA1111_DEVID_PS2_KBD,
 165                 .hwirq = {
 166                         IRQ_TPRXINT,
 167                         IRQ_TPTXINT
 168                 },
 169         },
 170         {
 171                 .offset         = SA1111_MSE,
 172                 .skpcr_mask     = SKPCR_PMCLKEN,
 173                 .devid          = SA1111_DEVID_PS2_MSE,
 174                 .hwirq = {
 175                         IRQ_MSRXINT,
 176                         IRQ_MSTXINT
 177                 },
 178         },
 179         {
 180                 .offset         = 0x1800,
 181                 .skpcr_mask     = 0,
 182                 .devid          = SA1111_DEVID_PCMCIA,
 183                 .hwirq = {
 184                         IRQ_S0_READY_NINT,
 185                         IRQ_S0_CD_VALID,
 186                         IRQ_S0_BVD1_STSCHG,
 187                         IRQ_S1_READY_NINT,
 188                         IRQ_S1_CD_VALID,
 189                         IRQ_S1_BVD1_STSCHG,
 190                 },
 191         },
 192 };
 193 
 194 static int sa1111_map_irq(struct sa1111 *sachip, irq_hw_number_t hwirq)
 195 {
 196         return irq_create_mapping(sachip->irqdomain, hwirq);
 197 }
 198 
 199 static void sa1111_handle_irqdomain(struct irq_domain *irqdomain, int irq)
 200 {
 201         struct irq_desc *d = irq_to_desc(irq_linear_revmap(irqdomain, irq));
 202 
 203         if (d)
 204                 generic_handle_irq_desc(d);
 205 }
 206 
 207 /*
 208  * SA1111 interrupt support.  Since clearing an IRQ while there are
 209  * active IRQs causes the interrupt output to pulse, the upper levels
 210  * will call us again if there are more interrupts to process.
 211  */
 212 static void sa1111_irq_handler(struct irq_desc *desc)
 213 {
 214         unsigned int stat0, stat1, i;
 215         struct sa1111 *sachip = irq_desc_get_handler_data(desc);
 216         struct irq_domain *irqdomain;
 217         void __iomem *mapbase = sachip->base + SA1111_INTC;
 218 
 219         stat0 = readl_relaxed(mapbase + SA1111_INTSTATCLR0);
 220         stat1 = readl_relaxed(mapbase + SA1111_INTSTATCLR1);
 221 
 222         writel_relaxed(stat0, mapbase + SA1111_INTSTATCLR0);
 223 
 224         desc->irq_data.chip->irq_ack(&desc->irq_data);
 225 
 226         writel_relaxed(stat1, mapbase + SA1111_INTSTATCLR1);
 227 
 228         if (stat0 == 0 && stat1 == 0) {
 229                 do_bad_IRQ(desc);
 230                 return;
 231         }
 232 
 233         irqdomain = sachip->irqdomain;
 234 
 235         for (i = 0; stat0; i++, stat0 >>= 1)
 236                 if (stat0 & 1)
 237                         sa1111_handle_irqdomain(irqdomain, i);
 238 
 239         for (i = 32; stat1; i++, stat1 >>= 1)
 240                 if (stat1 & 1)
 241                         sa1111_handle_irqdomain(irqdomain, i);
 242 
 243         /* For level-based interrupts */
 244         desc->irq_data.chip->irq_unmask(&desc->irq_data);
 245 }
 246 
 247 static u32 sa1111_irqmask(struct irq_data *d)
 248 {
 249         return BIT(irqd_to_hwirq(d) & 31);
 250 }
 251 
 252 static int sa1111_irqbank(struct irq_data *d)
 253 {
 254         return (irqd_to_hwirq(d) / 32) * 4;
 255 }
 256 
 257 static void sa1111_ack_irq(struct irq_data *d)
 258 {
 259 }
 260 
 261 static void sa1111_mask_irq(struct irq_data *d)
 262 {
 263         struct sa1111 *sachip = irq_data_get_irq_chip_data(d);
 264         void __iomem *mapbase = sachip->base + SA1111_INTC + sa1111_irqbank(d);
 265         u32 ie;
 266 
 267         ie = readl_relaxed(mapbase + SA1111_INTEN0);
 268         ie &= ~sa1111_irqmask(d);
 269         writel(ie, mapbase + SA1111_INTEN0);
 270 }
 271 
 272 static void sa1111_unmask_irq(struct irq_data *d)
 273 {
 274         struct sa1111 *sachip = irq_data_get_irq_chip_data(d);
 275         void __iomem *mapbase = sachip->base + SA1111_INTC + sa1111_irqbank(d);
 276         u32 ie;
 277 
 278         ie = readl_relaxed(mapbase + SA1111_INTEN0);
 279         ie |= sa1111_irqmask(d);
 280         writel_relaxed(ie, mapbase + SA1111_INTEN0);
 281 }
 282 
 283 /*
 284  * Attempt to re-trigger the interrupt.  The SA1111 contains a register
 285  * (INTSET) which claims to do this.  However, in practice no amount of
 286  * manipulation of INTEN and INTSET guarantees that the interrupt will
 287  * be triggered.  In fact, its very difficult, if not impossible to get
 288  * INTSET to re-trigger the interrupt.
 289  */
 290 static int sa1111_retrigger_irq(struct irq_data *d)
 291 {
 292         struct sa1111 *sachip = irq_data_get_irq_chip_data(d);
 293         void __iomem *mapbase = sachip->base + SA1111_INTC + sa1111_irqbank(d);
 294         u32 ip, mask = sa1111_irqmask(d);
 295         int i;
 296 
 297         ip = readl_relaxed(mapbase + SA1111_INTPOL0);
 298         for (i = 0; i < 8; i++) {
 299                 writel_relaxed(ip ^ mask, mapbase + SA1111_INTPOL0);
 300                 writel_relaxed(ip, mapbase + SA1111_INTPOL0);
 301                 if (readl_relaxed(mapbase + SA1111_INTSTATCLR0) & mask)
 302                         break;
 303         }
 304 
 305         if (i == 8)
 306                 pr_err("Danger Will Robinson: failed to re-trigger IRQ%d\n",
 307                        d->irq);
 308         return i == 8 ? -1 : 0;
 309 }
 310 
 311 static int sa1111_type_irq(struct irq_data *d, unsigned int flags)
 312 {
 313         struct sa1111 *sachip = irq_data_get_irq_chip_data(d);
 314         void __iomem *mapbase = sachip->base + SA1111_INTC + sa1111_irqbank(d);
 315         u32 ip, mask = sa1111_irqmask(d);
 316 
 317         if (flags == IRQ_TYPE_PROBE)
 318                 return 0;
 319 
 320         if ((!(flags & IRQ_TYPE_EDGE_RISING) ^ !(flags & IRQ_TYPE_EDGE_FALLING)) == 0)
 321                 return -EINVAL;
 322 
 323         ip = readl_relaxed(mapbase + SA1111_INTPOL0);
 324         if (flags & IRQ_TYPE_EDGE_RISING)
 325                 ip &= ~mask;
 326         else
 327                 ip |= mask;
 328         writel_relaxed(ip, mapbase + SA1111_INTPOL0);
 329         writel_relaxed(ip, mapbase + SA1111_WAKEPOL0);
 330 
 331         return 0;
 332 }
 333 
 334 static int sa1111_wake_irq(struct irq_data *d, unsigned int on)
 335 {
 336         struct sa1111 *sachip = irq_data_get_irq_chip_data(d);
 337         void __iomem *mapbase = sachip->base + SA1111_INTC + sa1111_irqbank(d);
 338         u32 we, mask = sa1111_irqmask(d);
 339 
 340         we = readl_relaxed(mapbase + SA1111_WAKEEN0);
 341         if (on)
 342                 we |= mask;
 343         else
 344                 we &= ~mask;
 345         writel_relaxed(we, mapbase + SA1111_WAKEEN0);
 346 
 347         return 0;
 348 }
 349 
 350 static struct irq_chip sa1111_irq_chip = {
 351         .name           = "SA1111",
 352         .irq_ack        = sa1111_ack_irq,
 353         .irq_mask       = sa1111_mask_irq,
 354         .irq_unmask     = sa1111_unmask_irq,
 355         .irq_retrigger  = sa1111_retrigger_irq,
 356         .irq_set_type   = sa1111_type_irq,
 357         .irq_set_wake   = sa1111_wake_irq,
 358 };
 359 
 360 static int sa1111_irqdomain_map(struct irq_domain *d, unsigned int irq,
 361         irq_hw_number_t hwirq)
 362 {
 363         struct sa1111 *sachip = d->host_data;
 364 
 365         /* Disallow unavailable interrupts */
 366         if (hwirq > SSPROR && hwirq < AUDXMTDMADONEA)
 367                 return -EINVAL;
 368 
 369         irq_set_chip_data(irq, sachip);
 370         irq_set_chip_and_handler(irq, &sa1111_irq_chip, handle_edge_irq);
 371         irq_clear_status_flags(irq, IRQ_NOREQUEST | IRQ_NOPROBE);
 372 
 373         return 0;
 374 }
 375 
 376 static const struct irq_domain_ops sa1111_irqdomain_ops = {
 377         .map = sa1111_irqdomain_map,
 378         .xlate = irq_domain_xlate_twocell,
 379 };
 380 
 381 static int sa1111_setup_irq(struct sa1111 *sachip, unsigned irq_base)
 382 {
 383         void __iomem *irqbase = sachip->base + SA1111_INTC;
 384         int ret;
 385 
 386         /*
 387          * We're guaranteed that this region hasn't been taken.
 388          */
 389         request_mem_region(sachip->phys + SA1111_INTC, 512, "irq");
 390 
 391         ret = irq_alloc_descs(-1, irq_base, SA1111_IRQ_NR, -1);
 392         if (ret <= 0) {
 393                 dev_err(sachip->dev, "unable to allocate %u irqs: %d\n",
 394                         SA1111_IRQ_NR, ret);
 395                 if (ret == 0)
 396                         ret = -EINVAL;
 397                 return ret;
 398         }
 399 
 400         sachip->irq_base = ret;
 401 
 402         /* disable all IRQs */
 403         writel_relaxed(0, irqbase + SA1111_INTEN0);
 404         writel_relaxed(0, irqbase + SA1111_INTEN1);
 405         writel_relaxed(0, irqbase + SA1111_WAKEEN0);
 406         writel_relaxed(0, irqbase + SA1111_WAKEEN1);
 407 
 408         /*
 409          * detect on rising edge.  Note: Feb 2001 Errata for SA1111
 410          * specifies that S0ReadyInt and S1ReadyInt should be '1'.
 411          */
 412         writel_relaxed(0, irqbase + SA1111_INTPOL0);
 413         writel_relaxed(BIT(IRQ_S0_READY_NINT & 31) |
 414                        BIT(IRQ_S1_READY_NINT & 31),
 415                        irqbase + SA1111_INTPOL1);
 416 
 417         /* clear all IRQs */
 418         writel_relaxed(~0, irqbase + SA1111_INTSTATCLR0);
 419         writel_relaxed(~0, irqbase + SA1111_INTSTATCLR1);
 420 
 421         sachip->irqdomain = irq_domain_add_linear(NULL, SA1111_IRQ_NR,
 422                                                   &sa1111_irqdomain_ops,
 423                                                   sachip);
 424         if (!sachip->irqdomain) {
 425                 irq_free_descs(sachip->irq_base, SA1111_IRQ_NR);
 426                 return -ENOMEM;
 427         }
 428 
 429         irq_domain_associate_many(sachip->irqdomain,
 430                                   sachip->irq_base + IRQ_GPAIN0,
 431                                   IRQ_GPAIN0, SSPROR + 1 - IRQ_GPAIN0);
 432         irq_domain_associate_many(sachip->irqdomain,
 433                                   sachip->irq_base + AUDXMTDMADONEA,
 434                                   AUDXMTDMADONEA,
 435                                   IRQ_S1_BVD1_STSCHG + 1 - AUDXMTDMADONEA);
 436 
 437         /*
 438          * Register SA1111 interrupt
 439          */
 440         irq_set_irq_type(sachip->irq, IRQ_TYPE_EDGE_RISING);
 441         irq_set_chained_handler_and_data(sachip->irq, sa1111_irq_handler,
 442                                          sachip);
 443 
 444         dev_info(sachip->dev, "Providing IRQ%u-%u\n",
 445                 sachip->irq_base, sachip->irq_base + SA1111_IRQ_NR - 1);
 446 
 447         return 0;
 448 }
 449 
 450 static void sa1111_remove_irq(struct sa1111 *sachip)
 451 {
 452         struct irq_domain *domain = sachip->irqdomain;
 453         void __iomem *irqbase = sachip->base + SA1111_INTC;
 454         int i;
 455 
 456         /* disable all IRQs */
 457         writel_relaxed(0, irqbase + SA1111_INTEN0);
 458         writel_relaxed(0, irqbase + SA1111_INTEN1);
 459         writel_relaxed(0, irqbase + SA1111_WAKEEN0);
 460         writel_relaxed(0, irqbase + SA1111_WAKEEN1);
 461 
 462         irq_set_chained_handler_and_data(sachip->irq, NULL, NULL);
 463         for (i = 0; i < SA1111_IRQ_NR; i++)
 464                 irq_dispose_mapping(irq_find_mapping(domain, i));
 465         irq_domain_remove(domain);
 466 
 467         release_mem_region(sachip->phys + SA1111_INTC, 512);
 468 }
 469 
 470 enum {
 471         SA1111_GPIO_PXDDR = (SA1111_GPIO_PADDR - SA1111_GPIO_PADDR),
 472         SA1111_GPIO_PXDRR = (SA1111_GPIO_PADRR - SA1111_GPIO_PADDR),
 473         SA1111_GPIO_PXDWR = (SA1111_GPIO_PADWR - SA1111_GPIO_PADDR),
 474         SA1111_GPIO_PXSDR = (SA1111_GPIO_PASDR - SA1111_GPIO_PADDR),
 475         SA1111_GPIO_PXSSR = (SA1111_GPIO_PASSR - SA1111_GPIO_PADDR),
 476 };
 477 
 478 static struct sa1111 *gc_to_sa1111(struct gpio_chip *gc)
 479 {
 480         return container_of(gc, struct sa1111, gc);
 481 }
 482 
 483 static void __iomem *sa1111_gpio_map_reg(struct sa1111 *sachip, unsigned offset)
 484 {
 485         void __iomem *reg = sachip->base + SA1111_GPIO;
 486 
 487         if (offset < 4)
 488                 return reg + SA1111_GPIO_PADDR;
 489         if (offset < 10)
 490                 return reg + SA1111_GPIO_PBDDR;
 491         if (offset < 18)
 492                 return reg + SA1111_GPIO_PCDDR;
 493         return NULL;
 494 }
 495 
 496 static u32 sa1111_gpio_map_bit(unsigned offset)
 497 {
 498         if (offset < 4)
 499                 return BIT(offset);
 500         if (offset < 10)
 501                 return BIT(offset - 4);
 502         if (offset < 18)
 503                 return BIT(offset - 10);
 504         return 0;
 505 }
 506 
 507 static void sa1111_gpio_modify(void __iomem *reg, u32 mask, u32 set)
 508 {
 509         u32 val;
 510 
 511         val = readl_relaxed(reg);
 512         val &= ~mask;
 513         val |= mask & set;
 514         writel_relaxed(val, reg);
 515 }
 516 
 517 static int sa1111_gpio_get_direction(struct gpio_chip *gc, unsigned offset)
 518 {
 519         struct sa1111 *sachip = gc_to_sa1111(gc);
 520         void __iomem *reg = sa1111_gpio_map_reg(sachip, offset);
 521         u32 mask = sa1111_gpio_map_bit(offset);
 522 
 523         return !!(readl_relaxed(reg + SA1111_GPIO_PXDDR) & mask);
 524 }
 525 
 526 static int sa1111_gpio_direction_input(struct gpio_chip *gc, unsigned offset)
 527 {
 528         struct sa1111 *sachip = gc_to_sa1111(gc);
 529         unsigned long flags;
 530         void __iomem *reg = sa1111_gpio_map_reg(sachip, offset);
 531         u32 mask = sa1111_gpio_map_bit(offset);
 532 
 533         spin_lock_irqsave(&sachip->lock, flags);
 534         sa1111_gpio_modify(reg + SA1111_GPIO_PXDDR, mask, mask);
 535         sa1111_gpio_modify(reg + SA1111_GPIO_PXSDR, mask, mask);
 536         spin_unlock_irqrestore(&sachip->lock, flags);
 537 
 538         return 0;
 539 }
 540 
 541 static int sa1111_gpio_direction_output(struct gpio_chip *gc, unsigned offset,
 542         int value)
 543 {
 544         struct sa1111 *sachip = gc_to_sa1111(gc);
 545         unsigned long flags;
 546         void __iomem *reg = sa1111_gpio_map_reg(sachip, offset);
 547         u32 mask = sa1111_gpio_map_bit(offset);
 548 
 549         spin_lock_irqsave(&sachip->lock, flags);
 550         sa1111_gpio_modify(reg + SA1111_GPIO_PXDWR, mask, value ? mask : 0);
 551         sa1111_gpio_modify(reg + SA1111_GPIO_PXSSR, mask, value ? mask : 0);
 552         sa1111_gpio_modify(reg + SA1111_GPIO_PXDDR, mask, 0);
 553         sa1111_gpio_modify(reg + SA1111_GPIO_PXSDR, mask, 0);
 554         spin_unlock_irqrestore(&sachip->lock, flags);
 555 
 556         return 0;
 557 }
 558 
 559 static int sa1111_gpio_get(struct gpio_chip *gc, unsigned offset)
 560 {
 561         struct sa1111 *sachip = gc_to_sa1111(gc);
 562         void __iomem *reg = sa1111_gpio_map_reg(sachip, offset);
 563         u32 mask = sa1111_gpio_map_bit(offset);
 564 
 565         return !!(readl_relaxed(reg + SA1111_GPIO_PXDRR) & mask);
 566 }
 567 
 568 static void sa1111_gpio_set(struct gpio_chip *gc, unsigned offset, int value)
 569 {
 570         struct sa1111 *sachip = gc_to_sa1111(gc);
 571         unsigned long flags;
 572         void __iomem *reg = sa1111_gpio_map_reg(sachip, offset);
 573         u32 mask = sa1111_gpio_map_bit(offset);
 574 
 575         spin_lock_irqsave(&sachip->lock, flags);
 576         sa1111_gpio_modify(reg + SA1111_GPIO_PXDWR, mask, value ? mask : 0);
 577         sa1111_gpio_modify(reg + SA1111_GPIO_PXSSR, mask, value ? mask : 0);
 578         spin_unlock_irqrestore(&sachip->lock, flags);
 579 }
 580 
 581 static void sa1111_gpio_set_multiple(struct gpio_chip *gc, unsigned long *mask,
 582         unsigned long *bits)
 583 {
 584         struct sa1111 *sachip = gc_to_sa1111(gc);
 585         unsigned long flags;
 586         void __iomem *reg = sachip->base + SA1111_GPIO;
 587         u32 msk, val;
 588 
 589         msk = *mask;
 590         val = *bits;
 591 
 592         spin_lock_irqsave(&sachip->lock, flags);
 593         sa1111_gpio_modify(reg + SA1111_GPIO_PADWR, msk & 15, val);
 594         sa1111_gpio_modify(reg + SA1111_GPIO_PASSR, msk & 15, val);
 595         sa1111_gpio_modify(reg + SA1111_GPIO_PBDWR, (msk >> 4) & 255, val >> 4);
 596         sa1111_gpio_modify(reg + SA1111_GPIO_PBSSR, (msk >> 4) & 255, val >> 4);
 597         sa1111_gpio_modify(reg + SA1111_GPIO_PCDWR, (msk >> 12) & 255, val >> 12);
 598         sa1111_gpio_modify(reg + SA1111_GPIO_PCSSR, (msk >> 12) & 255, val >> 12);
 599         spin_unlock_irqrestore(&sachip->lock, flags);
 600 }
 601 
 602 static int sa1111_gpio_to_irq(struct gpio_chip *gc, unsigned offset)
 603 {
 604         struct sa1111 *sachip = gc_to_sa1111(gc);
 605 
 606         return sa1111_map_irq(sachip, offset);
 607 }
 608 
 609 static int sa1111_setup_gpios(struct sa1111 *sachip)
 610 {
 611         sachip->gc.label = "sa1111";
 612         sachip->gc.parent = sachip->dev;
 613         sachip->gc.owner = THIS_MODULE;
 614         sachip->gc.get_direction = sa1111_gpio_get_direction;
 615         sachip->gc.direction_input = sa1111_gpio_direction_input;
 616         sachip->gc.direction_output = sa1111_gpio_direction_output;
 617         sachip->gc.get = sa1111_gpio_get;
 618         sachip->gc.set = sa1111_gpio_set;
 619         sachip->gc.set_multiple = sa1111_gpio_set_multiple;
 620         sachip->gc.to_irq = sa1111_gpio_to_irq;
 621         sachip->gc.base = -1;
 622         sachip->gc.ngpio = 18;
 623 
 624         return devm_gpiochip_add_data(sachip->dev, &sachip->gc, sachip);
 625 }
 626 
 627 /*
 628  * Bring the SA1111 out of reset.  This requires a set procedure:
 629  *  1. nRESET asserted (by hardware)
 630  *  2. CLK turned on from SA1110
 631  *  3. nRESET deasserted
 632  *  4. VCO turned on, PLL_BYPASS turned off
 633  *  5. Wait lock time, then assert RCLKEn
 634  *  7. PCR set to allow clocking of individual functions
 635  *
 636  * Until we've done this, the only registers we can access are:
 637  *   SBI_SKCR
 638  *   SBI_SMCR
 639  *   SBI_SKID
 640  */
 641 static void sa1111_wake(struct sa1111 *sachip)
 642 {
 643         unsigned long flags, r;
 644 
 645         spin_lock_irqsave(&sachip->lock, flags);
 646 
 647         clk_enable(sachip->clk);
 648 
 649         /*
 650          * Turn VCO on, and disable PLL Bypass.
 651          */
 652         r = readl_relaxed(sachip->base + SA1111_SKCR);
 653         r &= ~SKCR_VCO_OFF;
 654         writel_relaxed(r, sachip->base + SA1111_SKCR);
 655         r |= SKCR_PLL_BYPASS | SKCR_OE_EN;
 656         writel_relaxed(r, sachip->base + SA1111_SKCR);
 657 
 658         /*
 659          * Wait lock time.  SA1111 manual _doesn't_
 660          * specify a figure for this!  We choose 100us.
 661          */
 662         udelay(100);
 663 
 664         /*
 665          * Enable RCLK.  We also ensure that RDYEN is set.
 666          */
 667         r |= SKCR_RCLKEN | SKCR_RDYEN;
 668         writel_relaxed(r, sachip->base + SA1111_SKCR);
 669 
 670         /*
 671          * Wait 14 RCLK cycles for the chip to finish coming out
 672          * of reset. (RCLK=24MHz).  This is 590ns.
 673          */
 674         udelay(1);
 675 
 676         /*
 677          * Ensure all clocks are initially off.
 678          */
 679         writel_relaxed(0, sachip->base + SA1111_SKPCR);
 680 
 681         spin_unlock_irqrestore(&sachip->lock, flags);
 682 }
 683 
 684 #ifdef CONFIG_ARCH_SA1100
 685 
 686 static u32 sa1111_dma_mask[] = {
 687         ~0,
 688         ~(1 << 20),
 689         ~(1 << 23),
 690         ~(1 << 24),
 691         ~(1 << 25),
 692         ~(1 << 20),
 693         ~(1 << 20),
 694         0,
 695 };
 696 
 697 /*
 698  * Configure the SA1111 shared memory controller.
 699  */
 700 void
 701 sa1111_configure_smc(struct sa1111 *sachip, int sdram, unsigned int drac,
 702                      unsigned int cas_latency)
 703 {
 704         unsigned int smcr = SMCR_DTIM | SMCR_MBGE | FInsrt(drac, SMCR_DRAC);
 705 
 706         if (cas_latency == 3)
 707                 smcr |= SMCR_CLAT;
 708 
 709         writel_relaxed(smcr, sachip->base + SA1111_SMCR);
 710 
 711         /*
 712          * Now clear the bits in the DMA mask to work around the SA1111
 713          * DMA erratum (Intel StrongARM SA-1111 Microprocessor Companion
 714          * Chip Specification Update, June 2000, Erratum #7).
 715          */
 716         if (sachip->dev->dma_mask)
 717                 *sachip->dev->dma_mask &= sa1111_dma_mask[drac >> 2];
 718 
 719         sachip->dev->coherent_dma_mask &= sa1111_dma_mask[drac >> 2];
 720 }
 721 #endif
 722 
 723 static void sa1111_dev_release(struct device *_dev)
 724 {
 725         struct sa1111_dev *dev = to_sa1111_device(_dev);
 726 
 727         kfree(dev);
 728 }
 729 
 730 static int
 731 sa1111_init_one_child(struct sa1111 *sachip, struct resource *parent,
 732                       struct sa1111_dev_info *info)
 733 {
 734         struct sa1111_dev *dev;
 735         unsigned i;
 736         int ret;
 737 
 738         dev = kzalloc(sizeof(struct sa1111_dev), GFP_KERNEL);
 739         if (!dev) {
 740                 ret = -ENOMEM;
 741                 goto err_alloc;
 742         }
 743 
 744         device_initialize(&dev->dev);
 745         dev_set_name(&dev->dev, "%4.4lx", info->offset);
 746         dev->devid       = info->devid;
 747         dev->dev.parent  = sachip->dev;
 748         dev->dev.bus     = &sa1111_bus_type;
 749         dev->dev.release = sa1111_dev_release;
 750         dev->res.start   = sachip->phys + info->offset;
 751         dev->res.end     = dev->res.start + 511;
 752         dev->res.name    = dev_name(&dev->dev);
 753         dev->res.flags   = IORESOURCE_MEM;
 754         dev->mapbase     = sachip->base + info->offset;
 755         dev->skpcr_mask  = info->skpcr_mask;
 756 
 757         for (i = 0; i < ARRAY_SIZE(info->hwirq); i++)
 758                 dev->hwirq[i] = info->hwirq[i];
 759 
 760         /*
 761          * If the parent device has a DMA mask associated with it, and
 762          * this child supports DMA, propagate it down to the children.
 763          */
 764         if (info->dma && sachip->dev->dma_mask) {
 765                 dev->dma_mask = *sachip->dev->dma_mask;
 766                 dev->dev.dma_mask = &dev->dma_mask;
 767                 dev->dev.coherent_dma_mask = sachip->dev->coherent_dma_mask;
 768         }
 769 
 770         ret = request_resource(parent, &dev->res);
 771         if (ret) {
 772                 dev_err(sachip->dev, "failed to allocate resource for %s\n",
 773                         dev->res.name);
 774                 goto err_resource;
 775         }
 776 
 777         ret = device_add(&dev->dev);
 778         if (ret)
 779                 goto err_add;
 780         return 0;
 781 
 782  err_add:
 783         release_resource(&dev->res);
 784  err_resource:
 785         put_device(&dev->dev);
 786  err_alloc:
 787         return ret;
 788 }
 789 
 790 /**
 791  *      sa1111_probe - probe for a single SA1111 chip.
 792  *      @phys_addr: physical address of device.
 793  *
 794  *      Probe for a SA1111 chip.  This must be called
 795  *      before any other SA1111-specific code.
 796  *
 797  *      Returns:
 798  *      %-ENODEV        device not found.
 799  *      %-EBUSY         physical address already marked in-use.
 800  *      %-EINVAL        no platform data passed
 801  *      %0              successful.
 802  */
 803 static int __sa1111_probe(struct device *me, struct resource *mem, int irq)
 804 {
 805         struct sa1111_platform_data *pd = me->platform_data;
 806         struct sa1111 *sachip;
 807         unsigned long id;
 808         unsigned int has_devs;
 809         int i, ret = -ENODEV;
 810 
 811         if (!pd)
 812                 return -EINVAL;
 813 
 814         sachip = devm_kzalloc(me, sizeof(struct sa1111), GFP_KERNEL);
 815         if (!sachip)
 816                 return -ENOMEM;
 817 
 818         sachip->clk = devm_clk_get(me, "SA1111_CLK");
 819         if (IS_ERR(sachip->clk))
 820                 return PTR_ERR(sachip->clk);
 821 
 822         ret = clk_prepare(sachip->clk);
 823         if (ret)
 824                 return ret;
 825 
 826         spin_lock_init(&sachip->lock);
 827 
 828         sachip->dev = me;
 829         dev_set_drvdata(sachip->dev, sachip);
 830 
 831         sachip->pdata = pd;
 832         sachip->phys = mem->start;
 833         sachip->irq = irq;
 834 
 835         /*
 836          * Map the whole region.  This also maps the
 837          * registers for our children.
 838          */
 839         sachip->base = ioremap(mem->start, PAGE_SIZE * 2);
 840         if (!sachip->base) {
 841                 ret = -ENOMEM;
 842                 goto err_clk_unprep;
 843         }
 844 
 845         /*
 846          * Probe for the chip.  Only touch the SBI registers.
 847          */
 848         id = readl_relaxed(sachip->base + SA1111_SKID);
 849         if ((id & SKID_ID_MASK) != SKID_SA1111_ID) {
 850                 printk(KERN_DEBUG "SA1111 not detected: ID = %08lx\n", id);
 851                 ret = -ENODEV;
 852                 goto err_unmap;
 853         }
 854 
 855         pr_info("SA1111 Microprocessor Companion Chip: silicon revision %lx, metal revision %lx\n",
 856                 (id & SKID_SIREV_MASK) >> 4, id & SKID_MTREV_MASK);
 857 
 858         /*
 859          * We found it.  Wake the chip up, and initialise.
 860          */
 861         sa1111_wake(sachip);
 862 
 863         /*
 864          * The interrupt controller must be initialised before any
 865          * other device to ensure that the interrupts are available.
 866          */
 867         ret = sa1111_setup_irq(sachip, pd->irq_base);
 868         if (ret)
 869                 goto err_clk;
 870 
 871         /* Setup the GPIOs - should really be done after the IRQ setup */
 872         ret = sa1111_setup_gpios(sachip);
 873         if (ret)
 874                 goto err_irq;
 875 
 876 #ifdef CONFIG_ARCH_SA1100
 877         {
 878         unsigned int val;
 879 
 880         /*
 881          * The SDRAM configuration of the SA1110 and the SA1111 must
 882          * match.  This is very important to ensure that SA1111 accesses
 883          * don't corrupt the SDRAM.  Note that this ungates the SA1111's
 884          * MBGNT signal, so we must have called sa1110_mb_disable()
 885          * beforehand.
 886          */
 887         sa1111_configure_smc(sachip, 1,
 888                              FExtr(MDCNFG, MDCNFG_SA1110_DRAC0),
 889                              FExtr(MDCNFG, MDCNFG_SA1110_TDL0));
 890 
 891         /*
 892          * We only need to turn on DCLK whenever we want to use the
 893          * DMA.  It can otherwise be held firmly in the off position.
 894          * (currently, we always enable it.)
 895          */
 896         val = readl_relaxed(sachip->base + SA1111_SKPCR);
 897         writel_relaxed(val | SKPCR_DCLKEN, sachip->base + SA1111_SKPCR);
 898 
 899         /*
 900          * Enable the SA1110 memory bus request and grant signals.
 901          */
 902         sa1110_mb_enable();
 903         }
 904 #endif
 905 
 906         g_sa1111 = sachip;
 907 
 908         has_devs = ~0;
 909         if (pd)
 910                 has_devs &= ~pd->disable_devs;
 911 
 912         for (i = 0; i < ARRAY_SIZE(sa1111_devices); i++)
 913                 if (sa1111_devices[i].devid & has_devs)
 914                         sa1111_init_one_child(sachip, mem, &sa1111_devices[i]);
 915 
 916         return 0;
 917 
 918  err_irq:
 919         sa1111_remove_irq(sachip);
 920  err_clk:
 921         clk_disable(sachip->clk);
 922  err_unmap:
 923         iounmap(sachip->base);
 924  err_clk_unprep:
 925         clk_unprepare(sachip->clk);
 926         return ret;
 927 }
 928 
 929 static int sa1111_remove_one(struct device *dev, void *data)
 930 {
 931         struct sa1111_dev *sadev = to_sa1111_device(dev);
 932         if (dev->bus != &sa1111_bus_type)
 933                 return 0;
 934         device_del(&sadev->dev);
 935         release_resource(&sadev->res);
 936         put_device(&sadev->dev);
 937         return 0;
 938 }
 939 
 940 static void __sa1111_remove(struct sa1111 *sachip)
 941 {
 942         device_for_each_child(sachip->dev, NULL, sa1111_remove_one);
 943 
 944         sa1111_remove_irq(sachip);
 945 
 946         clk_disable(sachip->clk);
 947         clk_unprepare(sachip->clk);
 948 
 949         iounmap(sachip->base);
 950 }
 951 
 952 struct sa1111_save_data {
 953         unsigned int    skcr;
 954         unsigned int    skpcr;
 955         unsigned int    skcdr;
 956         unsigned char   skaud;
 957         unsigned char   skpwm0;
 958         unsigned char   skpwm1;
 959 
 960         /*
 961          * Interrupt controller
 962          */
 963         unsigned int    intpol0;
 964         unsigned int    intpol1;
 965         unsigned int    inten0;
 966         unsigned int    inten1;
 967         unsigned int    wakepol0;
 968         unsigned int    wakepol1;
 969         unsigned int    wakeen0;
 970         unsigned int    wakeen1;
 971 };
 972 
 973 #ifdef CONFIG_PM
 974 
 975 static int sa1111_suspend_noirq(struct device *dev)
 976 {
 977         struct sa1111 *sachip = dev_get_drvdata(dev);
 978         struct sa1111_save_data *save;
 979         unsigned long flags;
 980         unsigned int val;
 981         void __iomem *base;
 982 
 983         save = kmalloc(sizeof(struct sa1111_save_data), GFP_KERNEL);
 984         if (!save)
 985                 return -ENOMEM;
 986         sachip->saved_state = save;
 987 
 988         spin_lock_irqsave(&sachip->lock, flags);
 989 
 990         /*
 991          * Save state.
 992          */
 993         base = sachip->base;
 994         save->skcr     = readl_relaxed(base + SA1111_SKCR);
 995         save->skpcr    = readl_relaxed(base + SA1111_SKPCR);
 996         save->skcdr    = readl_relaxed(base + SA1111_SKCDR);
 997         save->skaud    = readl_relaxed(base + SA1111_SKAUD);
 998         save->skpwm0   = readl_relaxed(base + SA1111_SKPWM0);
 999         save->skpwm1   = readl_relaxed(base + SA1111_SKPWM1);
1000 
1001         writel_relaxed(0, sachip->base + SA1111_SKPWM0);
1002         writel_relaxed(0, sachip->base + SA1111_SKPWM1);
1003 
1004         base = sachip->base + SA1111_INTC;
1005         save->intpol0  = readl_relaxed(base + SA1111_INTPOL0);
1006         save->intpol1  = readl_relaxed(base + SA1111_INTPOL1);
1007         save->inten0   = readl_relaxed(base + SA1111_INTEN0);
1008         save->inten1   = readl_relaxed(base + SA1111_INTEN1);
1009         save->wakepol0 = readl_relaxed(base + SA1111_WAKEPOL0);
1010         save->wakepol1 = readl_relaxed(base + SA1111_WAKEPOL1);
1011         save->wakeen0  = readl_relaxed(base + SA1111_WAKEEN0);
1012         save->wakeen1  = readl_relaxed(base + SA1111_WAKEEN1);
1013 
1014         /*
1015          * Disable.
1016          */
1017         val = readl_relaxed(sachip->base + SA1111_SKCR);
1018         writel_relaxed(val | SKCR_SLEEP, sachip->base + SA1111_SKCR);
1019 
1020         clk_disable(sachip->clk);
1021 
1022         spin_unlock_irqrestore(&sachip->lock, flags);
1023 
1024 #ifdef CONFIG_ARCH_SA1100
1025         sa1110_mb_disable();
1026 #endif
1027 
1028         return 0;
1029 }
1030 
1031 /*
1032  *      sa1111_resume - Restore the SA1111 device state.
1033  *      @dev: device to restore
1034  *
1035  *      Restore the general state of the SA1111; clock control and
1036  *      interrupt controller.  Other parts of the SA1111 must be
1037  *      restored by their respective drivers, and must be called
1038  *      via LDM after this function.
1039  */
1040 static int sa1111_resume_noirq(struct device *dev)
1041 {
1042         struct sa1111 *sachip = dev_get_drvdata(dev);
1043         struct sa1111_save_data *save;
1044         unsigned long flags, id;
1045         void __iomem *base;
1046 
1047         save = sachip->saved_state;
1048         if (!save)
1049                 return 0;
1050 
1051         /*
1052          * Ensure that the SA1111 is still here.
1053          * FIXME: shouldn't do this here.
1054          */
1055         id = readl_relaxed(sachip->base + SA1111_SKID);
1056         if ((id & SKID_ID_MASK) != SKID_SA1111_ID) {
1057                 __sa1111_remove(sachip);
1058                 dev_set_drvdata(dev, NULL);
1059                 kfree(save);
1060                 return 0;
1061         }
1062 
1063         /*
1064          * First of all, wake up the chip.
1065          */
1066         sa1111_wake(sachip);
1067 
1068 #ifdef CONFIG_ARCH_SA1100
1069         /* Enable the memory bus request/grant signals */
1070         sa1110_mb_enable();
1071 #endif
1072 
1073         /*
1074          * Only lock for write ops. Also, sa1111_wake must be called with
1075          * released spinlock!
1076          */
1077         spin_lock_irqsave(&sachip->lock, flags);
1078 
1079         writel_relaxed(0, sachip->base + SA1111_INTC + SA1111_INTEN0);
1080         writel_relaxed(0, sachip->base + SA1111_INTC + SA1111_INTEN1);
1081 
1082         base = sachip->base;
1083         writel_relaxed(save->skcr,     base + SA1111_SKCR);
1084         writel_relaxed(save->skpcr,    base + SA1111_SKPCR);
1085         writel_relaxed(save->skcdr,    base + SA1111_SKCDR);
1086         writel_relaxed(save->skaud,    base + SA1111_SKAUD);
1087         writel_relaxed(save->skpwm0,   base + SA1111_SKPWM0);
1088         writel_relaxed(save->skpwm1,   base + SA1111_SKPWM1);
1089 
1090         base = sachip->base + SA1111_INTC;
1091         writel_relaxed(save->intpol0,  base + SA1111_INTPOL0);
1092         writel_relaxed(save->intpol1,  base + SA1111_INTPOL1);
1093         writel_relaxed(save->inten0,   base + SA1111_INTEN0);
1094         writel_relaxed(save->inten1,   base + SA1111_INTEN1);
1095         writel_relaxed(save->wakepol0, base + SA1111_WAKEPOL0);
1096         writel_relaxed(save->wakepol1, base + SA1111_WAKEPOL1);
1097         writel_relaxed(save->wakeen0,  base + SA1111_WAKEEN0);
1098         writel_relaxed(save->wakeen1,  base + SA1111_WAKEEN1);
1099 
1100         spin_unlock_irqrestore(&sachip->lock, flags);
1101 
1102         sachip->saved_state = NULL;
1103         kfree(save);
1104 
1105         return 0;
1106 }
1107 
1108 #else
1109 #define sa1111_suspend_noirq NULL
1110 #define sa1111_resume_noirq  NULL
1111 #endif
1112 
1113 static int sa1111_probe(struct platform_device *pdev)
1114 {
1115         struct resource *mem;
1116         int irq;
1117 
1118         mem = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1119         if (!mem)
1120                 return -EINVAL;
1121         irq = platform_get_irq(pdev, 0);
1122         if (irq < 0)
1123                 return irq;
1124 
1125         return __sa1111_probe(&pdev->dev, mem, irq);
1126 }
1127 
1128 static int sa1111_remove(struct platform_device *pdev)
1129 {
1130         struct sa1111 *sachip = platform_get_drvdata(pdev);
1131 
1132         if (sachip) {
1133 #ifdef CONFIG_PM
1134                 kfree(sachip->saved_state);
1135                 sachip->saved_state = NULL;
1136 #endif
1137                 __sa1111_remove(sachip);
1138                 platform_set_drvdata(pdev, NULL);
1139         }
1140 
1141         return 0;
1142 }
1143 
1144 static struct dev_pm_ops sa1111_pm_ops = {
1145         .suspend_noirq = sa1111_suspend_noirq,
1146         .resume_noirq = sa1111_resume_noirq,
1147 };
1148 
1149 /*
1150  *      Not sure if this should be on the system bus or not yet.
1151  *      We really want some way to register a system device at
1152  *      the per-machine level, and then have this driver pick
1153  *      up the registered devices.
1154  *
1155  *      We also need to handle the SDRAM configuration for
1156  *      PXA250/SA1110 machine classes.
1157  */
1158 static struct platform_driver sa1111_device_driver = {
1159         .probe          = sa1111_probe,
1160         .remove         = sa1111_remove,
1161         .driver         = {
1162                 .name   = "sa1111",
1163                 .pm     = &sa1111_pm_ops,
1164         },
1165 };
1166 
1167 /*
1168  *      Get the parent device driver (us) structure
1169  *      from a child function device
1170  */
1171 static inline struct sa1111 *sa1111_chip_driver(struct sa1111_dev *sadev)
1172 {
1173         return (struct sa1111 *)dev_get_drvdata(sadev->dev.parent);
1174 }
1175 
1176 /*
1177  * The bits in the opdiv field are non-linear.
1178  */
1179 static unsigned char opdiv_table[] = { 1, 4, 2, 8 };
1180 
1181 static unsigned int __sa1111_pll_clock(struct sa1111 *sachip)
1182 {
1183         unsigned int skcdr, fbdiv, ipdiv, opdiv;
1184 
1185         skcdr = readl_relaxed(sachip->base + SA1111_SKCDR);
1186 
1187         fbdiv = (skcdr & 0x007f) + 2;
1188         ipdiv = ((skcdr & 0x0f80) >> 7) + 2;
1189         opdiv = opdiv_table[(skcdr & 0x3000) >> 12];
1190 
1191         return 3686400 * fbdiv / (ipdiv * opdiv);
1192 }
1193 
1194 /**
1195  *      sa1111_pll_clock - return the current PLL clock frequency.
1196  *      @sadev: SA1111 function block
1197  *
1198  *      BUG: we should look at SKCR.  We also blindly believe that
1199  *      the chip is being fed with the 3.6864MHz clock.
1200  *
1201  *      Returns the PLL clock in Hz.
1202  */
1203 unsigned int sa1111_pll_clock(struct sa1111_dev *sadev)
1204 {
1205         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1206 
1207         return __sa1111_pll_clock(sachip);
1208 }
1209 EXPORT_SYMBOL(sa1111_pll_clock);
1210 
1211 /**
1212  *      sa1111_select_audio_mode - select I2S or AC link mode
1213  *      @sadev: SA1111 function block
1214  *      @mode: One of %SA1111_AUDIO_ACLINK or %SA1111_AUDIO_I2S
1215  *
1216  *      Frob the SKCR to select AC Link mode or I2S mode for
1217  *      the audio block.
1218  */
1219 void sa1111_select_audio_mode(struct sa1111_dev *sadev, int mode)
1220 {
1221         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1222         unsigned long flags;
1223         unsigned int val;
1224 
1225         spin_lock_irqsave(&sachip->lock, flags);
1226 
1227         val = readl_relaxed(sachip->base + SA1111_SKCR);
1228         if (mode == SA1111_AUDIO_I2S) {
1229                 val &= ~SKCR_SELAC;
1230         } else {
1231                 val |= SKCR_SELAC;
1232         }
1233         writel_relaxed(val, sachip->base + SA1111_SKCR);
1234 
1235         spin_unlock_irqrestore(&sachip->lock, flags);
1236 }
1237 EXPORT_SYMBOL(sa1111_select_audio_mode);
1238 
1239 /**
1240  *      sa1111_set_audio_rate - set the audio sample rate
1241  *      @sadev: SA1111 SAC function block
1242  *      @rate: sample rate to select
1243  */
1244 int sa1111_set_audio_rate(struct sa1111_dev *sadev, int rate)
1245 {
1246         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1247         unsigned int div;
1248 
1249         if (sadev->devid != SA1111_DEVID_SAC)
1250                 return -EINVAL;
1251 
1252         div = (__sa1111_pll_clock(sachip) / 256 + rate / 2) / rate;
1253         if (div == 0)
1254                 div = 1;
1255         if (div > 128)
1256                 div = 128;
1257 
1258         writel_relaxed(div - 1, sachip->base + SA1111_SKAUD);
1259 
1260         return 0;
1261 }
1262 EXPORT_SYMBOL(sa1111_set_audio_rate);
1263 
1264 /**
1265  *      sa1111_get_audio_rate - get the audio sample rate
1266  *      @sadev: SA1111 SAC function block device
1267  */
1268 int sa1111_get_audio_rate(struct sa1111_dev *sadev)
1269 {
1270         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1271         unsigned long div;
1272 
1273         if (sadev->devid != SA1111_DEVID_SAC)
1274                 return -EINVAL;
1275 
1276         div = readl_relaxed(sachip->base + SA1111_SKAUD) + 1;
1277 
1278         return __sa1111_pll_clock(sachip) / (256 * div);
1279 }
1280 EXPORT_SYMBOL(sa1111_get_audio_rate);
1281 
1282 /*
1283  * Individual device operations.
1284  */
1285 
1286 /**
1287  *      sa1111_enable_device - enable an on-chip SA1111 function block
1288  *      @sadev: SA1111 function block device to enable
1289  */
1290 int sa1111_enable_device(struct sa1111_dev *sadev)
1291 {
1292         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1293         unsigned long flags;
1294         unsigned int val;
1295         int ret = 0;
1296 
1297         if (sachip->pdata && sachip->pdata->enable)
1298                 ret = sachip->pdata->enable(sachip->pdata->data, sadev->devid);
1299 
1300         if (ret == 0) {
1301                 spin_lock_irqsave(&sachip->lock, flags);
1302                 val = readl_relaxed(sachip->base + SA1111_SKPCR);
1303                 writel_relaxed(val | sadev->skpcr_mask, sachip->base + SA1111_SKPCR);
1304                 spin_unlock_irqrestore(&sachip->lock, flags);
1305         }
1306         return ret;
1307 }
1308 EXPORT_SYMBOL(sa1111_enable_device);
1309 
1310 /**
1311  *      sa1111_disable_device - disable an on-chip SA1111 function block
1312  *      @sadev: SA1111 function block device to disable
1313  */
1314 void sa1111_disable_device(struct sa1111_dev *sadev)
1315 {
1316         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1317         unsigned long flags;
1318         unsigned int val;
1319 
1320         spin_lock_irqsave(&sachip->lock, flags);
1321         val = readl_relaxed(sachip->base + SA1111_SKPCR);
1322         writel_relaxed(val & ~sadev->skpcr_mask, sachip->base + SA1111_SKPCR);
1323         spin_unlock_irqrestore(&sachip->lock, flags);
1324 
1325         if (sachip->pdata && sachip->pdata->disable)
1326                 sachip->pdata->disable(sachip->pdata->data, sadev->devid);
1327 }
1328 EXPORT_SYMBOL(sa1111_disable_device);
1329 
1330 int sa1111_get_irq(struct sa1111_dev *sadev, unsigned num)
1331 {
1332         struct sa1111 *sachip = sa1111_chip_driver(sadev);
1333         if (num >= ARRAY_SIZE(sadev->hwirq))
1334                 return -EINVAL;
1335         return sa1111_map_irq(sachip, sadev->hwirq[num]);
1336 }
1337 EXPORT_SYMBOL_GPL(sa1111_get_irq);
1338 
1339 /*
1340  *      SA1111 "Register Access Bus."
1341  *
1342  *      We model this as a regular bus type, and hang devices directly
1343  *      off this.
1344  */
1345 static int sa1111_match(struct device *_dev, struct device_driver *_drv)
1346 {
1347         struct sa1111_dev *dev = to_sa1111_device(_dev);
1348         struct sa1111_driver *drv = SA1111_DRV(_drv);
1349 
1350         return !!(dev->devid & drv->devid);
1351 }
1352 
1353 static int sa1111_bus_probe(struct device *dev)
1354 {
1355         struct sa1111_dev *sadev = to_sa1111_device(dev);
1356         struct sa1111_driver *drv = SA1111_DRV(dev->driver);
1357         int ret = -ENODEV;
1358 
1359         if (drv->probe)
1360                 ret = drv->probe(sadev);
1361         return ret;
1362 }
1363 
1364 static int sa1111_bus_remove(struct device *dev)
1365 {
1366         struct sa1111_dev *sadev = to_sa1111_device(dev);
1367         struct sa1111_driver *drv = SA1111_DRV(dev->driver);
1368         int ret = 0;
1369 
1370         if (drv->remove)
1371                 ret = drv->remove(sadev);
1372         return ret;
1373 }
1374 
1375 struct bus_type sa1111_bus_type = {
1376         .name           = "sa1111-rab",
1377         .match          = sa1111_match,
1378         .probe          = sa1111_bus_probe,
1379         .remove         = sa1111_bus_remove,
1380 };
1381 EXPORT_SYMBOL(sa1111_bus_type);
1382 
1383 int sa1111_driver_register(struct sa1111_driver *driver)
1384 {
1385         driver->drv.bus = &sa1111_bus_type;
1386         return driver_register(&driver->drv);
1387 }
1388 EXPORT_SYMBOL(sa1111_driver_register);
1389 
1390 void sa1111_driver_unregister(struct sa1111_driver *driver)
1391 {
1392         driver_unregister(&driver->drv);
1393 }
1394 EXPORT_SYMBOL(sa1111_driver_unregister);
1395 
1396 #ifdef CONFIG_DMABOUNCE
1397 /*
1398  * According to the "Intel StrongARM SA-1111 Microprocessor Companion
1399  * Chip Specification Update" (June 2000), erratum #7, there is a
1400  * significant bug in the SA1111 SDRAM shared memory controller.  If
1401  * an access to a region of memory above 1MB relative to the bank base,
1402  * it is important that address bit 10 _NOT_ be asserted. Depending
1403  * on the configuration of the RAM, bit 10 may correspond to one
1404  * of several different (processor-relative) address bits.
1405  *
1406  * This routine only identifies whether or not a given DMA address
1407  * is susceptible to the bug.
1408  *
1409  * This should only get called for sa1111_device types due to the
1410  * way we configure our device dma_masks.
1411  */
1412 static int sa1111_needs_bounce(struct device *dev, dma_addr_t addr, size_t size)
1413 {
1414         /*
1415          * Section 4.6 of the "Intel StrongARM SA-1111 Development Module
1416          * User's Guide" mentions that jumpers R51 and R52 control the
1417          * target of SA-1111 DMA (either SDRAM bank 0 on Assabet, or
1418          * SDRAM bank 1 on Neponset). The default configuration selects
1419          * Assabet, so any address in bank 1 is necessarily invalid.
1420          */
1421         return (machine_is_assabet() || machine_is_pfs168()) &&
1422                 (addr >= 0xc8000000 || (addr + size) >= 0xc8000000);
1423 }
1424 
1425 static int sa1111_notifier_call(struct notifier_block *n, unsigned long action,
1426         void *data)
1427 {
1428         struct sa1111_dev *dev = to_sa1111_device(data);
1429 
1430         switch (action) {
1431         case BUS_NOTIFY_ADD_DEVICE:
1432                 if (dev->dev.dma_mask && dev->dma_mask < 0xffffffffUL) {
1433                         int ret = dmabounce_register_dev(&dev->dev, 1024, 4096,
1434                                         sa1111_needs_bounce);
1435                         if (ret)
1436                                 dev_err(&dev->dev, "failed to register with dmabounce: %d\n", ret);
1437                 }
1438                 break;
1439 
1440         case BUS_NOTIFY_DEL_DEVICE:
1441                 if (dev->dev.dma_mask && dev->dma_mask < 0xffffffffUL)
1442                         dmabounce_unregister_dev(&dev->dev);
1443                 break;
1444         }
1445         return NOTIFY_OK;
1446 }
1447 
1448 static struct notifier_block sa1111_bus_notifier = {
1449         .notifier_call = sa1111_notifier_call,
1450 };
1451 #endif
1452 
1453 static int __init sa1111_init(void)
1454 {
1455         int ret = bus_register(&sa1111_bus_type);
1456 #ifdef CONFIG_DMABOUNCE
1457         if (ret == 0)
1458                 bus_register_notifier(&sa1111_bus_type, &sa1111_bus_notifier);
1459 #endif
1460         if (ret == 0)
1461                 platform_driver_register(&sa1111_device_driver);
1462         return ret;
1463 }
1464 
1465 static void __exit sa1111_exit(void)
1466 {
1467         platform_driver_unregister(&sa1111_device_driver);
1468 #ifdef CONFIG_DMABOUNCE
1469         bus_unregister_notifier(&sa1111_bus_type, &sa1111_bus_notifier);
1470 #endif
1471         bus_unregister(&sa1111_bus_type);
1472 }
1473 
1474 subsys_initcall(sa1111_init);
1475 module_exit(sa1111_exit);
1476 
1477 MODULE_DESCRIPTION("Intel Corporation SA1111 core driver");
1478 MODULE_LICENSE("GPL");

/* [<][>][^][v][top][bottom][index][help] */