资源描述
第一道 I/O 口的控制 流水灯同一时间只有一个灯亮,亮的灯从左到右,再从右到左,如此反复循环
#include "GP32C.h"
#define Light_D PTA //宏定义
#define Light_P DDRA
void Delay1000(void); //延迟子函数
//=======主函数开始=======================================
void main()
{
Light_P=0xff; //IO口初始化
Light_D=0xff;
while(1)
{
unsigned char i;
for(i=0;i<8;i++)
{
Lignt_D=~(1<<i);
Delay1000();
}
for(i=0;i<8;i++)
{
Lignt_D=~(1<<(7-i));
Delay1000();
}
}
}
//=========延迟子函数=============================
void Delay1000(void)
{
unsigned char u;
for(u=0;u<=110;u++);
}
第二道 串口程序 要求串口初始化,有到1 .2.3……8 控制对应的灯亮
#include "GP32C.H"
#define Light_D PTA
#define Light_P DDRA
#define ReSendStatusR SCS1 //SCI状态寄存器
#define ReTestBit 5 //接收缓冲区满标志位
#define SendTestBit 7 //发送缓冲区空标志位
#define ReSendDataR SCDR //数据寄存器
void SCIInit(void); //串行口初始化子程序
void SCISend1(unsigned char o); //串行发送1字节
void SCISendN(unsigned char n,unsigned char ch[]); //串行发送N字节
unsigned char SCIRe1(unsigned char *p); // 串行接收1字节
unsigned char SCIReN(unsigned char n,unsigned char ch[]);//串行接收1字节
unsigned char SerialBuff[]; //存放接收数据的数组
//=======主函数开始=======================================
void main()
{
Light_P=0xff; //IO口初始化
Light_D=0xff;
SCIInit(void);//串口初始化
while(1)
{
i=SCIReN(1,SerialBuff);
if(i==0)
{
tmp=SerialBuff[0];
if((tmp>=1)&&(tmp<=8))
{
Light_D=~(1<<(tmp-1));
}
}
}
}
//==============================================
void SCIInit(void)
{
SCBR=0b00000010; //总线频率fBUS=2.4576MHz,定义波特率Bt=9600
SCC1=0b01000000; //设置允许SCI,正常码输出、8位数据、无校验
SCC2=0b00001100; //设置允许发送、允许接收,查询方式收发
}
//==============================================
/*SCISend1:串行发送1个字节-----------------------------*
void SCISend1(unsigned char o)
{//判断ReStatusR的第SendTestBit位是否为1,是1可以发送
while(1)
if ((ReSendStatusR & (1<<SendTestBit)) != 0)
{
ReSendDataR=o;
break;
}
}
//=================================================
/*SCISendN:串行发送N个字节-----------------------------*
void SCISendN(unsigned char n,unsigned char ch[])
{
int i;
for(i=0;i<n;i++)
SCISend1(ch[i]);
}
//==================================================
/*SCIRe1:串行收一个字节数据----------------------------*
unsigned char SCIRe1(unsigned char *p)
{
unsigned int k;
unsigned char i;
//ReStatusR第ReTestBit位为1表示可接收数据
for(k=0;k<0xfbbb;k++)
if ((ReSendStatusR & (1<<ReTestBit)) != 0)
{
i=ReSendDataR;
*p=0x00;
break;
}
if(k>=0xfbbb)
{
i=0xff;
*p=0x01;
}
return i;
}
//==================================================
/*SCIReN:HC08串行接收N个字节---------------------------*
unsigned char SCIReN(unsigned char n,unsigned char ch[])
{
int m;
unsigned char fp;
m=0;
while (m<n)
{
ch[m]=SCIRe1(&fp);
if (fp==1) return 1;
m++;
}
return 0;
}
第三道 简答题 4*4 的键盘原理
4*4键盘如下图所示
4*4键盘结构解析:列线(n1~n4)通过电阻接+5V,当键盘上没有键闭合时,所有的行线和列线断开,列线n1~n4都呈高电平。当键盘上某一个键闭合时,则该键所对应的行线和列线短路。例如,第2排第三个按键被按下闭合时,行线m2和列线n3短路,此时n3线上的电平由m2的电位所决定。
键盘处理程序的任务是:确定有无键按下,判断哪一个键按下,键的功能是什么;还要消除按键在闭合或断开时的抖动。两个并行口中,一个输出扫描码,使按键逐行动态接地,另一个并行口输入按键状态,由行扫描值和回馈信号共同形成键编码而识别按键,通过软件查表,查出该键的功能。
第四道 定时器(实现指定的定时程序 ——初始化 程序)用定时器的方法。
#include "GP32C.H"
#define Light_D PTA
#define Light_P DDRA
#define EnableMCUint() asm("CLI") //开放总中断
#define DisableMCUint() asm("SEI") //禁止总中断
#define EnableT1OVInt() T1SC |= (1 << 6) //开放定时器1溢出中断
#define DisableT1OVInt() T1SC &= ~(1 << 6) //禁止定时器1溢出中断
void T1init(void);
void main()
{
DisableMCUint(); //禁止总中断
Light_P=0xff; //IO口初始化
Light_D=0xff;
T1init(); //定时器1初始化
EnableT1OVInt(); //开放定时器1溢出中断
EnableMCUint(); // 开放总中断
while(1);
}
//T1init:定时器1初始化-----------------------------------------------------*
//功能:对定时器1初始化,禁止定时器1溢出中断,设置为1s发生1次定时器溢出中断 *
void T1init(void)
{
//禁止定时器1溢出中断,不启动计数,分频因子 = 64
T1SC = 0b00100110;
//计数寄存器初值 = 0x0000
T1CNTH = 0x00;
T1CNTL = 0x00;
//预置寄存器设定值 = 0x9600
T1MODH = 0x96;
T1MODL = 0x00;
//允许定时器1计数寄存器计数
T1SC &= ~(1 << TSTOPBit);
}
/*定时器中断处理函数------------------------------------*/
#pragma interrupt_handler isrLED
void isrLED(void)
{
DisableMCUint(); //禁止总中断
Light_D=~Light_D;
EnableMCUint(); //开放总中断
}
//未定义的中断处理函数,本函数不能删除
#pragma interrupt_handler isrDummy
void isrDummy(void)
{ }
#pragma abs_address:0xffdc //中断向量表起始地址
void (* const _vectab[])(void) = {
isrDummy, //时基中断
isrDummy, //AD转换中断
isrLED, //LED中断
isrDummy, //SCI TC/TE
isrDummy, //SCI RF/IDLE
isrDummy, //SCI PE/FE/NF/OR
isrDummy, //SPI TE
isrDummy, //SPI MOD/OVR/RF
isrDummy, //TIM2溢出中断
isrDummy, //TIM2通道1
isrDummy, //TIM2通道0
isrDummy, //TIM1溢出中断
isrDummy, //TIM1通道1
isrDummy, //TIM1通道0}
展开阅读全文