adc.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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)) * 100;
  41. printf("ADC1value[%d] : %f \r\n",i,tempval);
  42. }
  43. // Currstatus.DownLink_Forward_Det_H
  44. // = ((ADC1value[0] & 0xFF00) >> 8);
  45. // Currstatus.DownLink_Forward_Det_L
  46. // = ((ADC1value[0] & 0x00FF) );
  47. //
  48. // Currstatus.DownLink_Reverse_Det_H
  49. // = ((ADC1value[0] & 0xFF00) >> 8);
  50. // Currstatus.DownLink_Reverse_Det_L
  51. // = ((ADC1value[0] & 0x00FF) );
  52. //
  53. // Currstatus.DC_Level_Det_H
  54. // = ((ADC1value[0] & 0xFF00) >> 8);
  55. // Currstatus.DC_Level_Det_L
  56. // = ((ADC1value[0] & 0x00FF) );
  57. //
  58. // Currstatus.Temp_Monitor
  59. // = ((ADC1value[0] & 0xFF00) >> 8);
  60. // Currstatus.Temp_Monitor
  61. // = ((ADC1value[0] & 0x00FF) );
  62. adc1cnt = 0;
  63. }
  64. void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
  65. {
  66. if(hadc->Instance == hadc1.Instance)
  67. {
  68. // if(adc1cnt < ADC_AVERAGECNT){
  69. // for(int i = 0; i < ADC1_CNT; i++){
  70. // ADC1valuearray[i][adc1cnt] = ADC1value[i];
  71. // }
  72. // adc1cnt++;
  73. // }
  74. }
  75. }