您的位置 首页 资料

为什么要学STM32?答案就在这儿

为什么要学STM32?STM32是32位的单片机却只要八位单片机的价格,速度也是八位的好几倍。更重要的是它作为ARM入门级的芯片比较容易掌握,网上资料也很多,很多人都在用。STM32的

  为什么要学STM32?

  STM32是32位的单片机却只需八位单片机的价格,速度也是八位的好几倍。

  更重要的是它作为ARM入门级的芯片比较简略把握,网上材料也许多,许多人都在用。

  STM32的IO端口有7个寄存器来操控,可是咱们常用的就4个CRL CRH IDR ODR 。

  端口装备低寄存器(GPIOx_CRL)

  端口装备高寄存器(GPIOx_CRH)

  端口输入数据寄存器(GPIOx_IDR)

  端口输出数据寄存器(GPIOx_ODR)

  其间CRL 操控高8位的 IO CRH 低8这两个本质是相同的。

  对照咱们AVR来看GPIOx_CRL就相当于DDRx ,GPIOx_ODR就相当于PORTx,GPIOx_ODR就相当于PINxSTM32的 IO 口能够由 口能够由 软件装备成 软件装备成 软件装备成 8种形式: 种形式:

  1、输入浮空

  2、输入上拉

  3、输入下拉

  4、模仿输入

  5、开漏输出

  6、推挽输出

  7、推挽式复用功用

  8、开漏复用功用

  简略的来说STM32的CRL寄存器能够设置输入、输出形式,还能够设置输出的最大速率。

  输入浮空 :既不是上拉也不是下拉输入。

  开漏形式和推挽形式:弱上拉和下拉电阻被制止,开漏形式时,读输入数据寄存器时可得到I/O口状况,推挽形式时,读输出数据寄存器时可得到最后一次写的值,模仿输入装备。弱上拉和下拉电阻被制止读取输入数据寄存器时数值为’0’。

  好接下来要说下一个常常听到的操控办法了,直接操作寄存器和库函数办法直接操作寄存器便是直接对CRL等寄存器写值。库函数是ST官方吧一切的操控都写好了,咱们只需要调用。直接操作寄存器

  GPIOA-CRH=0XFFFFFFF0;

  GPIOA-CRH|=0X00000003;/PA8 推挽输出

  GPIOA-ODR|=18; /PA8 输出高

  库函数

  GPIO_InitTypeDef GPIO_InitStruct;

  GPIO_InitStruct.GPIO_Pin = GPIO_Pin_11|GPIO_Pin_12 ;

  GPIO_InitStruct.GPIO_Mode = GPIO_Mode_OUT;

  GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;

  GPIO_InitStruct.GPIO_Speed =GPIO_Speed_Level_3;

  GPIO_Init(GPIOA, GPIO_InitStruct);

  GPIO_SetBits(GPIOA, GPIO_Pin_11 | GPIO_Pin_12 );

  现在写一个LED的初始化

  直接操作寄存器

  /LED IO初始化

  void LED_Init(void)

  {

  RCC-APB2ENR|=12; /使能PORTA时钟

  GPIOA-CRH=0XFFFFFFF0; /PA8 推挽输出

  GPIOA-CRH|=0X00000003;/速率

  GPIOA-ODR|=18; /PA8 输出高 一开始高灭灯

  }

  注:先要使能PORTA时钟

  库函数

  void LED_Init(void)

  {

  GPIO_InitTypeDefGPIO_InitStructure; /声明结构体ST库

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);/使能PA端口时钟

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;/LED0–PA.8 端口装备

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; /推挽输出

  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; /速率

  GPIO_Init(GPIOA, GPIO_InitStructure); /结构体初始化

  GPIO_SetBits(GPIOA,GPIO_Pin_8);/PA.8 输出高

  }

  OK到这两种办法的初始化都OK了

  main 函数

  int main(void)

  {

  SystemInit(); /体系时钟初始化为72M SYSCLK_FREQ_72MHz

  delay_init(72); /延时函数初始化

  NVIC_Configuration(); /设置NVIC中止分组2:2位抢占优先级,2位呼应优先级

  LED_Init(); /LED端口初始化

  while(1)

  {

  LED0=0;/也能够运用 (库)GPIO_ResetBits(GPIOA,GPIO_Pin_8);

  /寄存器GPIOA-ODR=~(18);

  delay_ms(300);

  LED0=1; /也能够运用 GPIO_SetBits(GPIOA,GPIO_Pin_8);

  /寄存器 GPIOA-ODR|=18;

  delay_ms(300);

  }

  }

  使能PORTA时钟,这儿阐明下STM32的时钟树和AVR51等有很大的差异,它每个外设都会有自己的时钟,要运用一个外设必需要先开外设的时钟。这样也必定程度上减少了功耗。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/131269.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部