main_target.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #include "src/battery_data/battery.h"
  2. #include "ti_msp_dl_config.h"
  3. //#include "ti/driverlib/dl_i2c.h"
  4. #include <stdio.h>
  5. #include "src/i2c_comm/mcu_slave_interface.h"
  6. #include "src/interfaces/i2c_controller_interface.h"
  7. #define DELAY_CYCLE (50000000)
  8. volatile bool mcu_CommandPending= false;
  9. /*
  10. Scans all the addresses of the peripherals:
  11. */
  12. /*void I2C_scanBus(I2C_Regs *i2c) {
  13. printf("1");
  14. // **Step 1: Reset I2C Controller if Busy**
  15. if (DL_I2C_getControllerStatus(i2c) & DL_I2C_CONTROLLER_STATUS_BUSY_BUS) {
  16. printf("I2C Bus Busy! Resetting I2C Controller...\n");
  17. DL_I2C_disableController(i2c); // Disable I2C
  18. delay_cycles(20000);
  19. DL_I2C_enableController(i2c); // Re-enable I2C
  20. delay_cycles(20000);
  21. }
  22. uint32_t i2c_status;
  23. // **Step 2: Scan I2C Bus**
  24. for (uint8_t addr = 0x08; addr < 0x78; addr++) { // Valid I2C Address Range
  25. printf("Scanning 0x%02X\n", addr);
  26. DL_I2C_startControllerTransfer(i2c, addr, DL_I2C_CONTROLLER_DIRECTION_RX, 1);
  27. delay_cycles(5000);
  28. if (addr != 0x60 && addr != 0x68) {
  29. continue;
  30. }
  31. i2c_status = DL_I2C_getControllerStatus(i2c);
  32. printf("DL_I2C_getControllerStatus(i2c): %d\n", i2c_status);
  33. printf("busy?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_BUSY));
  34. printf("error?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_ERROR));
  35. printf("addr_ack?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_ADDR_ACK));
  36. printf("data_ack?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_DATA_ACK));
  37. printf("arb_lost?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_ARBITRATION_LOST));
  38. printf("idle?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_IDLE));
  39. printf("busy_bus?: %d\n", (i2c_status & DL_I2C_CONTROLLER_STATUS_BUSY_BUS));
  40. if (!(DL_I2C_getControllerStatus(i2c) & DL_I2C_CONTROLLER_STATUS_ERROR)) {
  41. printf("Device found at: 0x%02X\n", addr);
  42. DL_I2C_disableController(i2c);
  43. DL_I2C_enableController(i2c);
  44. }else {
  45. // Clear the error by resetting the I2C controller
  46. printf("Device not found...\n");
  47. DL_I2C_disableController(i2c);
  48. DL_I2C_enableController(i2c);
  49. }
  50. }
  51. //printf("I2C Scan Complete!\n");
  52. }
  53. */
  54. void I2C_controller_INST_IRQHandler(void) {
  55. // printf("I2C Interrupt Triggered to ADC!\n");
  56. switch (DL_I2C_getPendingInterrupt(I2C_controller_INST)) {
  57. case DL_I2C_IIDX_CONTROLLER_START:
  58. controllerRxPackage.count = 0;
  59. DL_I2C_flushControllerTXFIFO(I2C_controller_INST);
  60. break;
  61. case DL_I2C_IIDX_CONTROLLER_RXFIFO_TRIGGER:
  62. /* Store bytes received from target in Rx Msg Buffer */
  63. while (DL_I2C_isControllerRXFIFOEmpty(I2C_controller_INST) != true) {
  64. if (controllerRxPackage.count < controllerRxPackage.len) {
  65. controllerRxPackage.packet[controllerRxPackage.count] =
  66. DL_I2C_receiveControllerData(I2C_controller_INST);
  67. ;
  68. controllerRxPackage.count++;
  69. } else {
  70. /* Ignore and remove from FIFO if the buffer is full */
  71. DL_I2C_receiveControllerData(I2C_controller_INST);
  72. }
  73. }
  74. if (controllerRxPackage.count >= controllerRxPackage.len) {
  75. controllerRxPackage.complete = true;
  76. DL_I2C_enableInterrupt(I2C_controller_INST,
  77. DL_I2C_INTERRUPT_CONTROLLER_STOP);
  78. }
  79. break;
  80. /*TRANSMIT data to ADC*/
  81. case DL_I2C_IIDX_CONTROLLER_TXFIFO_TRIGGER:
  82. if (controllerTxPackage.count < controllerTxPackage.len) {
  83. DL_I2C_fillControllerTXFIFO(I2C_controller_INST,
  84. &controllerTxPackage.packet[controllerTxPackage.count],
  85. (controllerTxPackage.len - controllerTxPackage.count));
  86. controllerTxPackage.count++;
  87. } else {
  88. /*Prevent overflow and just ignore data*/
  89. DL_I2C_fillTargetTXFIFO(I2C_controller_INST, (uint8_t[]){0x00}, 1);
  90. controllerTxPackage.complete = true;
  91. }
  92. if(controllerTxPackage.count >= controllerTxPackage.len){
  93. controllerTxPackage.complete= true;
  94. }
  95. break;
  96. /*STOP condition*/
  97. case DL_I2C_IIDX_CONTROLLER_STOP:
  98. controllerTxPackage.complete = true;
  99. controllerRxPackage.complete = true;
  100. break;
  101. case DL_I2C_IIDX_CONTROLLER_ARBITRATION_LOST:
  102. break;
  103. case DL_I2C_IIDX_CONTROLLER_NACK:
  104. break;
  105. default:
  106. break;
  107. }
  108. }
  109. /**** Interrupt for Pi to MCU ****/
  110. void I2C_target_INST_IRQHandler(void) {
  111. uint32_t status = DL_I2C_getPendingInterrupt(I2C_target_INST);
  112. switch (status) {
  113. case DL_I2C_IIDX_TARGET_START:
  114. DL_I2C_flushTargetTXFIFO(I2C_target_INST);
  115. break;
  116. case DL_I2C_IIDX_TARGET_STOP:
  117. mcu_CommandPending= true;
  118. DL_I2C_flushTargetTXFIFO(I2C_target_INST);
  119. DL_I2C_flushTargetRXFIFO(I2C_target_INST);
  120. break;
  121. case DL_I2C_IIDX_TARGET_RXFIFO_TRIGGER:
  122. if (DL_I2C_isTargetRXFIFOEmpty(I2C_target_INST)) {
  123. return;
  124. }
  125. mcu_CommandPending= true;
  126. break;
  127. case DL_I2C_IIDX_TARGET_TXFIFO_TRIGGER:
  128. mcu_CommandPending= true;
  129. break;
  130. case DL_I2C_IIDX_TARGET_ARBITRATION_LOST:
  131. break;
  132. default:
  133. break;
  134. }
  135. }
  136. int main(void)
  137. {
  138. SYSCFG_DL_init();
  139. battery_slotmgr.init();
  140. //I2C_scanBus(I2C_controller_INST);
  141. NVIC_EnableIRQ(I2C_controller_INST_INT_IRQN);
  142. NVIC_EnableIRQ(I2C_target_INST_INT_IRQN);
  143. while (1) {
  144. if(mcu_CommandPending){
  145. printf("Step 1: Calling MCU target interrupt\n");
  146. mcu_i2c_handle(I2C_target_INST);
  147. mcu_CommandPending= false;
  148. }
  149. for(uint8_t slot= 0; slot< NUM_SLOTS; slot++){
  150. // step 1: update the voltage readings
  151. battery_slotmgr.read_state(slot);
  152. // step 2: control loop to adjust the dac / adc values
  153. battery_slotmgr.adjust_current(slot);
  154. }
  155. delay_cycles(DELAY_CYCLE);
  156. }
  157. }