STM32 experiência de cinco a aprendizagem: experiência GPIO - com base na operação bit

Gravá-lo, leia - para facilitar o futuro
conteúdo do teste : Marquee, campainha e uma chave de entrada
informações oficiais:
1) "o Manual STM32 chinês Referência V10" Capítulo 8 Geral e funções de multiplexação IO (GPIO e afio)
2) "o Cortex- M3 definitivo guia (chinês) "Capítulo 5 de operação bits
características : operação pouco
princípio da FIG :
1), como mostrado, marquises, PB5 então LED0, PE5 então Ledl;
Aqui Insert Picture Descrição
2) como mostrado, um sinal sonoro, PB8 em seguida, BIP (campainha);
Aqui Insert Picture Descrição
3) Como se mostra, em seguida, PE4 KEY0, PE3 então KEY1, PE2, em seguida, TECLA2, PA0 então WK_UP.
Aqui Insert Picture Descrição
O Works não entrar em detalhes, não deixe de ver o que periféricos e GPIO pin encaixe.
funções de biblioteca GPIO envolvidos aprenderam :

1void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct)//初始化作用

Novos conhecimentos : bit O cálculo do endereço:
Aqui Insert Picture Descrição)
é assumido como sendo um quinto pinos de saída a fim GPIOA: PAout (5), e stm32f10x.h vista sys.h dois cabeçalhos encontrado:
Aqui Insert Picture Descrição
Aqui Insert Picture Descrição
Por conseguinte, GPIOA_ODR_Addr = 0x4001080C, n = 5 . Antes de fórmula roxo no código chave arquivo de cabeçalho é único, o endereço do alias pode ser calculado PAout (5) a.
Aqui Insert Picture Descrição
Portanto, a manipulação pouco pode fazer isso:
é definido no arquivo de cabeçalho led.h:

#define LED0 PBout(5);

Led.c definido no arquivo:

PBout(5)=0; //设GPIOB的第五管脚为低电平。

Finalmente, mencionar porque é GPIOA_BASE + 12? Manual de Referência STM32 chinês mencionadas, GPIOx_ODR deslocamentos de endereço são 0Ch, e, portanto, é +12. Correspondente, GPIOx_IDR compensar endereço é 0x08, portanto +8. Quanto ao porquê do GPIOA_BASE igual APB2PERIPH_BASE + 0x0800, não encontrou a resposta, Daniel pode explicar.
Aqui Insert Picture Descrição
Aqui Insert Picture Descrição
Procedimento experimental :
1) novo modelo de construção;
2) Nova pasta vazio HARDWARE (o utilizador pasta amarrado);
3) no software RDM, o novo led.c, beep.c e key.c três arquivos .c e correspondência o led.h, beep.h arquivos de cabeçalho key.h e são salvos na pasta HARDWARE;
código de cabeçalho 4) led.h são os seguintes.:

#ifndef __LED_H
#define __LED_H
#include "sys.h"
void LED_Init(void);    //初始化函数
#define LED0 PBout(5)   // PB5
#define LED1 PEout(5)   // PE5 
#endif

5) de código de cabeçalho beep.h são como se segue:

#ifndef __BEEP_H
#define __BEEP_H
void BEEP_Init(void);   //初始化函数
#define BEEP PBout(8)   // PB8
#endif

6) Código cabeçalho key.h são como se segue:

#ifndef __KEY_H
#define __KEY_H
#include "sys.h"
#define KEY0 PEin(4)    //PE4
#define KEY1 PEin(3)   //PE3 
#define KEY2 PEin(2)   //PE2
#define WK_UP PAin(0)  //PA0  WK_UP
void KEY_Init(void);
u8 KEY_Scan(u8);
#endif

7) O código de arquivo led.c são os seguintes:

#include "led.h"
#include "sys.h"
void LED_Init(void)
{
 GPIO_InitTypeDef  GPIO_InitStructure; 
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);  //使能PB端口时钟
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE, ENABLE);  //使能PE端口时钟
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5;           //LED0-->PB.5 端口配置
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;      //推挽输出
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;     //IO口速度为50MHz
 GPIO_Init(GPIOB, &GPIO_InitStructure);              //根据设定参数初始化GPIOB.5
 LED0=1;                                         //PB.5 输出高,LED0灭
 GPIO_Init(GPIOE, &GPIO_InitStructure);               //根据设定参数初始化GPIOE.5
 LED1=1;                                          //PE.5 输出高,LED1灭  
}

