sata.c 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * TI SATA platform driver
  3. *
  4. * (C) Copyright 2013
  5. * Texas Instruments, <www.ti.com>
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #include <common.h>
  10. #include <ahci.h>
  11. #include <scsi.h>
  12. #include <asm/arch/clock.h>
  13. #include <asm/arch/sata.h>
  14. #include <sata.h>
  15. #include <asm/io.h>
  16. #include "pipe3-phy.h"
  17. static struct pipe3_dpll_map dpll_map_sata[] = {
  18. {12000000, {1000, 7, 4, 6, 0} }, /* 12 MHz */
  19. {16800000, {714, 7, 4, 6, 0} }, /* 16.8 MHz */
  20. {19200000, {625, 7, 4, 6, 0} }, /* 19.2 MHz */
  21. {20000000, {600, 7, 4, 6, 0} }, /* 20 MHz */
  22. {26000000, {461, 7, 4, 6, 0} }, /* 26 MHz */
  23. {38400000, {312, 7, 4, 6, 0} }, /* 38.4 MHz */
  24. { }, /* Terminator */
  25. };
  26. struct omap_pipe3 sata_phy = {
  27. .pll_ctrl_base = (void __iomem *)TI_SATA_PLLCTRL_BASE,
  28. /* .power_reg is updated at runtime */
  29. .dpll_map = dpll_map_sata,
  30. };
  31. int init_sata(int dev)
  32. {
  33. int ret;
  34. u32 val;
  35. u32 const clk_domains_sata[] = {
  36. 0
  37. };
  38. u32 const clk_modules_hw_auto_sata[] = {
  39. (*prcm)->cm_l3init_ocp2scp3_clkctrl,
  40. 0
  41. };
  42. u32 const clk_modules_explicit_en_sata[] = {
  43. (*prcm)->cm_l3init_sata_clkctrl,
  44. 0
  45. };
  46. do_enable_clocks(clk_domains_sata,
  47. clk_modules_hw_auto_sata,
  48. clk_modules_explicit_en_sata,
  49. 0);
  50. /* Enable optional functional clock for SATA */
  51. setbits_le32((*prcm)->cm_l3init_sata_clkctrl,
  52. SATA_CLKCTRL_OPTFCLKEN_MASK);
  53. sata_phy.power_reg = (void __iomem *)(*ctrl)->control_phy_power_sata;
  54. /* Power up the PHY */
  55. phy_pipe3_power_on(&sata_phy);
  56. /* Enable SATA module, No Idle, No Standby */
  57. val = TI_SATA_IDLE_NO | TI_SATA_STANDBY_NO;
  58. writel(val, TI_SATA_WRAPPER_BASE + TI_SATA_SYSCONFIG);
  59. ret = ahci_init((void __iomem *)DWC_AHSATA_BASE);
  60. return ret;
  61. }
  62. int reset_sata(int dev)
  63. {
  64. return 0;
  65. }
  66. /* On OMAP platforms SATA provides the SCSI subsystem */
  67. void scsi_init(void)
  68. {
  69. init_sata(0);
  70. scsi_scan(1);
  71. }
  72. void scsi_bus_reset(void)
  73. {
  74. ahci_reset((void __iomem *)DWC_AHSATA_BASE);
  75. ahci_init((void __iomem *)DWC_AHSATA_BASE);
  76. }