View previous topic :: View next topic |
Author |
Message |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
 |
temtronic
Joined: 01 Jul 2010 Posts: 9587 Location: Greensville,Ontario
|
|
Posted: Tue May 06, 2025 9:52 am |
|
|
OK, I have to ask.... what's wrong with simple, good old reliable 'RS-232' ?
Providing you have a comport( UART) at both ends, it's darn reliable. Even if bitbanged, communications can be very reliable( I can get 15 miles no problem) |
|
 |
dyeatman
Joined: 06 Sep 2003 Posts: 1968 Location: Norman, OK
|
|
Posted: Tue May 06, 2025 10:05 am |
|
|
A number of years ago I sent a fairly large array data via I2C 8 bits at a time.
Of course this be an issue if speed is required.
In my case speed was not an issue. The first bytes were "setup
data" bytes, of which two had the total number of bytes being sent (up to
65K) and two with the starting address in the array (so I could send partial
data if needed). I then used the offset from the beginning of the array and
copied the remaining (count) bytes into the array in order. If I had two
different segments I sent two separate streams.
This worked for me for more than 10 years on a industrial control system with
no issues until we phased out the system
Maybe this approach would work for you. _________________ Google and Forum Search are some of your best tools!!!! |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Tue May 06, 2025 2:22 pm |
|
|
Yes dyeatman, i2c was my first thought. I used it for years in my ROV.
I may still go that way. How does each end know what to expect? A slave PIC uses an Interrupt Service Routine. I don't understand what Python does.
I need to send two arrays of 512 bytes in 4 msec. I have a PIC installed in a Heathkit Curve Tracer and I need to send settings and digitized curves to a RaspberryPi 4b for plotting.
I would like to adapt it to show real time displays of an HP4193A Vector Impedance Analyzer and an HP4192A Impedance meter.
Yes Temtronic, RS232 has 1 or 2 start bits and a stop bit. Sounds easy but I need to see the protocol and an example of the software at each end.
How does each end know what to expect? One could be expecting ASCII with CRLF control bytes. I could spend weeks writing it but someone must have done this and that is what I'm asking for. Not an example with hundreds of lines of code that does other wonderful things I don't understand and I'm not interested in.
This schematic shows how far I went down the rabbit hole. I wanted a fast dual ADC (28 MSPS), then a PIC with lots of memory to store the data (maybe 8 kbytes or more), then enough pins to control everything. The project is an XY DSO that can be used to replace 1975 vintage pen plotters (paper and ink). It would be nice to make it versatile for other projects, hence the added complexity. Now I need to work out the things I don't understand. I'm a hardware guy, not a real programmer.
https://drive.google.com/file/d/1SUMeJ8wPJh5_twpTLxo1x-SfKuNpzXeY/view?usp=drive_link
Yes, the PIC won't do 28 MSPS but it can control logic chips that can.
Ideally I don't want to modify the RaspberryPi too much with a bunch of wires hanging out. It does have USB and Ethernet ports but they are beyond my skills, unless someone has done it. |
|
 |
dyeatman
Joined: 06 Sep 2003 Posts: 1968 Location: Norman, OK
|
|
Posted: Tue May 06, 2025 2:49 pm |
|
|
Here is a Python I2C receive routine that may help:
Code: | import RPi.GPIO as GPIO
import smbus2
# Define GPIO pin for interrupt line
interrupt_pin = 17
# Define I2C address
i2c_address = 0x20
# Initialize I2C bus
bus = smbus2.SMBus(1)
# Set up GPIO interrupt
def interrupt_callback(channel):
print("Interrupt triggered!")
# Read data from the I2C slave
try:
data = bus.read_byte(i2c_address)
print("Data:", data)
except IOError as e:
print(f"I2C Error: {e}")
GPIO.setmode(GPIO.BCM)
GPIO.setup(interrupt_pin, GPIO.IN, pull_up_down=GPIO.PUD_UP)
GPIO.add_event_detect(interrupt_pin, GPIO.RISING, callback=interrupt_callback, bouncetime=20)
|
_________________ Google and Forum Search are some of your best tools!!!! |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Wed May 07, 2025 7:08 am |
|
|
Thanks dyeatman; that gives me an idea of how Python works but isn't this all done in Python functions. I have found many snippets but no complete working examples showing both ends. I saw an Arduino example which would be difficult to convert to PIC (for me). The problem with i2c is that the PIC needs to be Master to send up to 126 bytes and the Pi does not support clock stretching. As Slave the PIC can only send one byte at a time.
UART seems to be a better choice as temtronic suggested. I don't know what the protocol is. RS232 has drivers for long lines that can be dispensed with for short distances (12 inches). The DB25 connector is not needed either. However proper RS232 has:
TXD & RXD which would be TX and Rx on the Pi and PIC. An interface is still required to switch the lines for bi-directional operation.
Example from my ROV: https://drive.google.com/file/d/1eZLK37uOr6xSMz0qtptk10BYL_UbB-lM/view?usp=drive_link
RTS & CTS: Request to Send (RTS) is activated by the transmitter when it needs to send data, and Clear to Send (CTS) is activated by the receiver to indicate readiness to receive data.
DTR & DSR: Data Terminal Ready (DTR) informs DCE that DTE is ready for communication, and Data Set Ready (DSR) indicates that DCE is ready
DCD: Data Carrier Detect (DCD) shows that DCE is connected to DTE
RI: Ring Indicator (RI) is activated when an incoming call is detected
At least RTS and CTS would be needed and there should be routines written to handle this. I shouldn't need to reinvent this. I need an example for both PIC and Pi. |
|
 |
