MPC837xE-rdb开发板上DUART的调试

花了一天时间搞MPC837xE-rdb开发板上DUART的调试。

 

因为Application的要求,要使用interrupt-driven 进行Transmit。

一些基本配置,比如 data length,stop bits length,parity,和baudrate都设置好了,FIFO mode 也是开启的。

 

中断方面,external interrupt(EE, bit16 in MSR), UART1 INT in IPIC module, THRE INT 都已经使能了。

 

并且,也将UART1 INT 的interrupt handler routine 与 UART1 INT hardware signal 联系起来了。

 

但是,总不能发送出数据。

 

进入interrupt handler routine之后,需要首先判断 interrupt identification register 中的 bit7, 也就是interrupt pending bit 是否是1,亦即,是否有中断在pending。

 

每次比较都是1,也就是没有中断pending。

 

在之前,IIR的读取是在将IER设置为0之后进行的。

 

后来,想了很多,还是搞不定,就调整了一下代码的顺序。将IIR的读取放在设置IER为0之前,居然就可以了。。。可以读取到 THRE 是当前pending的interrupt,并在THRE的处理中,向 THR 寄存器 写数据进行数据的发送了。。

你可能感兴趣的:(Module,application,Signal)