mpc8308_p1m.c 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * Copyright (C) 2010 Freescale Semiconductor, Inc.
  3. * Copyright (C) 2010 Ilya Yanok, Emcraft Systems, yanok@emcraft.com
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <common.h>
  8. #include <i2c.h>
  9. #include <libfdt.h>
  10. #include <fdt_support.h>
  11. #include <pci.h>
  12. #include <mpc83xx.h>
  13. #include <netdev.h>
  14. #include <asm/io.h>
  15. #include <asm/fsl_serdes.h>
  16. #include <asm/fsl_mpc83xx_serdes.h>
  17. DECLARE_GLOBAL_DATA_PTR;
  18. int checkboard(void)
  19. {
  20. printf("Board: MPC8308 P1M\n");
  21. return 0;
  22. }
  23. static struct pci_region pcie_regions_0[] = {
  24. {
  25. .bus_start = CONFIG_SYS_PCIE1_MEM_BASE,
  26. .phys_start = CONFIG_SYS_PCIE1_MEM_PHYS,
  27. .size = CONFIG_SYS_PCIE1_MEM_SIZE,
  28. .flags = PCI_REGION_MEM,
  29. },
  30. {
  31. .bus_start = CONFIG_SYS_PCIE1_IO_BASE,
  32. .phys_start = CONFIG_SYS_PCIE1_IO_PHYS,
  33. .size = CONFIG_SYS_PCIE1_IO_SIZE,
  34. .flags = PCI_REGION_IO,
  35. },
  36. };
  37. void pci_init_board(void)
  38. {
  39. immap_t *immr = (immap_t *)CONFIG_SYS_IMMR;
  40. sysconf83xx_t *sysconf = &immr->sysconf;
  41. law83xx_t *pcie_law = sysconf->pcielaw;
  42. struct pci_region *pcie_reg[] = { pcie_regions_0 };
  43. fsl_setup_serdes(CONFIG_FSL_SERDES1, FSL_SERDES_PROTO_PEX,
  44. FSL_SERDES_CLK_100, FSL_SERDES_VDD_1V);
  45. /* Deassert the resets in the control register */
  46. out_be32(&sysconf->pecr1, 0xE0008000);
  47. udelay(2000);
  48. /* Configure PCI Express Local Access Windows */
  49. out_be32(&pcie_law[0].bar, CONFIG_SYS_PCIE1_BASE & LAWBAR_BAR);
  50. out_be32(&pcie_law[0].ar, LBLAWAR_EN | LBLAWAR_512MB);
  51. mpc83xx_pcie_init(1, pcie_reg);
  52. }
  53. #if defined(CONFIG_OF_BOARD_SETUP)
  54. int ft_board_setup(void *blob, bd_t *bd)
  55. {
  56. ft_cpu_setup(blob, bd);
  57. fsl_fdt_fixup_dr_usb(blob, bd);
  58. return 0;
  59. }
  60. #endif
  61. int board_eth_init(bd_t *bis)
  62. {
  63. int rv, num_if = 0;
  64. /* Initialize TSECs first */
  65. rv = cpu_eth_init(bis);
  66. if (rv >= 0)
  67. num_if += rv;
  68. else
  69. printf("ERROR: failed to initialize TSECs.\n");
  70. rv = pci_eth_init(bis);
  71. if (rv >= 0)
  72. num_if += rv;
  73. else
  74. printf("ERROR: failed to initialize PCI Ethernet.\n");
  75. return num_if;
  76. }