config.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /***************************************************************************/
  2. /*
  3. * linux/arch/m68knommu/platform/520x/config.c
  4. *
  5. * Copyright (C) 2005, Freescale (www.freescale.com)
  6. * Copyright (C) 2005, Intec Automation (mike@steroidmicros.com)
  7. * Copyright (C) 1999-2007, Greg Ungerer (gerg@snapgear.com)
  8. * Copyright (C) 2001-2003, SnapGear Inc. (www.snapgear.com)
  9. */
  10. /***************************************************************************/
  11. #include <linux/kernel.h>
  12. #include <linux/param.h>
  13. #include <linux/init.h>
  14. #include <linux/io.h>
  15. #include <asm/machdep.h>
  16. #include <asm/coldfire.h>
  17. #include <asm/mcfsim.h>
  18. #include <asm/mcfuart.h>
  19. /***************************************************************************/
  20. #ifdef CONFIG_SPI_COLDFIRE_QSPI
  21. static void __init m520x_qspi_init(void)
  22. {
  23. u16 par;
  24. /* setup Port QS for QSPI with gpio CS control */
  25. writeb(0x3f, MCF_GPIO_PAR_QSPI);
  26. /* make U1CTS and U2RTS gpio for cs_control */
  27. par = readw(MCF_GPIO_PAR_UART);
  28. par &= 0x00ff;
  29. writew(par, MCF_GPIO_PAR_UART);
  30. }
  31. #endif /* CONFIG_SPI_COLDFIRE_QSPI */
  32. /***************************************************************************/
  33. static void __init m520x_uarts_init(void)
  34. {
  35. u16 par;
  36. u8 par2;
  37. /* UART0 and UART1 GPIO pin setup */
  38. par = readw(MCF_GPIO_PAR_UART);
  39. par |= MCF_GPIO_PAR_UART_PAR_UTXD0 | MCF_GPIO_PAR_UART_PAR_URXD0;
  40. par |= MCF_GPIO_PAR_UART_PAR_UTXD1 | MCF_GPIO_PAR_UART_PAR_URXD1;
  41. writew(par, MCF_GPIO_PAR_UART);
  42. /* UART1 GPIO pin setup */
  43. par2 = readb(MCF_GPIO_PAR_FECI2C);
  44. par2 &= ~0x0F;
  45. par2 |= MCF_GPIO_PAR_FECI2C_PAR_SCL_UTXD2 |
  46. MCF_GPIO_PAR_FECI2C_PAR_SDA_URXD2;
  47. writeb(par2, MCF_GPIO_PAR_FECI2C);
  48. }
  49. /***************************************************************************/
  50. static void __init m520x_fec_init(void)
  51. {
  52. u8 v;
  53. /* Set multi-function pins to ethernet mode */
  54. v = readb(MCF_GPIO_PAR_FEC);
  55. writeb(v | 0xf0, MCF_GPIO_PAR_FEC);
  56. v = readb(MCF_GPIO_PAR_FECI2C);
  57. writeb(v | 0x0f, MCF_GPIO_PAR_FECI2C);
  58. }
  59. /***************************************************************************/
  60. void __init config_BSP(char *commandp, int size)
  61. {
  62. mach_sched_init = hw_timer_init;
  63. m520x_uarts_init();
  64. m520x_fec_init();
  65. #ifdef CONFIG_SPI_COLDFIRE_QSPI
  66. m520x_qspi_init();
  67. #endif
  68. }
  69. /***************************************************************************/