mtd_nor.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. /*
  2. * COPYRIGHT (C) 2011-2023, Real-Thread Information Technology Ltd
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2012-5-30 Bernard the first version
  9. */
  10. #include <rtdevice.h>
  11. #ifdef RT_USING_MTD_NOR
  12. /**
  13. * RT-Thread Generic Device Interface
  14. */
  15. static rt_err_t _mtd_init(rt_device_t dev)
  16. {
  17. return RT_EOK;
  18. }
  19. static rt_err_t _mtd_open(rt_device_t dev, rt_uint16_t oflag)
  20. {
  21. return RT_EOK;
  22. }
  23. static rt_err_t _mtd_close(rt_device_t dev)
  24. {
  25. return RT_EOK;
  26. }
  27. static rt_ssize_t _mtd_read(rt_device_t dev,
  28. rt_off_t pos,
  29. void *buffer,
  30. rt_size_t size)
  31. {
  32. return size;
  33. }
  34. static rt_ssize_t _mtd_write(rt_device_t dev,
  35. rt_off_t pos,
  36. const void *buffer,
  37. rt_size_t size)
  38. {
  39. return size;
  40. }
  41. static rt_err_t _mtd_control(rt_device_t dev, int cmd, void *args)
  42. {
  43. return RT_EOK;
  44. }
  45. #ifdef RT_USING_DEVICE_OPS
  46. const static struct rt_device_ops mtd_nor_ops =
  47. {
  48. _mtd_init,
  49. _mtd_open,
  50. _mtd_close,
  51. _mtd_read,
  52. _mtd_write,
  53. _mtd_control
  54. };
  55. #endif
  56. rt_err_t rt_mtd_nor_register_device(const char *name,
  57. struct rt_mtd_nor_device *device)
  58. {
  59. rt_device_t dev;
  60. dev = RT_DEVICE(device);
  61. RT_ASSERT(dev != RT_NULL);
  62. /* set device class and generic device interface */
  63. dev->type = RT_Device_Class_MTD;
  64. #ifdef RT_USING_DEVICE_OPS
  65. dev->ops = &mtd_nor_ops;
  66. #else
  67. dev->init = _mtd_init;
  68. dev->open = _mtd_open;
  69. dev->read = _mtd_read;
  70. dev->write = _mtd_write;
  71. dev->close = _mtd_close;
  72. dev->control = _mtd_control;
  73. #endif
  74. dev->rx_indicate = RT_NULL;
  75. dev->tx_complete = RT_NULL;
  76. /* register to RT-Thread device system */
  77. return rt_device_register(dev, name, RT_DEVICE_FLAG_RDWR | RT_DEVICE_FLAG_STANDALONE);
  78. }
  79. rt_uint32_t rt_mtd_nor_read_id(struct rt_mtd_nor_device* device)
  80. {
  81. return device->ops->read_id(device);
  82. }
  83. rt_ssize_t rt_mtd_nor_read(struct rt_mtd_nor_device* device,
  84. rt_off_t offset, rt_uint8_t* data, rt_size_t length)
  85. {
  86. return device->ops->read(device, offset, data, length);
  87. }
  88. rt_ssize_t rt_mtd_nor_write(struct rt_mtd_nor_device* device,
  89. rt_off_t offset, const rt_uint8_t* data, rt_size_t length)
  90. {
  91. return device->ops->write(device, offset, data, length);
  92. }
  93. rt_err_t rt_mtd_nor_erase_block(struct rt_mtd_nor_device* device,
  94. rt_off_t offset, rt_size_t length)
  95. {
  96. return device->ops->erase_block(device, offset, length);
  97. }
  98. #endif