Mam dość dziwny problem z XC8 na mikrokontrolerze PIC18F27K40. Na PIC16F1778 działa . Zdefiniowałem:
void uart_putch(unsigned char byte) {
while (!PIR3bits.TX1IF);
TX1REG = byte;
}
Kiedy w mojej mainpętli dzwonię uart_putch('a');, działa to dobrze. Jednak gdy definiuję const char c = 'a';i dzwonię uart_putch(c);, to nie działa. Drukuje coś, choć nie jest a- myślę, że to 0x00postacie, z których czerpię hexdump -x /dev/ttyUSB0. To nie jest problem z portem szeregowym na moim komputerze; Patrzyłem z lunetą i sygnał jest inny (lewa działa, prawa nie):
Kod jest prosty:
void main(void) {
init(); // Sets up ports and UART control registers
while (1) {
uart_putch('a'); // or c
}
}
To, co nie działa, to użycie dowolnej funkcji łańcuchowej ( puts, printfitp.), Co moim zdaniem jest powiązane - dlatego w tym pytaniu podałem minimalny działający przykład ze znakami.
Wygenerowany zespół, gdy używam zmiennej, cma:
_c:
db low(061h)
global __end_of_c
_main:
; ...
movlw low((_c))
movwf tblptrl
if 1 ;There is more than 1 active tblptr byte
movlw high((_c))
movwf tblptrh
endif
if 1 ;There are 3 active tblptr bytes
movlw low highword((_c))
movwf tblptru
endif
tblrd *
movf tablat,w
call _putch
I ze stałą ma w _mainbloku:
movlw (061h)&0ffh
call _putch
Używam kompilatora MPLAB XC8 C V1.41 (24 stycznia 2017 r.) Z obsługą części w wersji 1.41.
Odpowiednie części mojego Makefile:
CC:=xc8
CFLAGS:=-I. --chip=18F27K40 -Q -Wall
SRC:=main.c uart.c
DEP:=uart.h
PRS:=$(subst .c,.p1,$(SRC))
OBJ:=main.hex
all: $(OBJ)
$(OBJ): $(PRS)
$(CC) $(CFLAGS) $^
$(PRS): %.p1: %.c $(DEP)
$(CC) $(CFLAGS) -o$@ --pass1 $<
Jakakolwiek pomoc w uzyskaniu tego działania byłaby bardzo mile widziana.
unsigned char, char, const unsigned chari const char.
byteTxzamiast tego zmienisz nazwę argumentu ? Obawiam się, że bytemoże być zdefiniowany gdzie indziej jako typ danych. (Wygląda na to, że wygenerowałoby to diagnostykę kompilatora, ale najwyraźniej dzieje się tutaj coś dziwnego.) A jako kolejny test, czy putch(0x61)zachowuje się w ten sam sposób jak putch('a')? Zastanawiam się, czy instrukcja odczytu tabeli odczytuje dane 8-bitowe czy 16-bitowe. Rejestr PIC W ma jednak tylko 8 bitów, prawda?

