灵动微MM32F013x芯片学习-ADC

MM32F013x的ADC还是蛮好用的,每一个ADC通道都有一个自己的结果寄存器。当启用连续转换模式时,ADC就可以自动更新转换结果到各自的结果寄存器,用户只需要直接读取结果寄存器即可,省去很多麻烦。由于ADC最快转换时间仅为1us,即使10个通道全部转换一次的时间也只有10us,对于一般的控制也是足够用的。还记得当初使用NXP芯片时,只有一个结果寄存器,每次都要修改转换通道,等待转换,而且还要考虑函数 的可重入性问题,甚是麻烦,而且也会浪费cpu的时间资源。灵动微的这点做的还是不错。下面就上代码:

void adc_init(void)
{
    //init pin mux
    RCC->AHBENR |= RCC_AHBENR_GPIOA; //enable GPIOA clock
    RCC->AHBENR |= RCC_AHBENR_GPIOB; //enable GPIOB clock
    
    GPIOA->CRL =0;// A0-A7->AD
    GPIOB->CRL &=  ~(GPIO_CNF_MODE_MASK << GPIO_CRL_CNF_MODE_0_Pos);//B0->ADIN8
    GPIOB->CRL |= GPIO_CNF_MODE_AIN << GPIO_CRL_CNF_MODE_0_Pos;
    GPIOB->CRL &=  ~(GPIO_CNF_MODE_MASK << GPIO_CRL_CNF_MODE_1_Pos);//B1->ADIN9
    GPIOB->CRL |= GPIO_CNF_MODE_AIN << GPIO_CRL_CNF_MODE_1_Pos;


    //init adc
    RCC->APB2ENR |= RCC_APB2ENR_ADC1EN; //enableADC1clock

    RCC->APB2RSTR |= RCC_APB2RSTR_ADC1RST; //ADC1reset
    RCC->APB2RSTR &= ~(RCC_APB2RSTR_ADC1RST); //reset   end


    ADC1->ADCFG |= ADCFG_ADCPRE_3; // 3 fractional frequency
    ADC1->ADCR |= ADCR_ADMD_CONTINUE;// continue mode
    ADC1->ADCR |= ADCR_ALIGN_RIGHT; //right-justified


    //enable channel
    ADC1->ADCHS |= ADCHS_CHEN0; //enable channel 0    
    ADC1->ADCHS |= ADCHS_CHEN1; //enable channel 1
    ADC1->ADCHS |= ADCHS_CHEN2; //enable channel 2
    ADC1->ADCHS |= ADCHS_CHEN3; //enable channel 3
    ADC1->ADCHS |= ADCHS_CHEN4; //enable channel 4
    ADC1->ADCHS |= ADCHS_CHEN5; //enable channel 5
    ADC1->ADCHS |= ADCHS_CHEN6; //enable channel 6
    ADC1->ADCHS |= ADCHS_CHEN7; //enable channel 7
    ADC1->ADCHS |= ADCHS_CHEN8; //enable channel 8
    ADC1->ADCHS |= ADCHS_CHEN9; //enable channel 9
    //ADC1->ADCHS |= ADCHS_CHENTS; //enable channel TS
    //ADC1->ADCHS |= ADCHS_CHENVS; //enable channel VS

    ADC1->ADCFG |= ADCFG_ADEN;//ADC1enable
    ADC1->ADCR |= ADCR_ADST;//Start Conversion
}
 

代码功能:实现通道0-9的自动转换,结果可在相应结果寄存器直接读取.

主要配置步骤:

1,引脚复用配置,要配置为模拟输入模式

2,使能ADC时钟

3,ADC模块复位,保证寄存器内容复位(这步可省略,因为上电复位效果一样)

4,配置ADC时钟速率,ADC模块时钟最快16Mhz,老实按照手册做,不要找过这个数,具体的分频根据自己的实际时钟频率确定

5,设置为连续转换模式,就是ADC自己不停的自动转换,不需要cpu的干预

6,转换结果右对齐,方便读取操作

7,使能要转换的ADC通道,MM32F013x有10个外部ADC通道,这里全部开启。当然,可以只开启自己想转换的通道,整个ADC数据更新的周期就更小,因为10us的更新周期已经可以满足我的需求,所以,这里全部使能

8,使能ADC模块

9,开启转换,这次才会触发ADC转换,一旦开启,ADC就会自动更新结果寄存器

总结,MM32F013x的ADC模块功能强大,而且操作起来相当简单

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于灵动电子MM32F5277控制器,您可以使用STM32的HAL库来与RFID-RC522模块进行通信。以下是一个示例代码,演示如何在MM32F5277上使用SPI与RFID-RC522模块进行通信: ```C #include "mm32f103.h" #include "mm32f103_rcc.h" #include "mm32f103_gpio.h" #include "mm32f103_spi.h" #include "rfid_rc522.h" void SPI1_Init(void) { SPI_InitTypeDef SPI_InitStructure; RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE); //使能SPI1时钟 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); //使能GPIOA时钟 //配置SPI1引脚 GPIO_PinRemapConfig(GPIO_Remap_SPI1, ENABLE); //配置SPI1的SCK、MISO、MOSI引脚 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_6 | GPIO_Pin_7; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); //配置NSS引脚作为普通GPIO输出 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOA, &GPIO_InitStructure); //SPI1参数配置 SPI_InitStructure.SPI_Direction = SPI_Direction_2Lines_FullDuplex; SPI_InitStructure.SPI_Mode = SPI_Mode_Master; SPI_InitStructure.SPI_DataSize = SPI_DataSize_8b; SPI_InitStructure.SPI_CPOL = SPI_CPOL_Low; SPI_InitStructure.SPI_CPHA = SPI_CPHA_1Edge; SPI_InitStructure.SPI_NSS = SPI_NSS_Soft; SPI_InitStructure.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_4; SPI_InitStructure.SPI_FirstBit = SPI_FirstBit_MSB; SPI_InitStructure.SPI_CRCPolynomial = 7; SPI_Init(SPI1, &SPI_InitStructure); //使能SPI1 SPI_Cmd(SPI1, ENABLE); } void Delay(__IO uint32_t nCount) { for (; nCount != 0; nCount--); } int main(void) { uint8_t status; uint8_t str[MAX_LEN]; //初始化SPI1 SPI1_Init(); //初始化RFID-RC522模块 RFID_RC522_Init(); while (1) { status = RFID_RC522_Request(PICC_REQIDL, str); //寻卡 if (status == MI_OK) { status = RFID_RC522_Anticoll(str); //防冲撞 if (status == MI_OK) { //卡片UID获取成功,执行相应操作 printf("Card UID: "); for (int i = 0; i < 5; i++) { printf("%X ", str[i]); } printf("\r\n"); } } Delay(0x3FFFFF); } } ``` 请注意,这只是一个基本的示例代码,仅包含RFID-RC522模块的初始化和基本读取卡片UID的操作。您可能需要根据实际需求进行更多的功能扩展和错误处理。 在使用此代码之前,请确保已正确连接RFID-RC522模块到MM32F5277板上的SPI引脚,并根据需要进行相应的引脚配置。 希望对您有所帮助!如果您有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值