View previous topic :: View next topic |
Author |
Message |
Torello
Joined: 29 Sep 2006 Posts: 120
|
Compiler implements hardware Uart or not? |
Posted: Wed Sep 11, 2024 9:54 am |
|
|
Hi,
Is there a simple way to check if the compiler uses the hardware UART for the written code or not? Especially for parts that have a lot of pin select options _________________ Regards, Edwin. PCWHD v5.114 |
|
|
gaugeguy
Joined: 05 Apr 2011 Posts: 303
|
|
Posted: Wed Sep 11, 2024 1:53 pm |
|
|
Look at the C/ASM list file. |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1351
|
Re: Compiler implements hardware Uart or not? |
Posted: Wed Sep 11, 2024 6:07 pm |
|
|
Torello wrote: | Hi,
Is there a simple way to check if the compiler uses the hardware UART for the written code or not? Especially for parts that have a lot of pin select options |
If you specify the #use rs232 with a specific UART moniker and also omit / remove any pin assignments, it will use a hardware UART:
Code: |
#USE RS232 (UART1, BAUD=9600, ERRORS)
|
If you are using a UART that needs pin assignments and still want to ensure it is hardware you can use #pin_select
Code: |
#PIN_SELECT U1RX=PIN_B11
#PIN_SELECT U1TX=PIN_B10
#USE RS232 (UART1, BAUD=9600, ERRORS)
|
|
|
|
lindsay.wilson.88
Joined: 11 Sep 2024 Posts: 40
|
|
Posted: Thu Sep 12, 2024 9:12 am |
|
|
Thanks for raising this point, it was something I was curious about as well. Had a little poke around with a program that just does putc('A');.
With no FORCE_SW specified in the header file, i.e. like this:
Code: | #use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8) |
it produces the following assembler (comments are mine):
Code: | .................... putc('A');
0085: MOVLW 41 Move 41h (the hex for "A") into W register
0086: BTFSS 0C.4 Test bit 4 (TXIF) of register 0Ch (PIR1), skip next instruction if set
0087: GOTO 086 i.e. loop until TXIF=1, i.e. the transmit register can accept data
0088: MOVWF 19 Move W register (41h) into register 19h (TXREG). This now sends the character. |
So that's definitely hardware UART. If FORCE_SW is specified, i.e. like:
Code: | #use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8,FORCE_SW) |
then it produces:
Code: | .................... putc('A');
0048: MOVLW 41 Move 41h (the hex for "A") into W register
0049: MOVWF 21 Move W register (41h) into register 21h, a general-purpose register
004A: CALL 004 Call some subroutine at 004h, this presumably is the software UART thing. |
and there's a big bunch of stuff also at 004h, presumably however it bit-bashes the UART. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19529
|
|
Posted: Thu Sep 12, 2024 11:40 am |
|
|
Exactly.
And as you see, easy to do.
There is a code trick that will allow you to detect it as well. When the
hardware UART is used the error byte is a copy of the status register.
This has bit 5 set (to say the receive is enabled), while the software
UART won't have this bit set. |
|
|
Torello
Joined: 29 Sep 2006 Posts: 120
|
|
Posted: Wed Sep 18, 2024 6:57 am |
|
|
thanx all! Code: |
#use delay(internal=8000000)
#PIN_SELECT U1RX=PIN_B7
#PIN_SELECT U1TX=PIN_B6
#use RS232(stream=debug, UART1, Baud=38400, ERRORS) |
Works, but doesn't raise a warning. however it not use the internal UART1, I see the Goto xx in the ASM file.
If I put the #use delay() -after- the #use RS232(..) the compiler does throws an error that it needs this declaration.
Isn't that also a good indication? Or does the HW-UART implementation still use delays bases on that declaration? _________________ Regards, Edwin. PCWHD v5.114 |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19529
|
|
Posted: Wed Sep 18, 2024 7:25 am |
|
|
No. Both the UART, and the software UART require the clock setup. How
else do you think they can setup the baud rate?.
What makes you say this doesn't select the UART?. It should. You don't
tell us what chip though, which leaves the possibility the compiler is
not selecting the hardware because these pins can't handle the UART. |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1351
|
|
Posted: Wed Sep 18, 2024 9:53 am |
|
|
Torello wrote: | thanx all! Code: |
#use delay(internal=8000000)
#PIN_SELECT U1RX=PIN_B7
#PIN_SELECT U1TX=PIN_B6
#use RS232(stream=debug, UART1, Baud=38400, ERRORS) |
Works, but doesn't raise a warning. however it not use the internal UART1, I see the Goto xx in the ASM file.
If I put the #use delay() -after- the #use RS232(..) the compiler does throws an error that it needs this declaration.
Isn't that also a good indication? Or does the HW-UART implementation still use delays bases on that declaration? |
Looks like a hardware UART to me when I look at the ASM:
Code: |
#case
#include <24fj64ga004.h>
#use delay(internal=8000000)
#PIN_SELECT U1RX=PIN_B7
#PIN_SELECT U1TX=PIN_B6
#use RS232(stream=debug, UART1, Baud=38400, ERRORS)
void main(){
fputc('0', debug);
}
|
ASM:
Code: |
.................... fputc('0', debug);
0242: MOV.B #30,W0L
0244: BTSC.B 223.1
0246: BRA 244
0248: MOV.B W0L,224
024A: CLR.B 225
|
0x223 - 0x225 are all HW registers for the chip I put in the example. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19529
|
|
Posted: Wed Sep 18, 2024 11:45 am |
|
|
Exactly. Using 'UART1', forces the compiler to use the hardware. I've never
seen it not do so. |
|
|
lindsay.wilson.88
Joined: 11 Sep 2024 Posts: 40
|
|
Posted: Wed Sep 18, 2024 12:00 pm |
|
|
So is either using UART1, or specifying the pins (e.g. xmit=PIN_C6,rcv=PIN_C7), both do the same thing?
I'm guessing that specifying the pins is superfluous since you can't pick and choose the pins anyway on most devices? |
|
|
jeremiah
Joined: 20 Jul 2010 Posts: 1351
|
|
Posted: Wed Sep 18, 2024 1:03 pm |
|
|
lindsay.wilson.88 wrote: | So is either using UART1, or specifying the pins (e.g. xmit=PIN_C6,rcv=PIN_C7), both do the same thing?
I'm guessing that specifying the pins is superfluous since you can't pick and choose the pins anyway on most devices? |
Specifying pins in the #use also has the potential to make it a software UART. I've had older compiler versions in the past that did that. Best practice for hardware UARTS is to specify the uart (UART1, etc) and not specify the pins |
|
|
lindsay.wilson.88
Joined: 11 Sep 2024 Posts: 40
|
|
Posted: Wed Sep 18, 2024 3:26 pm |
|
|
That's good to know, thanks! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19529
|
|
Posted: Thu Sep 19, 2024 1:27 am |
|
|
This is why you will see me saying to always use the UARTx syntax.
The 'pin' syntax is fine on older chips with the pins fixed in one place. On
later chips that had the pins movable by a fuse, this can easily get confused.
Then when PPS came along it got even easier to confuse it more!....
Set the fuse or PPS to select where the UART is
Then just tell the compiler to use the UART.
The most reliable way to ensure you are using the hardware UART. |
|
|
|