ARM 为什么老进不去串口中断呢?用的是正点原子的程序,用的是STM32-MINI开发板,不一定的地方是PORT接口

ARM 为什么老进不去串口中断呢?用的是正点原子的程序,用的是STM32-MINI开发板,不一定的地方是PORT接口,第1张

1. printk是linux内核的打印函数,纯固件的程序中当然不会有这个函数的定义。

2. printf只用到了串口输出,没有输入,如果只是单纯死在这里应该与中断无关。

目前需要继续定位问题:

1. 保证在程序执行到挂死的位置时串口没有输入。

2. 在没有仿真器的情况下,用IO口电压或LED点亮和关闭的方法定位程序死在哪一行代码上。该代码不应该是一个函数调用,应该是函数内部的寄存器判断或某个循环语句。

3. 如果确认是在串口输入到来时才会产生的现象,并且程序也没有执行到中断处理,需要检查中断入口地址是否正确。可以考虑检查所有中断,确认是否因为其它中断引起代码跳转错误。

//摘要: 掌握 UART0配置及使用,程序中将UART0 配置到P0.0、 P0.1。利用串口调试助手,波特率设置为4800,并选择十六进制发送和显示,十六进制发送为偶数个,不然会少返回一个数,详见程序注释。

#include "c8051f020.h"

unsigned char data1

void SYSCLK_Init()

void PORT_Init()

void UART0_Init()

void SYSCLK_Init()

{

unsigned int i

OSCXCN=0X67//0X67=0110,0111

for(i=0i<256i++)//等待>1ms

while(!(OSCXCN&0X80)) //等待XTLVLD变为1

OSCICN=0X88//时钟失效监测器,选择外部时钟源作为系统时钟

}

void PORT_Init()

{

XBR0 = 0x27/*交叉开关配置,URAT总线TX0置到P0.0口,RX0置到P0.1口, SPI总线SCK配置到P0.2口,

MOSI为P0.4口, NSS为P0.5,MISO配置到P0.3口,IIC总线SDA置到P0.6口�SCK置到P0.7 TX1,RX1配置到P1.0,P1.1,CEX0,CEX1,配置到P1.2,P1.3,外部中断int0配置到P1.4 */

XBR1 = 0x04

XBR2 = 0x44 /*允许功能选择开关有效*/

P0MDOUT = 0x1A/*SCK、MOSI和NSS为推拉式输出,MISO为开漏式.*/

P74OUT =0xff

}

void UART0_Init()

{

SCON0=0x50 //串口方式1

TMOD=0X20//选用定时器1作为波特率发生器

TH1=0xF4 //波特率为4800

TL1=0xF4

ES0=1 //开启串口中断0

TF1=0

TR1=1 //定时器启动

PCON=0X80//波特率加倍 波特率为9600

TI0=1

}

void UART0_ISR() interrupt 4 using 1

{

if(RI0)

{

RI0=0//中断接收标志清零

data1=SBUF0//接收数据

SBUF0=data1//发送数据

while(TI0==0)

TI0=0//发送标志清零

}

}

main()

{

WDTCN=0XDE

WDTCN=0XAD

SYSCLK_Init()

PORT_Init()

UART0_Init()

EA=1

while(1)

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11840157.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存