共2条
1/1 1 跳转至页
ARM7,2104 ARM7 2104开发板串口问题
问
今天闲来无事玩了会ARM7 2104开发板 问题如下:
使用工具:串口助手2.1
调试:ARM7 2104 开发板串口0
实验方式:自动发送 间隔 100MS
通讯方式:9600 、无校验、8BIT+1STOP
发送内容:ABCDEFGHIJKLMNOPQRSTUVWXYZ123456(一组32个数据)约30多MS
空闲70MS
实验目的:利用串口双工、和FIFO 资源,让ARM2104接收到PC 数据就返回PC
实验结果:单发正常!可是自动发送就发送数目!=接收数目
开始怀疑是串口助手2.1的事情!
:通过示波器看有的组后面没有返回数据!
从分析来看 应该收到PC一组当中头四个就应该向PC返回数据啊
在接收区看到数据总是一组一组的丢失!很奇怪!!!
实验过程:
volatile uint8 temp;
#define LED1CON 0x00000400 /* LED1控制,低电平点亮,用于通讯指示 */
#define LED2CON 0x00000800
void __irq IRQ_UART0(void)
{ uint32 i;
uint32 status;
i = IOSET; // 读取当前LED控制值
if( (i&LED1CON)==0 ) // 控制LED输出
{ IOSET = LED1CON;
}
else
{ IOCLR = LED1CON;
}
status=U0IIR&0x0f;
if((status==0x04)||(status==0x0c))
{ do
{ temp=U0RBR;
U0THR=temp;
}while(U0LSR&0X01);
}
VICVectAddr = 0x00; // 中断处理结束
}
/****************************************************************************
* 名称:UART0_Ini()
* 功能:初始化串口0。设置其工作模式及波特率。
* 入口参数:baud 波特率
* set 模式设置(UARTMODE数据结构)
* 出口参数:返回值为1时表示初化成功,为0表除参数出错
****************************************************************************/
uint8 UART0_Ini(uint32 baud, UARTMODE set)
{ uint32 bak;
/* 参数过滤 */
if( (0==baud)||(baud>115200) ) return(0);
if( (set.datab<5)||(set.datab>8) ) return(0);
if( (0==set.stopb)||(set.stopb>2) ) return(0);
if( set.parity>4 ) return(0);
/* 设置串口波特率 */
U0LCR = 0x80; // DLAB位置1
bak = (FPCLK>>4)/baud;
U0DLM = bak>>8;
U0DLL = bak&0xff;
/* 设置串口模式 */
bak = set.datab-5; // 设置字长度
if(2==set.stopb) bak |= 0x04; // 判断是否为2位停止位
if(0!=set.parity) set.parity = set.parity-1;
bak |= set.parity; // 设置奇偶校验
U0LCR = bak;
return(1);
}
int main(void)
{ uint32 i1;
UARTMODE uart0_set;
PINSEL0 = 0x00000005; // 设置I/O连接到UART0
PINSEL1 = 0x00000000;
IODIR = LED1CON+LED2CON; // 设置LED1控制口为输出,其它IO为输入
rcv_new = 0;
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(9600, uart0_set); // 初始化串口模式
U0FCR = 0x41; // 使能FIFO,并设置触发点为4字节
U0IER = 0x01; // 允许RBR中断,即接收中断
/* 设置中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
VICIntEnable = 0x00000040; // 使能UART0中断
while(1)
{ if( (IOSET&LED2CON)==0 ) // 控制LED输出
{ IOSET = LED2CON;
}
else
{ IOCLR = LED2CON;
}
}
return(0);
}
请高人指点一下! 答 1: ZLGARM帮忙看一下!帮分析分析啊! 答 2: 帮分析一下啊 答 3: 关注中。。。。。。。。
使用工具:串口助手2.1
调试:ARM7 2104 开发板串口0
实验方式:自动发送 间隔 100MS
通讯方式:9600 、无校验、8BIT+1STOP
发送内容:ABCDEFGHIJKLMNOPQRSTUVWXYZ123456(一组32个数据)约30多MS
空闲70MS
实验目的:利用串口双工、和FIFO 资源,让ARM2104接收到PC 数据就返回PC
实验结果:单发正常!可是自动发送就发送数目!=接收数目
开始怀疑是串口助手2.1的事情!
:通过示波器看有的组后面没有返回数据!
从分析来看 应该收到PC一组当中头四个就应该向PC返回数据啊
在接收区看到数据总是一组一组的丢失!很奇怪!!!
实验过程:
volatile uint8 temp;
#define LED1CON 0x00000400 /* LED1控制,低电平点亮,用于通讯指示 */
#define LED2CON 0x00000800
void __irq IRQ_UART0(void)
{ uint32 i;
uint32 status;
i = IOSET; // 读取当前LED控制值
if( (i&LED1CON)==0 ) // 控制LED输出
{ IOSET = LED1CON;
}
else
{ IOCLR = LED1CON;
}
status=U0IIR&0x0f;
if((status==0x04)||(status==0x0c))
{ do
{ temp=U0RBR;
U0THR=temp;
}while(U0LSR&0X01);
}
VICVectAddr = 0x00; // 中断处理结束
}
/****************************************************************************
* 名称:UART0_Ini()
* 功能:初始化串口0。设置其工作模式及波特率。
* 入口参数:baud 波特率
* set 模式设置(UARTMODE数据结构)
* 出口参数:返回值为1时表示初化成功,为0表除参数出错
****************************************************************************/
uint8 UART0_Ini(uint32 baud, UARTMODE set)
{ uint32 bak;
/* 参数过滤 */
if( (0==baud)||(baud>115200) ) return(0);
if( (set.datab<5)||(set.datab>8) ) return(0);
if( (0==set.stopb)||(set.stopb>2) ) return(0);
if( set.parity>4 ) return(0);
/* 设置串口波特率 */
U0LCR = 0x80; // DLAB位置1
bak = (FPCLK>>4)/baud;
U0DLM = bak>>8;
U0DLL = bak&0xff;
/* 设置串口模式 */
bak = set.datab-5; // 设置字长度
if(2==set.stopb) bak |= 0x04; // 判断是否为2位停止位
if(0!=set.parity) set.parity = set.parity-1;
bak |= set.parity; // 设置奇偶校验
U0LCR = bak;
return(1);
}
int main(void)
{ uint32 i1;
UARTMODE uart0_set;
PINSEL0 = 0x00000005; // 设置I/O连接到UART0
PINSEL1 = 0x00000000;
IODIR = LED1CON+LED2CON; // 设置LED1控制口为输出,其它IO为输入
rcv_new = 0;
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(9600, uart0_set); // 初始化串口模式
U0FCR = 0x41; // 使能FIFO,并设置触发点为4字节
U0IER = 0x01; // 允许RBR中断,即接收中断
/* 设置中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
VICIntEnable = 0x00000040; // 使能UART0中断
while(1)
{ if( (IOSET&LED2CON)==0 ) // 控制LED输出
{ IOSET = LED2CON;
}
else
{ IOCLR = LED2CON;
}
}
return(0);
}
请高人指点一下! 答 1: ZLGARM帮忙看一下!帮分析分析啊! 答 2: 帮分析一下啊 答 3: 关注中。。。。。。。。
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |