Slashdot Mirror


USB Development Tools for Embedded Devices?

engywook asks: "I am thinking about putting a USB interface onto a real-time (home-brew kernel) embedded device, (naturally) with the intent that it talk to another device. I am thinking that it would be very useful to be able to monitor the USB traffic between my device and the other device, and between that other device and (say) a PC that already knows how to talk to it. Looking around, it seems that this capability is available, but at prices in the US$10K and up realm, which is a lot more than I can afford. I am looking for pointers to tools that would accomplish this for much less money. Any ideas would be appreciated! Thanks!"

16 of 31 comments (clear)

  1. Linux Journal #7605 by eburrows · · Score: 5, Informative

    Last month's Linux Journal has an article titled "Snooping the USB Data Stream", where the author talks about exactly what you want. He talks about using Linux to monitor the data, but you can still use this method to monitor Windows talking to your device by running Windows in VMware.

    1. Re:Linux Journal #7605 by Anonymous Coward · · Score: 5, Informative

      I was going to mod you up, but I thought I'd help out the lazy instead: link to the article. :-)

  2. Cypress USB Kit by codexus · · Score: 4, Insightful

    I bought a Cypress USB kit a few years ago, it's quite cool. Is that company still in business? Their website seems to be gone.

    --
    True warriors use the Klingon Google
    1. Re:Cypress USB Kit by codexus · · Score: 4, Informative

      Actually it seems I was wrong, now their website is working and they still have affordable USB kits: http://www.cypress.com/

      --
      True warriors use the Klingon Google
  3. any linux-based usb-host-capable dev. board. by torpor · · Score: 4, Interesting


    there are tons out there, cheap. ARM, even ... google is your friend (so is linuxdevices...) they can be had for $99 or so, or free, in some cases, if you know your vendors ...

    that, and the linux kernel, is all you need to debug USB.

    --
    ; -- the corruption of government starts with its secrets. a truly free people keep no secrets. --
  4. Terrible. F by johnjones · · Score: 4, Informative

    your using a custom kernel so
    look at netbsd USB stack and see howto put that into your src

    you can dump out the usb traffic under netbsd look at the src

    if you want to reverse engineer a windows driver you can use VMware on linux and dump the traffic
    http://www.linuxjournal.com/article.php?s id=7582

    or

    insert a windows driver (that dumps usb traffic) and look at the dumps but this could taint the results see http://usbsnoop.sourceforge.net/

    or

    buy a hardware that sits inbetween the cables for $1000 see http://www.usbdeveloper.com/USBViewer/usbview.htm

    really I would look at http://www.fsmlabs.com/ as you can run real time tasks and use the linux drivers for usb because that part sure as hell is not going to be real time...

    it you have failed to do ANY RESEARCH at all

    Terrible. F

    regards

    john jones

  5. FPGA by psyconaut · · Score: 5, Informative

    Assuming that you're happy with USB1.1 and below, one approach is to use a low-cost FPGA (Altera Cyclones are great for this, and a suitable one is $20).

    Zip over to opencores.org, grab the USB 1.x MAC and PHY as a starting point....and you can start to build your own hardware USB sniffer.

    The beauty of this approach is that you can do *proper* sniffing type activities such as microsecond time stamping of samples, which gets (*ahem*) tricky doing things in the software domain under Linux or Windows.

    If you just want to see a vague picture of the wire, you can stick to operating system level sniffing as others have pointed out.

    -psy

  6. PC tools... by brianjcain · · Score: 4, Informative

    Seek out USB Snoop. You can monitor the goings-on between Windows and the USB device's driver. This probably won't replace a hardware USB debugger, but it's a good start.

    Your usage description seems to advocate a more node-to-node based relationship between devices on the bus. An interface like firewire seems much better suited to your application than USB (master/slave). Though I suppose it could be considerably more complex to implement?

    If you still need a hardware analyzer, this one looks more affordable.

    1. Re:PC tools... by engywook · · Score: 3, Insightful

      Yes, I'd also found USB Snoop. I think that it also may be of use in the early stages.

      You are right that there is a node=to-node relationship. In fact, I expect that my device and the other will be the only two connected at any given time. Unfortunately, I don't get to pick the interface. The other device already exists, at it is already USB.

      BTW, the only reason it is USB instead of RS-232 is that "someone" convinced (nearly) all the PC hardware manufacturers that RS-232 was Evil and USB was Good. So, PCs no longer have RS-232 ports. So, the manufacturers of the device I have to talk to are discontinuing their RS-232 versions and coming out with USB versions. So, we have to talk USB, too, even though the RS-232 stuff was working just fine. sigh.

      --
      "This signature quote intentionally left blank"
  7. FTDI transceiver by oojah · · Score: 3, Informative

    Use one of the FTDI USB tranceivers instead of trying to reinvent the wheel.

    http://www.ftdichip.com

    They make usb chips with serial interface (drop in replacement for an RS232 transceiver) or an 8-bit parallel interface. Comes with drivers for windows and there are drivers in the kernel already.

    Only does up to 12Mbit/s though.

    Cheers,

    Roger

    --
    Do you have any better hostages?
    1. Re:FTDI transceiver by psyconaut · · Score: 2, Informative

      AFAIK, they don't let you sniff the wire.

      -psy

  8. Do you need it? by Solder+Fumes · · Score: 2, Informative

    If all you want to do is get your USB device working, I'm not so sure you really need this capability. USB analyzers are primarily useful for testing the device for compliance with USB signal standards. That way, you only have to get your device compliance-tested once.

    I've developed a few USB devices, and frankly I haven't needed an analyzer just to get the device to work. If something's happening you don't understand, set breakpoints or toggle some status LEDs to see where you are in the firmware. That, and software-based sniffing for the occasional sanity check, has been all I really needed.

    Learn the standard USB device types, and if you try to reverse-engineer a proprietary device, stock up on Advil.

  9. Another angle by xenocide2 · · Score: 2, Insightful

    I've seen a lot of USB snoop suggestions, which are a fine solution. But if you don't find that acceptable, I'd suggest looking into a Controller Area Network(CAN) module instead. You can find PC adaptors for this very cheaply, sometimes as little as 20 dollars. It's specifically designed for systems where you know exactly the kind of communications that will go on, and who's more important than who. It's used in a lot of automotive situations, though there's a growing group that doesn't think it's safe enough.

    --
    I Browse at +4 Flamebait

    Open Source Sysadmin

  10. Three things for you to look at by raider_red · · Score: 3, Informative

    First, get a copy of USB Complete. This book provides a good reference to the USB interface, and is oriented to hardware design. It also gives a lot of useful advice on picking a USB controller.

    Second, visit the Silicon labs web site. They sell a development board for their USB enabled Microcontroller which includes all cables, an assembler, and a bunch of utilities and examples. They also include a development kit for implementing the Windows drivers for your new device.

    Finally, there's a utility available on the web called Snoopy which will let you capture USB packets.

    --
    It's good to use your head, but not as a battering ram.
  11. Circuit Cellar by FrankSchwab · · Score: 5, Informative
    CircuitCellar just happens to have one part of a multi-part article on implementing a USB device up on their website here (Page 7, with other references). You'll probably have to check out your local university library or order backissues to get all the parts. They've had 3 or 4 similar articles over the last 5 years.

    /frank

    --
    And the worms ate into his brain.
  12. Try Belkin's USB to serial converters. by Futurepower(R) · · Score: 2, Informative


    I've had success with USB to serial converters. I bought a bunch of them for $12.00 apiece from Belkin, for example. Email me if you want more info.