View previous topic :: View next topic |
Author |
Message |
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
#USE RS232 Hard/Soft mode? |
Posted: Tue Feb 04, 2014 11:56 am |
|
|
Hello! I have to use serial communication rs232. The question is: If I assign XMIT and RCV to different of datasheet pointed as hardware pins, is it still hardware rs232? In other words, if I am not using the hardware uart transfer pins, am I using hardware communication yet? Actually, what determines in which mode(hardware/software) am I? _________________ A person who never made a mistake never tried anything new. |
|
|
Gabriel
Joined: 03 Aug 2009 Posts: 1067 Location: Panama
|
|
Posted: Tue Feb 04, 2014 11:58 am |
|
|
if you change pins... you are using software. _________________ CCS PCM 5.078 & CCS PCH 5.093 |
|
|
bkamen
Joined: 07 Jan 2004 Posts: 1615 Location: Central Illinois, USA
|
|
Posted: Tue Feb 04, 2014 12:09 pm |
|
|
Gabriel wrote: | if you change pins... you are using software. |
Unless you're using a PPS capable PIC and can move signal pins around.
(one example is the PIC18FxxJ11's)
-Ben _________________ Dazed and confused? I don't think so. Just "plain lost" will do. :D |
|
|
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
|
Posted: Tue Feb 04, 2014 1:05 pm |
|
|
The problem is that the PIC I am using 18F4550 RX and SDO match. So I cant use both - hardware SPI and hardware UART. Can I?
Thank you for reply! _________________ A person who never made a mistake never tried anything new. |
|
|
asmboy
Joined: 20 Nov 2007 Posts: 2128 Location: albany ny
|
|
Posted: Tue Feb 04, 2014 1:37 pm |
|
|
if you can use hardware RX handshaking reception hold-off , then a bit of creative external 74HC logic 'glue' can perhaps enable what you seek to do ,
really it it depends on the necessity of neither the rs-232 RX nor the SDO/SDI features being uncontrolled asynchronous in nature. |
|
|
Humberto
Joined: 08 Sep 2003 Posts: 1215 Location: Buenos Aires, La Reina del Plata
|
|
Posted: Tue Feb 04, 2014 2:24 pm |
|
|
Quote: |
The problem is that the PIC I am using 18F4550 RX and SDO match. So I cant use both - hardware SPI and hardware UART. Can I?
|
I assume that the internal build-in logical hardware structure of any MCU is clever enough to disable the Rx (INPUT) hardware UART while toggling SDO (OUTPUT)
Each module that share a common PIN has this exclusive behaviour.
Humberto |
|
|
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
|
Posted: Tue Feb 04, 2014 2:29 pm |
|
|
I think I can handle with software UART and hardware SPI. Thank you all for valuable information! _________________ A person who never made a mistake never tried anything new. |
|
|
Humberto
Joined: 08 Sep 2003 Posts: 1215 Location: Buenos Aires, La Reina del Plata
|
|
Posted: Tue Feb 04, 2014 2:34 pm |
|
|
Each module that share a common PIN has this exclusive behaviour. If your external hardware meets the electrical needs to run without disturbing
mutually, I do not see any confict using the same pin for differents functions and using both modules, asychronous EUSART & SPI Module in differents
time slot, of course.
Humberto |
|
|
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
|
Posted: Tue Feb 04, 2014 3:13 pm |
|
|
After attempt, I will post feedback! _________________ A person who never made a mistake never tried anything new. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Feb 05, 2014 2:30 am |
|
|
Comments:
The things that are hard to do in software, are:
1) RS232 receive.
2) SPI slave.
Now it you only want RS232 transmission, you can either use software, or enable the UART, and turn off the receive half.
If you are the SPI master, then software SPI on other pins is easy.
The problem really appears when you want both full duplex RS232, and SPI slave operation, or you require absolute maximum speed from the SPI.
In this case I have to say 'look at another chip'. The PIC18F45K50, is pin/voltage compatible with your chip, but has SDO relocatable via fuses. It also has far fewer errata than the 4550, which makes coding a lot easier....
Best Wishes |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9269 Location: Greensville,Ontario
|
|
Posted: Wed Feb 05, 2014 6:10 am |
|
|
another choice....
I upgraded from the 18f4550 to the 18f46k22 to get 2 hardware UARTS AND 2 MSSP( SPI / I2C) ports.Has more memory too !
I consider it to be the 'Swiss Army Knife' of PICs.Lots of features that you my not use in one project but will in another.By using just this PIC, you save time(and $) on cutting/testing code as you can 'cut and past' from past working projects.
hth
jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Feb 05, 2014 7:57 am |
|
|
I must admit, I assumed that since the poster was using a USB capable chip, he needed USB. This is the one 'missing thing', on the 46K22....
However (for myself), I've been tending to use the 26J50, which has the similar 'jack of all trades' ability to the 46K22, but includes USB. However this is 3.3v...
The number of serious errata on the 4550, has put me off this chip.
Both the 46K22, and 26J50, only have a couple, likely to hit in quite rare circumstances. The one that should be borne in mind for the K22, is the USART one. Download the little alternative UART configuration routine, posted here by PCM_Programmer, if using this chip.
Best Wishes |
|
|
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
|
Posted: Wed Feb 05, 2014 11:41 am |
|
|
My goal is to create a dev board like this:
PC <—usb_cdc—> pic18lf4550 <—spi—> enc28j60
.................................l
.................................|rs232
.........................wiz107sr
I have a success with communication but separately. I am about to find out if the complex system would work. _________________ A person who never made a mistake never tried anything new. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Feb 05, 2014 12:51 pm |
|
|
Just use software SPI.
#use spi, allows this on any pins.
Best Wishes |
|
|
rikotech8
Joined: 10 Dec 2011 Posts: 376 Location: Sofiq,Bulgariq
|
|
Posted: Thu Feb 06, 2014 12:50 pm |
|
|
I promised to post feedback. Here is the code I use as debug between PC--usb_cdc--PIC18LF4550--max232--rs232toUSB Converter--PC. I used two com ports. One for CCS USB and the other for my USB - RS232 converter. The thing that surprised me is, how come my USB works pretty well at clock frequency 48MHz despite the fact it is forbidden by 18LF4550 errata. And bidirectional data being transfered is uncorrupted. Ttelmah warned me, I should not set clock freq. above 18MHz.
Here is the code: Code: |
#include <18LF4550.h>
#fuses HSPLL, PLL4, CPUDIV1, VREGEN, PUT, NODEBUG, CPUDIV1, USBDIV, NOXINST, NOIESO, NOWDT, NOPBADEN, NOMCLR
#use delay(clock =48M)
#use RS232(baud=9600, UART1, PARITY=N, BITS = 8, STOP=1, ERRORS)
#include <usb_cdc.h>
#DEFINE G_LED PIN_D0
#DEFINE Y_LED PIN_D1
#DEFINE R_LED PIN_C2
#INT_TIMER0
void TMR0(){
usb_task();
output_toggle(R_LED);
}
void main()
{
int i;
char ch_usb;
char ch_rs;
delay_ms(500);
usb_init_cs();
SETUP_TIMER_0(T0_DIV_1);
while(!usb_enumerated())
{
usb_task();
output_toggle(Y_LED);
delay_ms(50);
}
output_low(Y_LED);
output_high(G_LED);
ENABLE_INTERRUPTS(INT_TIMER0);
ENABLE_INTERRUPTS(GLOBAL);
while (true)
{
if(usb_cdc_kbhit())
{
ch_usb=usb_cdc_getc();
if(ch_usb=='E')output_toggle(Y_LED);
putc(ch_usb);
}
if(kbhit())
{
ch_rs=getc();
if(ch_rs=='R')output_toggle(Y_LED);
usb_cdc_putc(ch_rs);
}
delay_ms(5);
}
} |
This code (in my opinion) ensures me, I can use the PIC as PC<->WIZ107SR converter on TTL signal base.
The SPI is not relevant by now! _________________ A person who never made a mistake never tried anything new. |
|
|
|