sata.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2000-2005, DENX Software Engineering
  4. * Wolfgang Denk <wd@denx.de>
  5. * Copyright (C) Procsys. All rights reserved.
  6. * Mushtaq Khan <mushtaq_k@procsys.com>
  7. * <mushtaqk_921@yahoo.co.in>
  8. * Copyright (C) 2008 Freescale Semiconductor, Inc.
  9. * Dave Liu <daveliu@freescale.com>
  10. */
  11. #include <common.h>
  12. #include <ahci.h>
  13. #include <blk.h>
  14. #include <dm.h>
  15. #include <part.h>
  16. #include <sata.h>
  17. #ifndef CONFIG_AHCI
  18. struct blk_desc sata_dev_desc[CONFIG_SYS_SATA_MAX_DEVICE];
  19. #endif
  20. int sata_reset(struct udevice *dev)
  21. {
  22. struct ahci_ops *ops = ahci_get_ops(dev);
  23. if (!ops->reset)
  24. return -ENOSYS;
  25. return ops->reset(dev);
  26. }
  27. int sata_dm_port_status(struct udevice *dev, int port)
  28. {
  29. struct ahci_ops *ops = ahci_get_ops(dev);
  30. if (!ops->port_status)
  31. return -ENOSYS;
  32. return ops->port_status(dev, port);
  33. }
  34. int sata_scan(struct udevice *dev)
  35. {
  36. struct ahci_ops *ops = ahci_get_ops(dev);
  37. if (!ops->scan)
  38. return -ENOSYS;
  39. return ops->scan(dev);
  40. }
  41. #ifndef CONFIG_AHCI
  42. #ifdef CONFIG_PARTITIONS
  43. struct blk_desc *sata_get_dev(int dev)
  44. {
  45. return (dev < CONFIG_SYS_SATA_MAX_DEVICE) ? &sata_dev_desc[dev] : NULL;
  46. }
  47. #endif
  48. #endif
  49. static unsigned long sata_bread(struct udevice *dev, lbaint_t start,
  50. lbaint_t blkcnt, void *dst)
  51. {
  52. return -ENOSYS;
  53. }
  54. static unsigned long sata_bwrite(struct udevice *dev, lbaint_t start,
  55. lbaint_t blkcnt, const void *buffer)
  56. {
  57. return -ENOSYS;
  58. }
  59. #ifndef CONFIG_AHCI
  60. int __sata_initialize(void)
  61. {
  62. int rc, ret = -1;
  63. int i;
  64. for (i = 0; i < CONFIG_SYS_SATA_MAX_DEVICE; i++) {
  65. memset(&sata_dev_desc[i], 0, sizeof(struct blk_desc));
  66. sata_dev_desc[i].uclass_id = UCLASS_AHCI;
  67. sata_dev_desc[i].devnum = i;
  68. sata_dev_desc[i].part_type = PART_TYPE_UNKNOWN;
  69. sata_dev_desc[i].type = DEV_TYPE_HARDDISK;
  70. sata_dev_desc[i].lba = 0;
  71. sata_dev_desc[i].blksz = 512;
  72. sata_dev_desc[i].log2blksz = LOG2(sata_dev_desc[i].blksz);
  73. rc = init_sata(i);
  74. if (!rc) {
  75. rc = scan_sata(i);
  76. if (!rc && sata_dev_desc[i].lba > 0 &&
  77. sata_dev_desc[i].blksz > 0) {
  78. part_init(&sata_dev_desc[i]);
  79. ret = i;
  80. }
  81. }
  82. }
  83. return ret;
  84. }
  85. int sata_initialize(void) __attribute__((weak, alias("__sata_initialize")));
  86. __weak int __sata_stop(void)
  87. {
  88. int i, err = 0;
  89. for (i = 0; i < CONFIG_SYS_SATA_MAX_DEVICE; i++)
  90. err |= reset_sata(i);
  91. if (err)
  92. printf("Could not reset some SATA devices\n");
  93. return err;
  94. }
  95. int sata_stop(void) __attribute__((weak, alias("__sata_stop")));
  96. #endif
  97. static const struct blk_ops sata_blk_ops = {
  98. .read = sata_bread,
  99. .write = sata_bwrite,
  100. };
  101. U_BOOT_DRIVER(sata_blk) = {
  102. .name = "sata_blk",
  103. .id = UCLASS_BLK,
  104. .ops = &sata_blk_ops,
  105. };