sata.c 2.7 KB

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