mpc8308_p1m.c 1.9 KB

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