花了一天时间搞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 寄存器 写数据进行数据的发送了。。