mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
148 lines
3.7 KiB
C
148 lines
3.7 KiB
C
#include <stdint.h>
|
|
#include "BaseObj.h"
|
|
#include "STM32F1_common.h"
|
|
#include "dataStrs.h"
|
|
|
|
ADC_HandleTypeDef pika_hadc1 = {0};
|
|
|
|
uint16_t Get_Adc(ADC_HandleTypeDef* hadc, uint32_t ch) {
|
|
ADC_ChannelConfTypeDef ADC_ChanConf;
|
|
ADC_ChanConf.Channel = ch;
|
|
ADC_ChanConf.Rank = ADC_REGULAR_RANK_1;
|
|
#ifdef STM32F103xB
|
|
ADC_ChanConf.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
|
|
#endif
|
|
HAL_ADC_ConfigChannel(hadc, &ADC_ChanConf);
|
|
HAL_ADC_Start(hadc);
|
|
HAL_ADC_PollForConversion(hadc, 10);
|
|
return (uint16_t)HAL_ADC_GetValue(hadc);
|
|
}
|
|
|
|
void STM32F1_ADC_platformEnable(PikaObj* self) {
|
|
char *pin = obj_getStr(self, "pin");
|
|
if (!strIsStartWith(pin, "PA")) {
|
|
obj_setErrorCode(self, 1);
|
|
obj_setSysOut(self, "[error] not match adc pin.");
|
|
return;
|
|
}
|
|
|
|
/* MSP Init */
|
|
|
|
#ifdef STM32F103xB
|
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
|
#endif
|
|
if (0 != enableClk(pin)) {
|
|
obj_setErrorCode(self, 1);
|
|
obj_setSysOut(self, "[error] not match gpio port.");
|
|
return;
|
|
}
|
|
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
GPIO_InitStruct.Pin = getGpioPin(pin);
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
HAL_GPIO_Init(getGpioPort(pin), &GPIO_InitStruct);
|
|
|
|
/* init ADC */
|
|
pika_hadc1.Instance = ADC1;
|
|
pika_hadc1.Init.ScanConvMode = ADC_SCAN_DISABLE;
|
|
pika_hadc1.Init.ContinuousConvMode = DISABLE;
|
|
pika_hadc1.Init.DiscontinuousConvMode = DISABLE;
|
|
pika_hadc1.Init.ExternalTrigConv = ADC_SOFTWARE_START;
|
|
pika_hadc1.Init.DataAlign = ADC_DATAALIGN_RIGHT;
|
|
pika_hadc1.Init.NbrOfConversion = 1;
|
|
|
|
HAL_StatusTypeDef state = HAL_ADC_Init(&pika_hadc1);
|
|
if (state != HAL_OK) {
|
|
obj_setErrorCode(self, 1);
|
|
obj_setSysOut(self, "[error] adc init faild.");
|
|
return;
|
|
}
|
|
|
|
/* Run the ADC calibration */
|
|
if (HAL_ADCEx_Calibration_Start(&pika_hadc1) != HAL_OK) {
|
|
obj_setErrorCode(self, 1);
|
|
obj_setSysOut(self, "[error] adc calibratie faild.");
|
|
return;
|
|
}
|
|
}
|
|
|
|
uint32_t getChannel(char* pin) {
|
|
Args* buffs = New_strBuff();
|
|
uint32_t channel = 0;
|
|
|
|
pin = strsCopy(buffs, pin + 2);
|
|
if (strEqu(pin, "0")) {
|
|
channel = ADC_CHANNEL_0;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "1")) {
|
|
channel = ADC_CHANNEL_1;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "2")) {
|
|
channel = ADC_CHANNEL_2;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "3")) {
|
|
channel = ADC_CHANNEL_3;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "4")) {
|
|
channel = ADC_CHANNEL_4;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "5")) {
|
|
channel = ADC_CHANNEL_5;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "6")) {
|
|
channel = ADC_CHANNEL_6;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "7")) {
|
|
channel = ADC_CHANNEL_7;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "8")) {
|
|
channel = ADC_CHANNEL_8;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "9")) {
|
|
channel = ADC_CHANNEL_9;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "10")) {
|
|
channel = ADC_CHANNEL_10;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "11")) {
|
|
channel = ADC_CHANNEL_11;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "12")) {
|
|
channel = ADC_CHANNEL_12;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "13")) {
|
|
channel = ADC_CHANNEL_13;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "14")) {
|
|
channel = ADC_CHANNEL_14;
|
|
goto exit;
|
|
}
|
|
if (strEqu(pin, "15")) {
|
|
channel = ADC_CHANNEL_15;
|
|
goto exit;
|
|
}
|
|
exit:
|
|
args_deinit(buffs);
|
|
return channel;
|
|
}
|
|
|
|
void STM32F1_ADC_platformRead(PikaObj* self) {
|
|
char *pin = obj_getStr(self, "pin");
|
|
obj_setFloat(self, "val", 3.3f * Get_Adc(&pika_hadc1, getChannel(pin)) / 4096.0f);
|
|
}
|