platform.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * Pb1550 board platform device registration
  3. *
  4. * Copyright (C) 2009 Manuel Lauss
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU General Public License
  17. * along with this program; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. #include <linux/init.h>
  21. #include <asm/mach-au1x00/au1000.h>
  22. #include <asm/mach-pb1x00/pb1550.h>
  23. #include <asm/mach-db1x00/bcsr.h>
  24. #include "../platform.h"
  25. static int __init pb1550_dev_init(void)
  26. {
  27. int swapped;
  28. /* Pb1550, like all others, also has statuschange irqs; however they're
  29. * wired up on one of the Au1550's shared GPIO201_205 line, which also
  30. * services the PCMCIA card interrupts. So we ignore statuschange and
  31. * use the GPIO201_205 exclusively for card interrupts, since a) pcmcia
  32. * drivers are used to shared irqs and b) statuschange isn't really use-
  33. * ful anyway.
  34. */
  35. db1x_register_pcmcia_socket(PCMCIA_ATTR_PHYS_ADDR,
  36. PCMCIA_ATTR_PHYS_ADDR + 0x000400000 - 1,
  37. PCMCIA_MEM_PHYS_ADDR,
  38. PCMCIA_MEM_PHYS_ADDR + 0x000400000 - 1,
  39. PCMCIA_IO_PHYS_ADDR,
  40. PCMCIA_IO_PHYS_ADDR + 0x000010000 - 1,
  41. AU1550_GPIO201_205_INT,
  42. AU1550_GPIO0_INT,
  43. 0,
  44. 0,
  45. 0);
  46. db1x_register_pcmcia_socket(PCMCIA_ATTR_PHYS_ADDR + 0x008000000,
  47. PCMCIA_ATTR_PHYS_ADDR + 0x008400000 - 1,
  48. PCMCIA_MEM_PHYS_ADDR + 0x008000000,
  49. PCMCIA_MEM_PHYS_ADDR + 0x008400000 - 1,
  50. PCMCIA_IO_PHYS_ADDR + 0x008000000,
  51. PCMCIA_IO_PHYS_ADDR + 0x008010000 - 1,
  52. AU1550_GPIO201_205_INT,
  53. AU1550_GPIO1_INT,
  54. 0,
  55. 0,
  56. 1);
  57. swapped = bcsr_read(BCSR_STATUS) & BCSR_STATUS_PB1550_SWAPBOOT;
  58. db1x_register_norflash(128 * 1024 * 1024, 4, swapped);
  59. return 0;
  60. }
  61. device_initcall(pb1550_dev_init);