8) Código de arquivo beep.c são os seguintes:

#include "beep.h"
#include "sys.h"
void BEEP_Init(void)
{
 GPIO_InitTypeDef  GPIO_InitStructure; 
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);  //使能PB端口时钟
 GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;           //LED0-->PB.5 端口配置
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;      //推挽输出
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;     //IO口速度为50MHz
 GPIO_Init(GPIOB, &GPIO_InitStructure);              //根据设定参数初始化GPIOB.5
 BEEP=0;                                          //PB8 输出低,LED0灭
} 

9) Código de arquivo key.c são os seguintes:

#include "key.h"
#include "sys.h"
#include "delay.h"
void KEY_Init(void) //IO初始化
{ 
 GPIO_InitTypeDef GPIO_InitStructure;
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOE,ENABLE);    //使能PA,PE端口时钟
 GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_2|GPIO_Pin_3|GPIO_Pin_4;             //KEY0-KEY2
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;                                //设置成上拉输入
 GPIO_Init(GPIOE, &GPIO_InitStructure);                                       //初始化GPIOE2,3,4
 GPIO_InitStructure.GPIO_Pin  = GPIO_Pin_0;
 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPD;                                //PA0设置成输入,默认下拉   
 GPIO_Init(GPIOA, &GPIO_InitStructure);                                       //初始化GPIOA.0
}
u8 KEY_Scan(u8 mode)
{  
 static u8 key_up=1;                                                          //按键按松开标志
 if(mode)key_up=1;                                                            //支持连按    
 if(key_up&&(KEY0==0||KEY1==0||KEY2==0||WK_UP==1))
 {
  delay_ms(10);                                                              //去抖动 
  key_up=0;
  if(KEY0==0)return 1;                                                       //KEY0按下,即PE4为低电平
  else if(KEY1==0)return 2;                                                  //KEY1按下,即PE3为低电平
  else if(KEY2==0)return 3;                                                  //KEY2按下,即PE2为低电平
  else if(WK_UP==1)return 4;                                                 //WK_UP按下,即PA0为高电平
 }else if(KEY0==1&&KEY1==1&&KEY2==1&&WK_UP==0)key_up=1;      
  return 0;                                                                    // 无按键按下
}

10) No software MDK, Target1 direita, clique em Gerenciar Itens de projeto ..., na interface do Projeto Items, Grupos coluna, o novo hardware e led.c, beep.c e key.c três arquivos .c são adicionados ao entrar;
11) no software MDK, clique na varinha mágica opção C / C ++, clique Incluir
o direito de ... Caminhos, adicione o led.h diretório, três arquivos de cabeçalho key.h (ie hardware) beep.h e;
12 ) Nova função principal main.c, como segue:

#include "led.h"
#include "beep.h"
#include "key.h"
#include "sys.h"
#include "delay.h"
int main(void)
{
   vu8 key=0;
  delay_init();
    LED_Init();
    BEEP_Init();
   KEY_Init();
    while(1)
  {
   key=KEY_Scan(1);
      if(key)
    {        
       switch(key)
     {     
      case 4:
       BEEP=1;   //控制蜂鸣器叫   
       break;
      case 3: 
        LED0=0;     //控制LED0亮       
       break; 
      case 2: 
        LED1=0;     //控制LED1亮  
       break;
      case 1:                               
        LED0=0;     //控制LED0亮 
        LED1=0;     //控制LED1亮 
       break;
     }
     delay_ms(300);  //延迟300ms
     BEEP=0;         //控制蜂鸣器不叫
     LED0=1;         //控制LED0灭
     LED1=1;         //控制LED1灭
   }else delay_ms(10); 
  }
 }

13) Após a conclusão você pode executar para ver os resultados.
Conhecimento :
1) operação bit Learning Basics;
2) revisar arquivos key.c GPIO e bibliotecas u8 KEY_Scan (u8) de funções lógicas, referência pode STM32 experiência de três aprendizagem: Experiência GPIO - baseado bibliotecas
e STM32 experiência de quatro aprendizagem : GPIO experiência - baseada registo
como 4) revisão novos modelos de projeto, referência aprendendo STM32 experiência II: Novo modelo de projeto

Publicado 24 artigos originais · ganhou elogios 2 · Vistas 4128

Acho que você gosta

Origin blog.csdn.net/Leisure_ksj/article/details/105111870
Recomendado
Clasificación