PIC18f46k42 UART未收到

时间:2018-02-27 19:19:54

标签: assembly embedded uart pic18

TL; DR优先:UART1接收器未接收;请告诉我我做错了什么。

更详细的版本:

我目前正在开发一个项目,该项目使用UART在两个PIC18f46k42芯片之间发送状态报告。以前在使用f8722芯片的原型板上进行的测试工作正常,但在切换到f46k42后,我只能使发射器工作;接收缓冲区根本没有填充。

我检查并重新检查了文档中描述的设置(数据表的第480页有一个基本清单),所以我得出结论,这是一个我不知道的简单错误,或者有一些错误其他设置我忽略了。

我在调试时检查过的一些细节和事项:

  • 我正在使用mpasm编程,MPLABX和PICKIT3

  • U1RXB没有填充任何内容,甚至没有垃圾数据

  • 我打算设置所有控制寄存器;可能没错过BANKSEL
  • 引脚设置为数字,接收引脚设置为输入
  • 检查范围内的发射器;按预期发出信号
  • 双重检查数据极性是否正确
  • 明确设置我能想到的每个控制寄存器,以防万一

这是使用单个芯片的一些测试代码(想要确保我的其他芯片不坏/振荡器明显不同)并且没有所有的花里胡哨以便专注于UART问题。它不是很漂亮(包含来自其他测试的不必要的工件),所以我提前道歉。这段代码永远不会到达接收子程序,接收缓冲区中永远不会有任何东西(0x00,应该是0x87),接收FIFO永远不会溢出。有趣的是,RXIDL位在运行此测试时是清楚的,即使它实际上从未接收过任何内容。

;UART TEST

    #include <p18F46k42.inc> 
    CONFIG  WDTE = OFF
    CONFIG  LVP = OFF
    CONFIG  FEXTOSC = HS          ; External Oscillator Selection (HS (crystal oscillator) above 8 MHz; PFM set to high power)
    CONFIG  RSTOSC = HFINTOSC_1MHZ




PROCR   EQU 0x02    ;Temp register for receiving 
PROCT   EQU 0x03    ;Temp register for transmitting 

    ORG 0x00
    GOTO    START
    ORG 0x100
START:
    BCF TRISD,0
    BCF PORTD,0
    BANKSEL ANSELC
    BCF     ANSELC,7
    BCF     ANSELC,6
    BSF    TRISC,7
    BCF     TRISC,6

UART1_INIT:
    BANKSEL U1BRGL
    MOVLW   d'207' ;particularly slow baud rate for testing purposes
    MOVWF   U1BRGL
    CLRF    U1BRGH
    BANKSEL U1CON0
    MOVLW   b'00110000'  ;enable tx and rx for UART1; 8-bit, no parity
    MOVWF   U1CON0
    MOVLW   b'10000000'  ;enable UART1 module
    MOVWF   U1CON1
    MOVLW   b'00000000'  ;normal polarity (high idle)
    MOVWF   U1CON2

    BANKSEL PIE0
    MOVLW   b'01001000';Turn on UART1, and Receive interrupts
    MOVWF   PIE3


    BANKSEL INTCON0
    BSF INTCON0,GIEH

    BANKSEL U1RXPPS
    MOVLW   b'00010111' ;PORTC,7 for U1 receive pin
    MOVWF   U1RXPPS
    BANKSEL RC6PPS
    MOVLW   b'00010011' ;PORTC,6 for U1 tx pin
    MOVWF   RC6PPS

MAIN:
    MOVLW   0x87
    MOVWF   PROCT
    CALL    TRANSMT
M2:
    BANKSEL PIR3
    BTFSS   PIR3,3  ;check for full receive buffer
    BRA MAIN
    CALL    RECEIVE
    BRA MAIN


TRANSMT: 
    BANKSEL U1FIFO
    BTFSS   U1FIFO,5    ;Check if transmit register is empty
    BRA     TRANSMT     ;If not, wait until it is empty
    MOVF    PROCT,W
    BANKSEL U1TXB
    MOVWF   U1TXB       ;Send data
    RETURN

RECEIVE:
    BANKSEL PIR0
    BCF     PIR3,U1RXIF   ;Clear interrupt flag
    BANKSEL U1RXB
    MOVF    U1RXB,W
    MOVWF   PORTD
    RETURN

    END

感谢任何帮助;这个问题是阻碍我目前进步的唯一因素,也是我自己无法解决的唯一问题。

1 个答案:

答案 0 :(得分:1)

终于把它想出来了(经过一次重大的休息以使我的眼睛焕然一新)。

所以,这个答案是双重的,既适用于此处的问题,也适用于我创建此测试程序要解决的问题。

此问题

在修复中断启用后,该程序将起作用。不应设置U1RXIE(PIE3,4)。这对我来说是一个令人尴尬的疏忽。不过,我仍然不确定为什么在没有读取接收缓冲区的情况下清除了标志。以下是上述错误设置的工作版本:

UART1_INIT:
    BANKSEL U1BRGL
    MOVLW   d'207'
    MOVWF   U1BRGL
    CLRF    U1BRGH
    BANKSEL U1CON0
    MOVLW   b'00110000'
    MOVWF   U1CON0
    MOVLW   b'10000000'
    MOVWF   U1CON1
    MOVLW   b'00000000'
    MOVWF   U1CON2

    BANKSEL PIE0
    MOVLW   b'01000000';Turn on UART1 interrupts
    MOVWF   PIE3


    BANKSEL INTCON0
    BSF INTCON0,GIEH

    BANKSEL U1RXPPS
    MOVLW   b'00010111' ;PORTC,7 for U1 recieve pin
    MOVWF   U1RXPPS
    BANKSEL RC6PPS
    MOVLW   b'00010011' ;PORTC,6 for U1 tx pin
    MOVWF   RC6PPS

整体问题

如果有人帮助读这个:我的实际代码应该在接收数据字节时中断。在调试时,它没有进入ISR,我从未在接收缓冲区中看到过任何内容,而且我从未看到设置了中断标志。所以我开始尝试使用上面的代码来解决问题;一旦我修好它,我就回到另一个测试(使用中断)。由于它仍然不起作用,我知道它与中断有关。

事实证明,当我指着IVT时我搞砸了,所以我的ISR的地址被放在了桌子的错误部分......加上所有的东西搞砸......

嗯,从好的方面来看,两件事都是我搞砸的事情,而不是我一无所知的事情。感谢任何看过这个问题的人!