dyeatman
Joined: 06 Sep 2003 Posts: 1968 Location: Norman, OK
|
|
Posted: Wed May 07, 2025 8:30 am |
|
|
Also, you likely know with RS232 the characters must all be converted to ASCII
before sending and converted back on the other end which is somewhat a pain...
In my case I sent each byte, not a group of bytes and it worked fine (and I was
totally unlimited to the number of bytes I could send). I just picked the start
point in the array and started sending. This way I could update 1 byte, a
group, or all as needed. BTW, I also sent a terminator byte at the end to tell
the other end I was done. This way there was no time limit on how fast I had
to send one or more bytes. It just kept adding them into the array at the next
location until I told it I was done but I had to be sure I sent that
terminator command or it started overwriting memory! _________________ Google and Forum Search are some of your best tools!!!! |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Wed May 07, 2025 8:59 am |
|
|
I don't think it has to be ASCII with RS232. It can be any 8 bit byte.
Without functions for each of the Pi and PIC and a connection diagram it is a waste of time.
I also have a PL2303 USB from UART board. There are lots on Ebay but the software is usually missing. I do have a routine for Hitec on MPLAB but it is uncommented and there are no instructions on connecting it. |
|
 |
dyeatman
Joined: 06 Sep 2003 Posts: 1968 Location: Norman, OK
|
|
Posted: Wed May 07, 2025 9:06 am |
|
|
Don't forget the control characters.
Since you have no way of knowing the data you can't just send it raw. _________________ Google and Forum Search are some of your best tools!!!! |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Wed May 07, 2025 10:23 am |
|
|
Would it be easier to use SPI?
I have never used it so I would like to know:
Are there limitations like those of I2C?
Can unlimited data be sent from a slave in a stream?
Example software for a SIMPLE connection would be appreciated.
I can look for Pi examples if this looks hopeful. |
|
 |
Ttelmah
Joined: 11 Mar 2010 Posts: 19961
|
|
Posted: Wed May 07, 2025 11:00 am |
|
|
You seem to be wanting to make things complex. All of these interfaces
are single bit serial interfaces. SPI is the fastest, but needs three tires.
I2C is simple, bidirectional and reliable. Has the advantage of allowing more
than two devices on a single pair of wires. Normal UART serial is probably
the easiest, and if it is only going a few inches can be run very fast without
special interfaces. Can be sent really long distances if you use suitable drivers.
All only send a bit at a time, but the PIC can assemble these into bytes for
you and with suitable code can handle packets any length you want on any
of these interfaces. I2C as standard can handle up to 126 bytes per
transaction. Serial can handle any length packet for which you have memory.
SPI the same.
Your original I2C would work fine. It is only you who seem to think you can't
do more than one byte back. |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Thu May 08, 2025 8:22 am |
|
|
No Ttelmah, I'm trying to make things simple.
I thought we established in this thread that I could only send one byte at a time if my PIC is the slave. So I am looking for something better.
https://www.ccsinfo.com/forum/viewtopic.php?t=60622
Please realize I am learning Python and am looking for a way to send up to 18 512 byte arrays to a Raspberry Pi 4b for plotting.
In this thread
https://www.ccsinfo.com/forum/viewtopic.php?t=60622
the code for the Raspberry Pi is not shown so I'm doing a lot of guessing. This happens often so I don't ever see an actual working example of code for both ends. Python code written 10 years ago may no longer run because of changes. Python 2 will not run on Python 3. Example code often mixes tabs with spaces so the code may not run. WiringPi uses different pin numbering for the GPIO making for 3 numbering systems.
In this thread
https://forums.raspberrypi.com/viewtopic.php?t=149577
I see "Although raspberry pi does not support ISR interrupts, I read about wiringpi "pseudo interrupts" but I guess that this is only for GPIO pins, not for USB serial data."
So if the Pi does not use interrupts it has to poll, which sounds inefficient. I would rather have it ask for the data.
I need help from someone who has actually sent data from a PIC to a Raspberry Pi. I have i2c working but only one byte per transaction.
Maybe multiple transactions is the way to go. That means up to 18 x 512 transactions. How long will that take? Longer than a few seconds would be annoying.
Is this really the easiest way? |
|
 |
temtronic
Joined: 01 Jul 2010 Posts: 9587 Location: Greensville,Ontario
|
|
Posted: Thu May 08, 2025 8:31 am |
|
|
Never had a PI, but they seem to have USB so....
...can you use a USB<>TTL module to easily connect to the PIC ?
I've used them as the 'glue' between PICs and PCs for years.
I have to assume that the PI doesn't have real UARTs under the hood as no ISR ? |
|
 |
rovtech
Joined: 24 Sep 2006 Posts: 288
|
|
Posted: Thu May 08, 2025 9:37 am |
|
|
I have a hardware PL2303 USB-to-UART adapter but doesn't that just create another serial bus, and how do I communicate over it?
Python has read_block_data(addr,cmd) for i2c with smbus but I can't find an example of using it with a PIC. |
|
 |
|