adc.c 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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. float tempval = 0;
  39. for(int i = 0 ; i < 1; i++){
  40. tempval = (ADC1value[i] * (3.3 / 4095));
  41. tempval *= 1000;
  42. }
  43. printf("ADC1value[%d] : %f \r\n",0,tempval);
  44. // printf("ADC1value[%d] : %d \r\n",i,ADC1value[i] );
  45. #if 1 // PYJ.2020.08.26_BEGIN --
  46. Currstatus.DownLink_Forward_Det_H
  47. = (((uint16_t)tempval & 0xFF00) >> 8);
  48. Currstatus.DownLink_Forward_Det_L
  49. = (((uint16_t)tempval & 0x00FF) );
  50. printf("Currstatus.DownLink_Forward_Det : %d \r\n",Currstatus.DownLink_Forward_Det_H << 8 | Currstatus.DownLink_Forward_Det_L);
  51. #endif // PYJ.2020.08.26_END --
  52. adc1cnt = 0;
  53. }
  54. void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
  55. {
  56. if(hadc->Instance == hadc1.Instance)
  57. {
  58. // if(adc1cnt < ADC_AVERAGECNT){
  59. // for(int i = 0; i < ADC1_CNT; i++){
  60. // ADC1valuearray[i][adc1cnt] = ADC1value[i];
  61. // }
  62. // adc1cnt++;
  63. // }
  64. }
  65. }