Simple USB Storage Read/Write?

Question about which tools to use, bugs, the best way to implement a function, etc should go here. Don't forget to see if your question is answered in the wiki first! When in doubt post here.
geppyfx
Member
Member
Posts: 87
Joined: Tue Apr 28, 2009 4:58 pm

Re: Simple USB Storage Read/Write?

Post by geppyfx »

earlz wrote: There so should be some community made, BSD or PD licensed USB drivers that are easily adaptable and capable of making the equivalent of a ugen device(generic usb stream device) with only a few lines of code and a plugin PCI driver..
that means copying old bugs and maybe poor desing

Mr/Ms xvedejas there are no handouts once you are past bootloader and entering protected mode. If there are any - the handouts will have their own bugs.

use BIOS(with its own bugs) if you need it done simple way
maybe you should do sata first, a lot less reading
User avatar
Combuster
Member
Member
Posts: 9301
Joined: Wed Oct 18, 2006 3:45 am
Libera.chat IRC: [com]buster
Location: On the balcony, where I can actually keep 1½m distance
Contact:

Re: Simple USB Storage Read/Write?

Post by Combuster »

And don't try to expect "simple" code when dealing with a device that isn't simple at all...
"Certainly avoid yourself. He is a newbie and might not realize it. You'll hate his code deeply a few years down the road." - Sortie
[ My OS ] [ VDisk/SFS ]
madeofstaples
Member
Member
Posts: 204
Joined: Thu Apr 12, 2007 8:15 am
Location: Michigan

Re: Simple USB Storage Read/Write?

Post by madeofstaples »

xvedejas wrote:No source code anyone? The Linux kernel isn't exactly the simplest piece of software ever written...
I don't think you understand what you're asking. If you consider the bare minimum required to "simply" read/write a USB mass storage class device, the list might look like this:
  • PCI enumeration, or, if applicable, the bootloader could ask the bios for the bus, device, and function numbers of the host controller (assuming the BIOS booted from a USB drive). Either way, basic PCI configuration space access is necessary to determine the type of host controller, possibly modify the command register, and to find the BAR.
  • Reset the host controller
  • Initialize the host controller.
  • For each port that detects a device connected:
    • Assert a reset signal, wait, then deassert the reset signal.
    • Assign a unique address to the device via it's default control pipe (requires implementing control transfers).
    • Retrieve a device descriptor. This may indicate if the device is a mass storage class device, OR it may indicate that you need to:
      • Retrieve a configuration descriptor for each possible configuration
      • Examine all interface descriptors associated with any configuration to determine if any of them are mass storage class interfaces
    • Any device that is a mass storage class device should be flagged or somehow recorded for later use.
  • At this point you have a list of directly-connected USB drives.
  • For each such device, then, you must:
    • Set the configuration to whichever configuration implements the mass storage class interface
    • The protocol specified by the device/interface descriptor determines how to communicate with the device, you can probably assume, for simplicity, that this will indicate a SCSI protocol.
    • Then, using the appropriate endpoint numbers (indicated in the interface descriptor), you must execute bulk transfers which wrap around the appropriate protocol in order to communicate with the device. The protocol defines how to go about read/write operations.
And that's not including the possibility of accessing a USB drive connected to a USB hub...

If you're patient, I will cover many of these things in greater detail in the wiki.
Some people are offended by the verifiable truth; such people tend to remain blissfully unencumbered by fact.
If you are one of these people, my posts may cause considerable discomfort. Read at your own risk.
TomT
Member
Member
Posts: 42
Joined: Sat Mar 15, 2008 7:20 am
Location: Wisconsin, USA
Contact:

Re: Simple USB Storage Read/Write?

Post by TomT »

My OS has a protected mode driver for UHCI. This is the usb controller used on older computers with 2 usb ports on the back. Feel free to hack away. The folder /uhci contains about 20 files totaling 68,000 bytes of assembly code. Ive not attempted a driver for hard drives so not sure how much work that would be. There are other open source OS's with usb drivers. You just have to look.


I suggest downloading and studying the following:


For USB UHCI Universal Host Controller Driver Development:
*************************************************************************
[1] "Universal Serial Bus Mass Storage Class Bulk Only Transport", rev 1.0 Sept 1999 Usb Implementors Forum

[2] "Universal Serial Bus Specification", rev 1.1 1998 and rev 2.0, ch9 is most important

[3] Intel "82371AB PCI-ISA Xcelerator (PIIX4)" Controller Manual and "Universal Host Controller Interface (UHCI) Design Guide" rev 1.1, these are your hardware manuals

[4] "Working Draft American National Standard SCSI Block Commands (SBC-2)" Nov 2004 and the "SCSI Primary Commands (SPC-2)"

[5] "PCI Bios Spec" rev2.1

"Usb Simply Buffered Device Enumeration" and "Usb Simply Buffered Mass Storage Class - Bulk Only Transport" 2007 Shakthi Kannan, actual bytes from usb transactions

"USB Made Simple", web site with 7 part series.
"SnoopyPro" software for windows to view some usb transaction data.
LinuxBios usb_scsi_low.h
Beyond Logic "Usb in a Nutshell" excellent website
waste.org "PCI bus info and code from a programmers perspective"



TomT
http://code.google.com/p/tatos/
Post Reply