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;
2) como mostrado, um sinal sonoro, PB8 em seguida, BIP (campainha);
3) Como se mostra, em seguida, PE4 KEY0, PE3 então KEY1, PE2, em seguida, TECLA2, PA0 então WK_UP.
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 :
1)void GPIO_Init(GPIO_TypeDef* GPIOx,GPIO_InitTypeDef* GPIO_InitStruct); //初始化作用
Novos conhecimentos : bit O cálculo do endereç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:
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.
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.
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