View previous topic :: View next topic |
Author |
Message |
rvalor
Joined: 16 Apr 2009 Posts: 18 Location: Spain
|
Problems with software and hardware uart in PIC18F4550 |
Posted: Thu Apr 16, 2009 8:28 am |
|
|
Hello everybody in this forum. I'm new in it, and this is my problem:
I'm using PIC18F4550 to communicate with a PC using a bluetooth device. This device communicates with the microcontroller via hardware uart. This communication works ok.
In the other hand I use a software uart in the pins used by ICSP (C6 & C7), this uart is useful in order to show info about the device itself (eg: if our supplier gives us a bluetooth module with a different firmware version, this will be checked by the PIC and will be shown via this interface...)
This software uart doesn't work, rubbish is received in the PC.
I thought that problem was in clock... but I use an external crystal at 8MHz.
In addition to the uart interfaces, I have an USB communication using the internal USB module in this PIC. The USB runs at 48MHz and works ok.
I think problem lies in the clock of the system but I configured it to get the clock directly from the external crystal not internal oscillator is used.
I configured all of them using the CCS compiler wizard and it generates this code:
Code: |
#FUSES HS //High speed Osc (> 4mhz)
#FUSES PLL2 //Divide By 2(8MHz oscillator input)
#FUSES CPUDIV1 //No System Clock Postscaler
#FUSES USBDIV //USB clock source comes from PLL divide by 2
#use delay(clock = 8000000, CRYSTAL)
#use rs232(stream =WT11, baud=115200, parity=N, xmit=PIN_C6, rcv=PIN_C7, bits=8)
#use rs232(stream = DEBUGG, baud= 9600, parity=N, xmit=PIN_B7, rcv=PIN_B6, bits=8)
|
In order to send data to each interface I use fprintf or fputc, using the correct stream (WT11 or DEBUGG).
I tried to solve the problem by setting the registers manually:
I create a variable in the memory position of the special function register...
Code: |
//CONFIG1L y CONFIG1H -> Seleccionan el modo del oscilador y el postscaler y preescaler para el USB
#BYTE CONFIG1L =0x300000
#BYTE CONFIG1H =0x300001
#BYTE UCFG =0xF6F
#BYTE OSCCON =0xFD3
//CONFIG1L bits...
#BIT CONFIG1L_USBDIV =0x300000.5
#BIT CONFIG1L_CPUDIV1 =0x300000.4
#BIT CONFIG1L_CPUDIV0 =0x300000.3
#BIT CONFIG1L_PLLDIV2 =0x300000.2
#BIT CONFIG1L_PLLDIV1 =0x300000.1
#BIT CONFIG1L_PLLDIV0 =0x300000.0
//CONFIG1H bits...
#BIT CONFIG1H_IESO =0x300001.7
#BIT CONFIG1H_FCMEN =0x300001.6
#BIT CONFIG1H_FOSC3 =0x300001.3
#BIT CONFIG1H_FOSC2 =0x300001.2
#BIT CONFIG1H_FOSC1 =0x300001.1
#BIT CONFIG1H_FOSC0 =0x300001.0
//UCFG bits...
#BIT UCFG_UTEYE =0xF6F.7
#BIT UCFG_UOEMON =0xF6F.6
#BIT UCFG_UPUEN =0xF6F.4
#BIT UCFG_UTRDIS =0xF6F.3
#BIT UCFG_FSEN =0xF6F.2
#BIT UCFG_PPB1 =0xF6F.1
#BIT UCFG_PPB0 =0xF6F.0
//OSCCON bits...
#BIT OSCCON_IDLEN =0xFD3.7
#BIT OSCCON_IRCF2 =0xFD3.6
#BIT OSCCON_IRCF1 =0xFD3.5
#BIT OSCCON_IRCF0 =0xFD3.4
#BIT OSCCON_OSTS =0xFD3.3
#BIT OSCCON_IOFS =0xFD3.2
#BIT OSCCON_SCS1 =0xFD3.1
#BIT OSCCON_SCS0 =0xFD3.0
|
and now I configure each bit:
Code: |
CONFIG1L_PLLDIV2 = FALSE; // Prescaler selection bits
CONFIG1L_PLLDIV1 = 0; // from 8MHz to 4MHz
CONFIG1L_PLLDIV0 = 1;
CONFIG1L_USBDIV = 1; //PLL at 96MHz
//96/2 ---> 48MHz
UCFG_FSEN = 1; //Full Speed USB
//---------------------------------------
//Configuración de reloj para CPU:
//---------------------------------------
CONFIG1L_CPUDIV1 =0; //Primary osc. as the system clock
CONFIG1L_CPUDIV0 =0;
CONFIG1H_FOSC3 =1; //CPU clock directly from crystal -> 8MHz
CONFIG1H_FOSC2 =1; //HS without PLL
CONFIG1H_FOSC1 =0;
CONFIG1H_FOSC0 =0; //This bit can be 0 or 1
|
But the compiler doesn't like it.... Can the configuration bits be accessed in this way??? It seems no.
Well this is my problem with software uart in this project...... any idea???
Thank you in advance¡¡¡¡¡ bye¡ |
|
|
bignick270
Joined: 11 Sep 2008 Posts: 44
|
|
Posted: Thu Apr 16, 2009 8:45 am |
|
|
I noticed when i used a hardware uart and a software uart at the same that on rare occasions when the hardware uart was receiving and the software uart was putting out data the timing would get messed up and the data going out the software uart was incorrect. I fixed that by adding a delay before the software uart could begin transmitting.
I am not saying this is your problem but it is something that I came across and only saw it by using a logic analyzer. |
|
|
asmallri
Joined: 12 Aug 2004 Posts: 1636 Location: Perth, Australia
|
|
Posted: Thu Apr 16, 2009 9:35 am |
|
|
You software uart timing is being affected by interrupts. _________________ Regards, Andrew
http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!! |
|
|
rvalor
Joined: 16 Apr 2009 Posts: 18 Location: Spain
|
Problem is now solved¡ |
Posted: Thu Apr 16, 2009 10:09 am |
|
|
Hello guys¡
I've solved the problem. The solution of the problem is to use a timer (eg: 100 us), so my time unit will be 100us. Next I send the info from the ISR using variables to control the transmition:
every second ---> send via software serial port next ...
send via hardware serial port and next...
send via USB interface...
well I don't understand why works in this manner but I will continue experimenting...
Bye and thank you very much¡¡ |
|
|
|