platform-imx2-wdt.c 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * Copyright (C) 2010 Pengutronix
  3. * Uwe Kleine-Koenig <u.kleine-koenig@pengutronix.de>
  4. *
  5. * This program is free software; you can redistribute it and/or modify it under
  6. * the terms of the GNU General Public License version 2 as published by the
  7. * Free Software Foundation.
  8. */
  9. #include <asm/sizes.h>
  10. #include <mach/hardware.h>
  11. #include <mach/devices-common.h>
  12. #define imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size) \
  13. { \
  14. .id = _id, \
  15. .iobase = soc ## _WDOG ## _hwid ## _BASE_ADDR, \
  16. .iosize = _size, \
  17. }
  18. #define imx_imx2_wdt_data_entry(soc, _id, _hwid, _size) \
  19. [_id] = imx_imx2_wdt_data_entry_single(soc, _id, _hwid, _size)
  20. #ifdef CONFIG_SOC_IMX21
  21. const struct imx_imx2_wdt_data imx21_imx2_wdt_data __initconst =
  22. imx_imx2_wdt_data_entry_single(MX21, 0, , SZ_4K);
  23. #endif /* ifdef CONFIG_SOC_IMX21 */
  24. #ifdef CONFIG_SOC_IMX25
  25. const struct imx_imx2_wdt_data imx25_imx2_wdt_data __initconst =
  26. imx_imx2_wdt_data_entry_single(MX25, 0, , SZ_16K);
  27. #endif /* ifdef CONFIG_SOC_IMX25 */
  28. #ifdef CONFIG_SOC_IMX27
  29. const struct imx_imx2_wdt_data imx27_imx2_wdt_data __initconst =
  30. imx_imx2_wdt_data_entry_single(MX27, 0, , SZ_4K);
  31. #endif /* ifdef CONFIG_SOC_IMX27 */
  32. #ifdef CONFIG_SOC_IMX31
  33. const struct imx_imx2_wdt_data imx31_imx2_wdt_data __initconst =
  34. imx_imx2_wdt_data_entry_single(MX31, 0, , SZ_16K);
  35. #endif /* ifdef CONFIG_SOC_IMX31 */
  36. #ifdef CONFIG_SOC_IMX35
  37. const struct imx_imx2_wdt_data imx35_imx2_wdt_data __initconst =
  38. imx_imx2_wdt_data_entry_single(MX35, 0, , SZ_16K);
  39. #endif /* ifdef CONFIG_SOC_IMX35 */
  40. #ifdef CONFIG_SOC_IMX51
  41. const struct imx_imx2_wdt_data imx51_imx2_wdt_data[] __initconst = {
  42. #define imx51_imx2_wdt_data_entry(_id, _hwid) \
  43. imx_imx2_wdt_data_entry(MX51, _id, _hwid, SZ_16K)
  44. imx51_imx2_wdt_data_entry(0, 1),
  45. imx51_imx2_wdt_data_entry(1, 2),
  46. };
  47. #endif /* ifdef CONFIG_SOC_IMX51 */
  48. #ifdef CONFIG_SOC_IMX53
  49. const struct imx_imx2_wdt_data imx53_imx2_wdt_data[] __initconst = {
  50. #define imx53_imx2_wdt_data_entry(_id, _hwid) \
  51. imx_imx2_wdt_data_entry(MX53, _id, _hwid, SZ_16K)
  52. imx53_imx2_wdt_data_entry(0, 1),
  53. imx53_imx2_wdt_data_entry(1, 2),
  54. };
  55. #endif /* ifdef CONFIG_SOC_IMX53 */
  56. struct platform_device *__init imx_add_imx2_wdt(
  57. const struct imx_imx2_wdt_data *data)
  58. {
  59. struct resource res[] = {
  60. {
  61. .start = data->iobase,
  62. .end = data->iobase + data->iosize - 1,
  63. .flags = IORESOURCE_MEM,
  64. },
  65. };
  66. return imx_add_platform_device("imx2-wdt", data->id,
  67. res, ARRAY_SIZE(res), NULL, 0);
  68. }