avengers_lite.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * linux/arch/arm/mach-mmp/avengers_lite.c
  4. *
  5. * Support for the Marvell PXA168-based Avengers lite Development Platform.
  6. *
  7. * Copyright (C) 2009-2010 Marvell International Ltd.
  8. */
  9. #include <linux/init.h>
  10. #include <linux/kernel.h>
  11. #include <linux/gpio-pxa.h>
  12. #include <linux/platform_device.h>
  13. #include <asm/mach-types.h>
  14. #include <asm/mach/arch.h>
  15. #include "addr-map.h"
  16. #include "mfp-pxa168.h"
  17. #include "pxa168.h"
  18. #include "irqs.h"
  19. #include "common.h"
  20. #include <linux/delay.h>
  21. /* Avengers lite MFP configurations */
  22. static unsigned long avengers_lite_pin_config_V16F[] __initdata = {
  23. /* DEBUG_UART */
  24. GPIO88_UART2_TXD,
  25. GPIO89_UART2_RXD,
  26. };
  27. static struct pxa_gpio_platform_data pxa168_gpio_pdata = {
  28. .irq_base = MMP_GPIO_TO_IRQ(0),
  29. };
  30. static void __init avengers_lite_init(void)
  31. {
  32. mfp_config(ARRAY_AND_SIZE(avengers_lite_pin_config_V16F));
  33. /* on-chip devices */
  34. pxa168_add_uart(2);
  35. platform_device_add_data(&pxa168_device_gpio, &pxa168_gpio_pdata,
  36. sizeof(struct pxa_gpio_platform_data));
  37. platform_device_register(&pxa168_device_gpio);
  38. }
  39. MACHINE_START(AVENGERS_LITE, "PXA168 Avengers lite Development Platform")
  40. .map_io = mmp_map_io,
  41. .nr_irqs = MMP_NR_IRQS,
  42. .init_irq = pxa168_init_irq,
  43. .init_time = pxa168_timer_init,
  44. .init_machine = avengers_lite_init,
  45. .restart = pxa168_restart,
  46. MACHINE_END