sata.c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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 <sata.h>
  14. struct blk_desc sata_dev_desc[CONFIG_SYS_SATA_MAX_DEVICE];
  15. #ifdef CONFIG_PARTITIONS
  16. struct blk_desc *sata_get_dev(int dev)
  17. {
  18. return (dev < CONFIG_SYS_SATA_MAX_DEVICE) ? &sata_dev_desc[dev] : NULL;
  19. }
  20. #endif
  21. static unsigned long sata_bread(struct blk_desc *block_dev, lbaint_t start,
  22. lbaint_t blkcnt, void *dst)
  23. {
  24. return sata_read(block_dev->devnum, start, blkcnt, dst);
  25. }
  26. static unsigned long sata_bwrite(struct blk_desc *block_dev, lbaint_t start,
  27. lbaint_t blkcnt, const void *buffer)
  28. {
  29. return sata_write(block_dev->devnum, start, blkcnt, buffer);
  30. }
  31. int __sata_initialize(void)
  32. {
  33. int rc;
  34. int i;
  35. for (i = 0; i < CONFIG_SYS_SATA_MAX_DEVICE; i++) {
  36. memset(&sata_dev_desc[i], 0, sizeof(struct blk_desc));
  37. sata_dev_desc[i].if_type = IF_TYPE_SATA;
  38. sata_dev_desc[i].devnum = i;
  39. sata_dev_desc[i].part_type = PART_TYPE_UNKNOWN;
  40. sata_dev_desc[i].type = DEV_TYPE_HARDDISK;
  41. sata_dev_desc[i].lba = 0;
  42. sata_dev_desc[i].blksz = 512;
  43. sata_dev_desc[i].log2blksz = LOG2(sata_dev_desc[i].blksz);
  44. sata_dev_desc[i].block_read = sata_bread;
  45. sata_dev_desc[i].block_write = sata_bwrite;
  46. rc = init_sata(i);
  47. if (!rc) {
  48. rc = scan_sata(i);
  49. if (!rc && sata_dev_desc[i].lba > 0 &&
  50. sata_dev_desc[i].blksz > 0)
  51. part_init(&sata_dev_desc[i]);
  52. }
  53. }
  54. return rc;
  55. }
  56. int sata_initialize(void) __attribute__((weak, alias("__sata_initialize")));
  57. __weak int __sata_stop(void)
  58. {
  59. int i, err = 0;
  60. for (i = 0; i < CONFIG_SYS_SATA_MAX_DEVICE; i++)
  61. err |= reset_sata(i);
  62. if (err)
  63. printf("Could not reset some SATA devices\n");
  64. return err;
  65. }
  66. int sata_stop(void) __attribute__((weak, alias("__sata_stop")));
  67. U_BOOT_LEGACY_BLK(sata) = {
  68. .if_typename = "sata",
  69. .if_type = IF_TYPE_SATA,
  70. .max_devs = CONFIG_SYS_SATA_MAX_DEVICE,
  71. .desc = sata_dev_desc,
  72. };