board-espt.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /*
  2. * Data Technology Inc. ESPT-GIGA board support
  3. *
  4. * Copyright (C) 2008, 2009 Renesas Solutions Corp.
  5. * Copyright (C) 2008, 2009 Nobuhiro Iwamatsu <iwamatsu.nobuhiro@renesas.com>
  6. *
  7. * This file is subject to the terms and conditions of the GNU General Public
  8. * License. See the file "COPYING" in the main directory of this archive
  9. * for more details.
  10. */
  11. #include <linux/init.h>
  12. #include <linux/platform_device.h>
  13. #include <linux/interrupt.h>
  14. #include <linux/mtd/physmap.h>
  15. #include <linux/io.h>
  16. #include <linux/sh_eth.h>
  17. #include <linux/sh_intc.h>
  18. #include <asm/machvec.h>
  19. #include <asm/sizes.h>
  20. /* NOR Flash */
  21. static struct mtd_partition espt_nor_flash_partitions[] = {
  22. {
  23. .name = "U-Boot",
  24. .offset = 0,
  25. .size = (2 * SZ_128K),
  26. .mask_flags = MTD_WRITEABLE, /* Read-only */
  27. }, {
  28. .name = "Linux-Kernel",
  29. .offset = MTDPART_OFS_APPEND,
  30. .size = (20 * SZ_128K),
  31. }, {
  32. .name = "Root Filesystem",
  33. .offset = MTDPART_OFS_APPEND,
  34. .size = MTDPART_SIZ_FULL,
  35. },
  36. };
  37. static struct physmap_flash_data espt_nor_flash_data = {
  38. .width = 2,
  39. .parts = espt_nor_flash_partitions,
  40. .nr_parts = ARRAY_SIZE(espt_nor_flash_partitions),
  41. };
  42. static struct resource espt_nor_flash_resources[] = {
  43. [0] = {
  44. .name = "NOR Flash",
  45. .start = 0,
  46. .end = SZ_8M - 1,
  47. .flags = IORESOURCE_MEM,
  48. },
  49. };
  50. static struct platform_device espt_nor_flash_device = {
  51. .name = "physmap-flash",
  52. .resource = espt_nor_flash_resources,
  53. .num_resources = ARRAY_SIZE(espt_nor_flash_resources),
  54. .dev = {
  55. .platform_data = &espt_nor_flash_data,
  56. },
  57. };
  58. /* SH-Ether */
  59. static struct resource sh_eth_resources[] = {
  60. {
  61. .start = 0xFEE00800, /* use eth1 */
  62. .end = 0xFEE00F7C - 1,
  63. .flags = IORESOURCE_MEM,
  64. }, {
  65. .start = 0xFEE01800, /* TSU */
  66. .end = 0xFEE01FFF,
  67. .flags = IORESOURCE_MEM,
  68. }, {
  69. .start = evt2irq(0x920), /* irq number */
  70. .flags = IORESOURCE_IRQ,
  71. },
  72. };
  73. static struct sh_eth_plat_data sh7763_eth_pdata = {
  74. .phy = 0,
  75. .edmac_endian = EDMAC_LITTLE_ENDIAN,
  76. .phy_interface = PHY_INTERFACE_MODE_MII,
  77. };
  78. static struct platform_device espt_eth_device = {
  79. .name = "sh7763-gether",
  80. .resource = sh_eth_resources,
  81. .num_resources = ARRAY_SIZE(sh_eth_resources),
  82. .dev = {
  83. .platform_data = &sh7763_eth_pdata,
  84. },
  85. };
  86. static struct platform_device *espt_devices[] __initdata = {
  87. &espt_nor_flash_device,
  88. &espt_eth_device,
  89. };
  90. static int __init espt_devices_setup(void)
  91. {
  92. return platform_add_devices(espt_devices,
  93. ARRAY_SIZE(espt_devices));
  94. }
  95. device_initcall(espt_devices_setup);
  96. static struct sh_machine_vector mv_espt __initmv = {
  97. .mv_name = "ESPT-GIGA",
  98. };