共3条
1/1 1 跳转至页
【求助】初学C语言,问个很菜的问题,见笑了
问
本人从一本书上,找了一段键盘处理子函数来学习,但是编译时出现ERRO,请各位大侠指点,谢谢。
程序如下:
#include <pgmspace.h>
#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h"
#define BUFF_SIZE 64
unsigned char edge, bitcount; // 0 =符号. 1 = 正号.
unsigned char kb_buffer[BUFF_SIZE];
unsigned char *inpt, *outpt;
unsigned char buffcnt;
void init_kb(void)
{
inpt = kb_buffer; // 初始化缓冲区
outpt = kb_buffer;
buffcnt = 0;
MCUCR = 2; // INT0 中断,下降沿触发
edge = 0; // 0 = 下降沿; 1 = 上升沿
bitcount = 11;
}
interrupt [INT0_vect] void INT0_interrupt(void)
{
static unsigned char data; // 保持接受扫描码的状态
if (!edge) // 下降沿触发中断服务程序
{
if(bitcount < 11 && bitcount > 2) // 3到10位是数据,
{ // 忽略起始和停止位
data = (data >> 1);
if(PIND & 8)
data = data | 0x80; // 存储一个'1'
}
MCUCR = 3; // 用上升沿引发中断
edge = 1;
}
else
{ // 上升沿触发中断服务程序
MCUCR = 2; // 用下降沿引发中断
edge = 0;
if(--bitcount == 0) // 接受到所有的数据位
{
decode(data);
bitcount = 11;
}
}
}
void decode(unsigned char sc)
{
static unsigned char is_up=0, shift = 0, mode = 0;
unsigned char i;
if (!is_up) // 最后一位数据接受
{
switch (sc)
{
case 0xF0 : // 确定完成键
is_up = 1;
break;
case 0x12 : // 左SHIFT按键
shift = 1;
break;
case 0x59 : // 右SHIFT按键
shift = 1;
break;
case 0x05 : // F1键
if(mode == 0)
mode = 1; // 进入按键扫描码模式
if(mode == 2)
mode = 3; // 离开按键扫描码模式
break;
default:
if(mode == 0 || mode == 3) // ASCII 模式
{
if(!shift) //如果没有SHIFT键按下,
{ // 查表
for(i = 0; unshifted[i][0]!=sc && unshifted[i][0]; i++);
if (unshifted[i][0] == sc)
{
put_kbbuff(unshifted[i][1]);
}
}
else
{ // 如果SHIFT键按下
for(i = 0; shifted[i][0]!=sc && shifted[i][0]; i++);
if (shifted[i][0] == sc)
{
put_kbbuff(shifted[i][1]);
}
}
}
else
{ // 扫描键盘码模式
print_hexbyte(sc); // 显示模式
put_kbbuff(' ');
put_kbbuff(' ');
}
break;
}
}
else
{
is_up = 0; // 2个 0xF0在一列中是不允许的
switch (sc)
{
case 0x12 : // 左 SHIFT
shift = 0;
break;
case 0x59 : // 右SHIFT
shift = 0;
break;
case 0x05 : // F1
if(mode == 1)
mode = 2;
if(mode == 3)
mode = 0;
break;
case 0x06 : // F2
clr();
break;
}
}
}
void put_kbbuff(unsigned char c)
{
if (buffcnt<BUFF_SIZE) // 若缓冲区为空
{
*inpt = c; // 在缓冲区中输入一个字符
inpt++; // 指针加1
buffcnt++;
if (inpt >= kb_buffer + BUFF_SIZE) // 指针判断
inpt = kb_buffer;
}
}
int getchar(void)
{
int byte;
while(buffcnt == 0); // 等待数据
byte = *outpt; // 取数据
outpt++; // 指针加1
if (outpt >= kb_buffer + BUFF_SIZE) // 指针比较
outpt = kb_buffer;
buffcnt--; // 缓冲区减去1
return byte;
}
编译状态显示:
sh207.c(5):error c318:CAN't open file "gpr.h"
sh207.c(6):error c318:CAN't open file "sCANcodes.h"
sh207.c(17):error c202:"MCUCR":undefined identifier
sh207.c(21):error c141: syntax error near "interrupt"
sh207.c(21):error c129: missing ";"before ']' 答 1: 你用的是什么编译环境?你确定这些*.h文件都在当前文件夹吗?
#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h" 答 2: 要学会看懂error,error上说的很清楚了 答 3: 21行21行的 interrupt 用法是IAR的用法。不知道你所用的是什么MCU,什么编译器。如果是KEIL,那就是不行的,要改成KEIL的用法,interrupt 放后面,再跟个中断号。 答 4: re:我用的是KEIL,CPU是AT89C51#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h"
都不在当前文件夹。
程序如下:
#include <pgmspace.h>
#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h"
#define BUFF_SIZE 64
unsigned char edge, bitcount; // 0 =符号. 1 = 正号.
unsigned char kb_buffer[BUFF_SIZE];
unsigned char *inpt, *outpt;
unsigned char buffcnt;
void init_kb(void)
{
inpt = kb_buffer; // 初始化缓冲区
outpt = kb_buffer;
buffcnt = 0;
MCUCR = 2; // INT0 中断,下降沿触发
edge = 0; // 0 = 下降沿; 1 = 上升沿
bitcount = 11;
}
interrupt [INT0_vect] void INT0_interrupt(void)
{
static unsigned char data; // 保持接受扫描码的状态
if (!edge) // 下降沿触发中断服务程序
{
if(bitcount < 11 && bitcount > 2) // 3到10位是数据,
{ // 忽略起始和停止位
data = (data >> 1);
if(PIND & 8)
data = data | 0x80; // 存储一个'1'
}
MCUCR = 3; // 用上升沿引发中断
edge = 1;
}
else
{ // 上升沿触发中断服务程序
MCUCR = 2; // 用下降沿引发中断
edge = 0;
if(--bitcount == 0) // 接受到所有的数据位
{
decode(data);
bitcount = 11;
}
}
}
void decode(unsigned char sc)
{
static unsigned char is_up=0, shift = 0, mode = 0;
unsigned char i;
if (!is_up) // 最后一位数据接受
{
switch (sc)
{
case 0xF0 : // 确定完成键
is_up = 1;
break;
case 0x12 : // 左SHIFT按键
shift = 1;
break;
case 0x59 : // 右SHIFT按键
shift = 1;
break;
case 0x05 : // F1键
if(mode == 0)
mode = 1; // 进入按键扫描码模式
if(mode == 2)
mode = 3; // 离开按键扫描码模式
break;
default:
if(mode == 0 || mode == 3) // ASCII 模式
{
if(!shift) //如果没有SHIFT键按下,
{ // 查表
for(i = 0; unshifted[i][0]!=sc && unshifted[i][0]; i++);
if (unshifted[i][0] == sc)
{
put_kbbuff(unshifted[i][1]);
}
}
else
{ // 如果SHIFT键按下
for(i = 0; shifted[i][0]!=sc && shifted[i][0]; i++);
if (shifted[i][0] == sc)
{
put_kbbuff(shifted[i][1]);
}
}
}
else
{ // 扫描键盘码模式
print_hexbyte(sc); // 显示模式
put_kbbuff(' ');
put_kbbuff(' ');
}
break;
}
}
else
{
is_up = 0; // 2个 0xF0在一列中是不允许的
switch (sc)
{
case 0x12 : // 左 SHIFT
shift = 0;
break;
case 0x59 : // 右SHIFT
shift = 0;
break;
case 0x05 : // F1
if(mode == 1)
mode = 2;
if(mode == 3)
mode = 0;
break;
case 0x06 : // F2
clr();
break;
}
}
}
void put_kbbuff(unsigned char c)
{
if (buffcnt<BUFF_SIZE) // 若缓冲区为空
{
*inpt = c; // 在缓冲区中输入一个字符
inpt++; // 指针加1
buffcnt++;
if (inpt >= kb_buffer + BUFF_SIZE) // 指针判断
inpt = kb_buffer;
}
}
int getchar(void)
{
int byte;
while(buffcnt == 0); // 等待数据
byte = *outpt; // 取数据
outpt++; // 指针加1
if (outpt >= kb_buffer + BUFF_SIZE) // 指针比较
outpt = kb_buffer;
buffcnt--; // 缓冲区减去1
return byte;
}
编译状态显示:
sh207.c(5):error c318:CAN't open file "gpr.h"
sh207.c(6):error c318:CAN't open file "sCANcodes.h"
sh207.c(17):error c202:"MCUCR":undefined identifier
sh207.c(21):error c141: syntax error near "interrupt"
sh207.c(21):error c129: missing ";"before ']' 答 1: 你用的是什么编译环境?你确定这些*.h文件都在当前文件夹吗?
#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h" 答 2: 要学会看懂error,error上说的很清楚了 答 3: 21行21行的 interrupt 用法是IAR的用法。不知道你所用的是什么MCU,什么编译器。如果是KEIL,那就是不行的,要改成KEIL的用法,interrupt 放后面,再跟个中断号。 答 4: re:我用的是KEIL,CPU是AT89C51#include "kb.h"
#include "serial.h"
#include "gpr.h"
#include "sCANcodes.h"
都不在当前文件夹。
共3条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【笔记】生成报错synthdesignERROR被打赏50分 | |
【STM32H7S78-DK评测】LTDC+DMA2D驱动RGBLCD屏幕被打赏50分 | |
【STM32H7S78-DK评测】Coremark基准测试被打赏50分 | |
【STM32H7S78-DK评测】浮点数计算性能测试被打赏50分 | |
【STM32H7S78-DK评测】Execute in place(XIP)模式学习笔记被打赏50分 | |
每周了解几个硬件知识+buckboost电路(五)被打赏10分 | |
【换取逻辑分析仪】RA8 PMU 模块功能寄存器功能说明被打赏20分 | |
野火启明6M5适配SPI被打赏20分 | |
NUCLEO-U083RC学习历程2-串口输出测试被打赏20分 | |
【笔记】STM32CUBEIDE的Noruletomaketarget编译问题被打赏50分 |