bcsr.c 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2007 Freescale Semiconductor.
  4. */
  5. #include <common.h>
  6. #include <asm/io.h>
  7. #include "bcsr.h"
  8. void enable_8568mds_duart(void)
  9. {
  10. volatile uint* duart_mux = (uint *)(CONFIG_SYS_CCSRBAR + 0xe0060);
  11. volatile uint* devices = (uint *)(CONFIG_SYS_CCSRBAR + 0xe0070);
  12. volatile u8 *bcsr = (u8 *)(CONFIG_SYS_BCSR);
  13. *duart_mux = 0x80000000; /* Set the mux to Duart on PMUXCR */
  14. *devices = 0; /* Enable all peripheral devices */
  15. bcsr[5] |= 0x01; /* Enable Duart in BCSR*/
  16. }
  17. void enable_8568mds_flash_write(void)
  18. {
  19. volatile u8 *bcsr = (u8 *)(CONFIG_SYS_BCSR);
  20. bcsr[9] |= 0x01;
  21. }
  22. void disable_8568mds_flash_write(void)
  23. {
  24. volatile u8 *bcsr = (u8 *)(CONFIG_SYS_BCSR);
  25. bcsr[9] &= ~(0x01);
  26. }
  27. void enable_8568mds_qe_mdio(void)
  28. {
  29. u8 *bcsr = (u8 *)(CONFIG_SYS_BCSR);
  30. bcsr[7] |= 0x01;
  31. }
  32. #if defined(CONFIG_UEC_ETH1) || defined(CONFIG_UEC_ETH2)
  33. void reset_8568mds_uccs(void)
  34. {
  35. volatile u8 *bcsr = (u8 *)(CONFIG_SYS_BCSR);
  36. /* Turn off UCC1 & UCC2 */
  37. out_8(&bcsr[8], in_8(&bcsr[8]) & ~BCSR_UCC1_GETH_EN);
  38. out_8(&bcsr[9], in_8(&bcsr[9]) & ~BCSR_UCC2_GETH_EN);
  39. /* Mode is RGMII, all bits clear */
  40. out_8(&bcsr[11], in_8(&bcsr[11]) & ~(BCSR_UCC1_MODE_MSK |
  41. BCSR_UCC2_MODE_MSK));
  42. /* Turn UCC1 & UCC2 on */
  43. out_8(&bcsr[8], in_8(&bcsr[8]) | BCSR_UCC1_GETH_EN);
  44. out_8(&bcsr[9], in_8(&bcsr[9]) | BCSR_UCC2_GETH_EN);
  45. }
  46. #endif