sata.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  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;
  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. }
  69. }
  70. return rc;
  71. }
  72. int sata_initialize(void) __attribute__((weak, alias("__sata_initialize")));
  73. __weak int __sata_stop(void)
  74. {
  75. int i, err = 0;
  76. for (i = 0; i < CONFIG_SYS_SATA_MAX_DEVICE; i++)
  77. err |= reset_sata(i);
  78. if (err)
  79. printf("Could not reset some SATA devices\n");
  80. return err;
  81. }
  82. int sata_stop(void) __attribute__((weak, alias("__sata_stop")));
  83. #ifdef CONFIG_BLK
  84. static const struct blk_ops sata_blk_ops = {
  85. .read = sata_bread,
  86. .write = sata_bwrite,
  87. };
  88. U_BOOT_DRIVER(sata_blk) = {
  89. .name = "sata_blk",
  90. .id = UCLASS_BLK,
  91. .ops = &sata_blk_ops,
  92. };
  93. #else
  94. U_BOOT_LEGACY_BLK(sata) = {
  95. .if_typename = "sata",
  96. .if_type = IF_TYPE_SATA,
  97. .max_devs = CONFIG_SYS_SATA_MAX_DEVICE,
  98. .desc = sata_dev_desc,
  99. };
  100. #endif