View previous topic :: View next topic |
Author |
Message |
guy
Joined: 21 Oct 2005 Posts: 291
|
High speed USB |
Posted: Tue Oct 17, 2023 10:15 pm |
|
|
Hello everyone, it's been a while...
Is there a [cost-effective hardware] solution to use CCS compiler with USB High Speed (2.0) ? Some interface chip maybe? I need to get as much bandwidth as possible.
Thank you! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19391
|
|
Posted: Wed Oct 18, 2023 3:34 am |
|
|
The problem will be how are you going to handle the data?.
Even the fastest PIC's using DMA, you won't be able to get the data to/from
an external memory, and the internal RAM would be too small for any
HS communication to really be worthwhile.
I've done USB PIC's giving just over 1MB/sec on the internal USB,
and even with the fastest PIC's, the problem is keeping up with handling
the data at this speed. The overhead of transferring in/out on another
port would negate any speed advantage of an external interface.
The fastest PIC USB is the 32MZ series, but these are full 32bit chips,
so not supported by CCS. None of the lesser CPU's deem it worthwhile
offering a faster interface, because they simply can't handle more than this. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9182 Location: Greensville,Ontario
|
|
Posted: Wed Oct 18, 2023 5:04 am |
|
|
hmm....just how MUCH data ? You'll need a PIC with a LOT of RAM or maybe a huge FRAM ? BIG buffers for sure.
Does the 'data' need to be stored ?
Then there's 'processing the data'. Moving bytes is fairly fast but any 'math' on them will slow down the program, especially if ,ugh, floating point is involved |
|
|
guy
Joined: 21 Oct 2005 Posts: 291
|
|
Posted: Thu Oct 19, 2023 3:20 pm |
|
|
Thanks for the support.
I don't have to get to the top speed USB 2.0, but USB 1.1 is not enough.
I worked with dsPIC33 series & CCS and things worked smoothly. As you mentioned, they don't support USB 2.0 so my question was, is there some interface chip that converts to USB 2.0 high speed and supports fast bulk transfers?
If you can estimate what will be the bottleneck and what throughput I can expect, that would be great. I see the dspics go up to 70-100MIPS (not sure they are all supported by CCS). |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9182 Location: Greensville,Ontario
|
|
Posted: Thu Oct 19, 2023 5:10 pm |
|
|
something like the 'CP2102' USB2.0 <> TTL modules might work for you ?? They're $5 a pop, can be 3 or 5v. used them for years but honestly never worried about speed just that they connected to PC that don't have real comports in them ! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19391
|
|
Posted: Fri Oct 20, 2023 3:53 am |
|
|
Problem still not answered is where this data is gong to go to or come from?.
Simply fetching a byte from an external memory takes time. If wired
really carefully you can use DMA, but this would then have to be to the
processors memory. Then a second DMA transfer would be needed to
the external port to feed the USB. The time involved for all this takes the
top speed way down.....
You could interface to a device like the FT120T. 8bit port plus chip select,
DMA and read/write controls. You can use the ping/pong buffers on this.
Potentially this could transfer a small block from the RAM of the PIC.
You'd still only get to about 1MB/sec, which the PIC with careful programming can already do.
I cannot honestly see any 8/16 bit PIC being able to prepare and send or
receive data faster than it can currently be done on the existing interface....
I can send 0.5MB files to a fast PC in under half a second from the PIC
using an isochronous USB transfer. The limit is how fast I can actually
read the data into the PIC's memory. |
|
|
guy
Joined: 21 Oct 2005 Posts: 291
|
|
Posted: Fri Oct 20, 2023 6:30 am |
|
|
The application is not a secret... I intend to read digital I/Os and fast internal/external ADCs and transmit them to a PC. There is no specific target bandwidth at the moment. In the past I used on-the-fly basic data compression which greatly improved speed but this is not always possible.
Take this beast for example: dsPIC33CK256MC506 - supported by CCS (let me know if have a status update - stable?), 100MIPS, A/D 3.5MSPS@12bits, and 20 multiplexed channels. With DMA+ping pong buffers+flow control and a touch of assembly code if required I believe I need the higher transfer rates...
CP2102N supports UART 3Mbaud (~300KB/sec), still not USB High Speed but not too bad.
If you have faster options please share them.
Thanks! |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9182 Location: Greensville,Ontario
|
|
Posted: Fri Oct 20, 2023 7:05 am |
|
|
hmm, looked and found the CP2104. Says it's FULL speed, USB2.0. several versions, I presume different FIFO buffers ?
I know in the past, it was better for me to use an external USB<>TTL module than the internal in the '4550'. Saved a lot of code space( USB driver), easy connections and cheap(added $1 per project) |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19391
|
|
Posted: Fri Oct 20, 2023 8:04 am |
|
|
You are still an order of magnitude short on the performance needed
with the CP210x.
If you actually ran the ADC at 3.5meg samples per second, you would be
generating data at 42Mbps. Over ten times faster that the CP210x manages.
The USB interface this supports is identical to the PIC. So 64 byte buffers
and maximum 12Mbps. You need to be looking at an interface with larger
buffers and supporting FS mode to actually get beyond the rate that the
PIC natively supports. Also be very aware that often the PC itself will
become the limiting factor once you start to get to these sort of rates.
You can interface to the parallel connection on a FT2232H, and potentially
do small bursts at up to 8Mbps. Still only a quarter of what you potentially
need. Go to a USB3 to parallel interface, like the FT600Q, and use a 16bit
port to talk to this, and you could potentially get to the sort of rates
you'd need.
Also you need to be aware you will not get to 3.25Msamples/sec. This
is a maximum, and only achievable if the clock is selected to be an exact
division of the time needed. This sample rate is only achievable using the
8bit resolution mode, and with a very low impedance source. The quoted
maximum throughput in 12bit mode is 2.7MS/sec, and in fact you will
be lucky to get even 2M samples/sec. in a real system.
Last edited by Ttelmah on Sun Oct 22, 2023 1:48 am; edited 1 time in total |
|
|
guy
Joined: 21 Oct 2005 Posts: 291
|
|
Posted: Sun Oct 22, 2023 1:47 am |
|
|
Thank you both, esp. for reminding me of FTDI. They have a wide range of USB solutions incl. High Speed and USB 3.0 . Just what I needed! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19391
|
|
Posted: Sun Oct 22, 2023 1:49 am |
|
|
Be aware though (as I have just modified my post to say), you will _not_
get 3.5MS/sec. This is only available in 8bit mode. |
|
|
guy
Joined: 21 Oct 2005 Posts: 291
|
|
Posted: Sun Oct 22, 2023 2:23 am |
|
|
Quote: | Be aware though (as I have just modified my post to say), you will _not_
get 3.5MS/sec. This is only available in 8bit mode. |
Duly noted. This is an early stage of development and I just want to know I have some solution for the fast comm. There will always be overhead and compromises, we take this into account.
Any tips on dsPIC33CK256MC506 and the like in general, and specifically with CCS ? Will it work out of the box like the previous experience I had with the dsPIC33 series? |
|
|
newguy
Joined: 24 Jun 2004 Posts: 1903
|
|
Posted: Sun Oct 22, 2023 9:57 am |
|
|
5.116 has the MP part in the devices folder, but not the MC part.
That processor looks to be relatively new, judging from the copyright date on its data sheet. My concern here is unknown errata biting you.
Anything the MC part has which the MP doesn't can be compensated for by writing your own low level (register setting) protocol. I've used dsPICs in the past quite a number of times and they just work, similar to any of their 8 bit brethren. The only minor difference comes down to interrupt priority and DMA, which not many (if any) 8 bit PICs have. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19391
|
|
Posted: Mon Oct 23, 2023 1:41 am |
|
|
Step back.
The MC releases of that chip have only just started to be supported by the
compiler. you could ask CCS, and they will probably be able to supply a 'beta'
library for these, but expect there to be some issues. As Newguy says you
also face the issue of effectively being a beta tester for the chip as well as
the compiler.
Consider an alternative approach. The fastest chips for doing two jobs like
this (so sampling and sending), are the multi-core units. More complex to
code, but you can have the secondary core actually retrieving and storing
data while the main core organises and transfers this,
On the fastest 33CH units you have a 100MIPS on the secondary core,
and 90MIPS on the primary. Nearly doubling the available processor
power. The ADC sample rates available are the same as the
dsPIC33CK256MC506 you are looking at. |
|
|
dyeatman
Joined: 06 Sep 2003 Posts: 1925 Location: Norman, OK
|
|
Posted: Mon Oct 23, 2023 5:29 am |
|
|
I am a real fan of the 33CH PICs.
It was a little work to set up two ICD-64s and get things ready to debug (dual
terminal sessions etc), but the twin CPUs are really nice and passing data
between them via the MSI works nicely once you get it working (there
are some options here to consider). I typically use the secondary processor for
display and I/O (switch/indicator control) which offloads the main processor.
I ended up using a 32inch monitor to get both compiler debug sessions
side by side along with the associated terminal output windows under them. _________________ Google and Forum Search are some of your best tools!!!! |
|
|
|