mach-imx6sl.c 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * Copyright 2013 Freescale Semiconductor, Inc.
  3. *
  4. * This program is free software; you can redistribute it and/or modify
  5. * it under the terms of the GNU General Public License version 2 as
  6. * published by the Free Software Foundation.
  7. *
  8. */
  9. #include <linux/irqchip.h>
  10. #include <linux/of.h>
  11. #include <linux/of_platform.h>
  12. #include <linux/mfd/syscon.h>
  13. #include <linux/mfd/syscon/imx6q-iomuxc-gpr.h>
  14. #include <linux/regmap.h>
  15. #include <asm/mach/arch.h>
  16. #include <asm/mach/map.h>
  17. #include "common.h"
  18. static void __init imx6sl_fec_init(void)
  19. {
  20. struct regmap *gpr;
  21. /* set FEC clock from internal PLL clock source */
  22. gpr = syscon_regmap_lookup_by_compatible("fsl,imx6sl-iomuxc-gpr");
  23. if (!IS_ERR(gpr)) {
  24. regmap_update_bits(gpr, IOMUXC_GPR1,
  25. IMX6SL_GPR1_FEC_CLOCK_MUX2_SEL_MASK, 0);
  26. regmap_update_bits(gpr, IOMUXC_GPR1,
  27. IMX6SL_GPR1_FEC_CLOCK_MUX1_SEL_MASK, 0);
  28. } else {
  29. pr_err("failed to find fsl,imx6sl-iomux-gpr regmap\n");
  30. }
  31. }
  32. static void __init imx6sl_init_machine(void)
  33. {
  34. mxc_arch_reset_init_dt();
  35. of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL);
  36. imx6sl_fec_init();
  37. }
  38. static void __init imx6sl_init_irq(void)
  39. {
  40. imx_init_l2cache();
  41. imx_src_init();
  42. imx_gpc_init();
  43. irqchip_init();
  44. }
  45. static const char *imx6sl_dt_compat[] __initdata = {
  46. "fsl,imx6sl",
  47. NULL,
  48. };
  49. DT_MACHINE_START(IMX6SL, "Freescale i.MX6 SoloLite (Device Tree)")
  50. .map_io = debug_ll_io_init,
  51. .init_irq = imx6sl_init_irq,
  52. .init_machine = imx6sl_init_machine,
  53. .dt_compat = imx6sl_dt_compat,
  54. .restart = mxc_restart,
  55. MACHINE_END