AT24CXX.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. #include "i2c.h"
  2. #include "AT24CXX.h"
  3. #include "clock.h"
  4. void AT24CXX_Init(void)
  5. {
  6. gd32_i2c_init(0, 100*1000);//here, need 120K min speed, may be the GD lib is something wrong!!!!
  7. }
  8. void AT24CXX_DeInit(void){
  9. gd32_i2c_deinit(0);
  10. }
  11. uint8_t AT24CXX_ReadOneByte(uint16_t ReadAddr)
  12. {
  13. uint8_t value = 0;
  14. uint8_t device_addr = 0xA0 | ((ReadAddr >>8) << 1);
  15. int try_count = 100;
  16. while(0 >= gd32_i2c_read_byte(0, device_addr, (uint8_t)(ReadAddr&0xFF), (uint8_t *)&value)){
  17. if (try_count-- <= 0){
  18. break;
  19. }
  20. };
  21. return value;
  22. }
  23. void AT24CXX_WriteOneByte(uint16_t WriteAddr,uint8_t DataToWrite)
  24. {
  25. uint8_t device_addr = 0xA0 | ((WriteAddr >>8) << 1);
  26. int try_count = 100;
  27. while(0 >= gd32_i2c_write_byte(0, device_addr, (uint8_t)(WriteAddr & 0xFF), (uint8_t)DataToWrite)){
  28. if (try_count-- <= 0){
  29. break;
  30. }
  31. };
  32. }
  33. int AT24CXX_Read(uint16_t ReadAddr,uint8_t *pBuffer,uint16_t NumToRead)
  34. {
  35. uint8_t device_addr = 0xA0 | ((ReadAddr >>8) << 1);
  36. int try_count = 100;
  37. while(0 >= gd32_i2c_read_nbytes(0, device_addr, (uint8_t)(ReadAddr&0xFF), pBuffer, NumToRead)){
  38. if (try_count-- <= 0){
  39. return -1;
  40. }
  41. if ((try_count % 20) == 0) {
  42. AT24CXX_DeInit();
  43. task_udelay(1000);
  44. AT24CXX_Init();
  45. }
  46. };
  47. return NumToRead;
  48. }
  49. /* use page write to improve write time */
  50. static int AT24CXX_Write_Pages(uint16_t WriteAddr,uint8_t *pBuffer,uint16_t NumToWrite){
  51. uint8_t device_addr = 0xA0 | ((WriteAddr >>8) << 1);
  52. int try_count = 100;
  53. while(0 >= gd32_i2c_write_nbytes(0, device_addr, (uint8_t)(WriteAddr&0xFF), pBuffer, NumToWrite)){
  54. if (try_count-- <= 0){
  55. return -1;
  56. }
  57. if ((try_count % 20) == 0) {
  58. AT24CXX_DeInit();
  59. task_udelay(1000);
  60. AT24CXX_Init();
  61. }
  62. };
  63. return 0;
  64. }
  65. int AT24CXX_Write(uint16_t WriteAddr,uint8_t *pBuffer,uint16_t NumToWrite){
  66. uint16_t remain_len = NumToWrite;
  67. while(remain_len > 0){
  68. uint16_t w_len = (remain_len > PAGE_SIZE)?PAGE_SIZE:remain_len;
  69. if (AT24CXX_Write_Pages(WriteAddr, pBuffer, w_len) < 0){
  70. return -1;
  71. }
  72. WriteAddr += w_len;
  73. pBuffer += w_len;
  74. remain_len -= w_len;
  75. }
  76. return NumToWrite;
  77. }
  78. #if 0
  79. #define ADDR_START (0)
  80. static uint8_t buffr[128];
  81. static int index = 0;
  82. static int _AT24CXX_test(void)
  83. {
  84. int i=0;
  85. char wdata = 0x5A;
  86. if (index % 2 == 1){
  87. wdata = 0xA5;
  88. }
  89. for(i=0;i<128;i++)
  90. {
  91. buffr[i] = wdata;
  92. }
  93. AT24CXX_Write(ADDR_START,buffr,128);
  94. memset(buffr,0,128);
  95. AT24CXX_Read(ADDR_START,buffr,128);
  96. for(i=0;i<128;i++)
  97. {
  98. if (buffr[i] != wdata){
  99. return -1;
  100. }
  101. }
  102. return 0;
  103. }
  104. void AT24CXX_test(void){
  105. while(_AT24CXX_test() == 0){
  106. index++;
  107. };
  108. }
  109. #endif