adc(7790).c 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * adc.c
  3. *
  4. * Created on: 2020. 8. 3.
  5. * Author: parkyj
  6. */
  7. #include "main.h"
  8. #include "adc.h"
  9. #include "NessLab.h"
  10. extern ADC_HandleTypeDef hadc1;
  11. extern DMA_HandleTypeDef hdma_adc1;
  12. extern Nesslab_Prot Currstatus;
  13. //volatile uint16_t ADC1valuearray[ADC1_CNT][ADC_AVERAGECNT];
  14. volatile uint16_t ADC1value[ADC1_CNT];
  15. uint16_t adc1cnt = 0 ;
  16. /*
  17. *
  18. * ADC 0 :DL TX
  19. * ADC 1 :DL RX
  20. * ADC 2 :TEMP
  21. * */
  22. void ADC_Value_Get(){
  23. uint16_t CalcRet = 0 ;
  24. /*DL TX Calc*/
  25. Currstatus.DownLink_Forward_Det_H = ((ADC1value[0] & 0xFF00) >> 8);
  26. Currstatus.DownLink_Forward_Det_L = (ADC1value[0] & 0x00FF);
  27. /*DL RX Calc*/
  28. Currstatus.DownLink_Reverse_Det_H = ((ADC1value[1] & 0xFF00) >> 8);
  29. Currstatus.DownLink_Reverse_Det_L = (ADC1value[1] & 0x00FF);
  30. /*Temp Calc*/
  31. Currstatus.Temp_Monitor = ((ADC1value[1] & 0xFF00) >> 8);
  32. }
  33. void ADC_Initialize(){
  34. while(!(HAL_ADCEx_Calibration_Start(&hadc1)==HAL_OK));
  35. HAL_ADC_Start_DMA(&hadc1, (uint16_t*)ADC1value,(uint32_t) 3);
  36. }
  37. void ADC_Check(){
  38. double tempval = 0;
  39. for(int i = 0 ; i < ADC1_CNT; i++){
  40. tempval = (ADC1value[i] * (3.3 / 4095));
  41. printf("ADC1value[%d] : %f \r\n",i,tempval);
  42. // printf("ADC1value[%d] : %d \r\n",i,ADC1value[i] );
  43. }
  44. // Currstatus.DownLink_Forward_Det_H
  45. // = ((ADC1value[0] & 0xFF00) >> 8);
  46. // Currstatus.DownLink_Forward_Det_L
  47. // = ((ADC1value[0] & 0x00FF) );
  48. //
  49. // Currstatus.DownLink_Reverse_Det_H
  50. // = ((ADC1value[0] & 0xFF00) >> 8);
  51. // Currstatus.DownLink_Reverse_Det_L
  52. // = ((ADC1value[0] & 0x00FF) );
  53. //
  54. // Currstatus.DC_Level_Det_H
  55. // = ((ADC1value[0] & 0xFF00) >> 8);
  56. // Currstatus.DC_Level_Det_L
  57. // = ((ADC1value[0] & 0x00FF) );
  58. //
  59. // Currstatus.Temp_Monitor
  60. // = ((ADC1value[0] & 0xFF00) >> 8);
  61. // Currstatus.Temp_Monitor
  62. // = ((ADC1value[0] & 0x00FF) );
  63. adc1cnt = 0;
  64. }
  65. void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
  66. {
  67. if(hadc->Instance == hadc1.Instance)
  68. {
  69. // if(adc1cnt < ADC_AVERAGECNT){
  70. // for(int i = 0; i < ADC1_CNT; i++){
  71. // ADC1valuearray[i][adc1cnt] = ADC1value[i];
  72. // }
  73. // adc1cnt++;
  74. // }
  75. }
  76. }