- Hacking U3 USB Drives
Updates! (latest ones first)
May 29, 2011:
While this was the first information available on the public Internet regarding the modification of U3 drives, 5 years later, it isn’t exactly the freshest information on it. I just got this comment in my mail:
Please take the Hacking U3 USB Drives section offline or edit it, it’s full of crap (you only need the u3-tool.exe) – it wastes people’s time, moreover, you’re pointing to a trojan-containing website (hxxp://www.GuidoZ.com/U3/), and down below (!!!) the post there’s the warning…
If you’re interested in modifying your U3 drive, Tomas is absolutely right, go with U3-tool. I don’t agree that this page is “crap” or “wastes people’s time”, though, and it will remain up, if for no other reason than to document how this was originally done.
As for the stuff in comments, I haven’t verified whether or not GuidoZ’s software contains trojans or not. Some say it does, and he claims that it doesn’t. To be on the safe side, I’ll remove the links, and folks can take a look at it if they want.
October 27th, 2006:
New for July 20th from an anonymous source:
U3 and the hardware sellers are trying to agree on how to keep the users’ data safe during manipulation, like perhaps enable locking of at least one partition from being messed with. Once agreed, they consider giving away a tool that will enable a limited set of smarter manipulations on the device.
The tools for full repartitioning are going to be kept in house for security reasons (so a plugged key cannot be scratched by malware on the host). Such tools are still only made available to vendors.
(My personal opinion as a computer guy has always been the same – security by obscurity never holds for too long…)
I have another report that after running U3-Uninstaller.exe,
the drive was no longer recognized by LPInstaller.exe. So please don’t
attempt this unless you’ve got a quick and easy way of getting a replacement,
or if you’re just experimenting before wiping out U3 anyway, or if you’re feeling
particularly adventurous. GrangerX verified that he was still able to install after
uninstalling and provided the following notes (also note the URL for the official U3
The U3 Drive i'm using is: SanDisk Cruzer(R) Micro USB Flash Drive SDCZ6-512-A10 UPC: 6 19659 02536 6 (serial number censored) My OS is WinXP SP2, with all but the latest Windows Updates. The PC is a Via Chipset Athlon (Sempron?) Socket462 freebie from the weekly Fry's "buy a CPU, get a motherboard effectively free" deal. The utilities I used had the following MD5s: 352bca7784d8dc68503379ff8cf46700 *u3_uninstall.exe #u3 branded, from http://www.u3.com/uninstall 3f8ea63524f0c8339c34c6851f6ae8a6 *U3_Uninstaller.exe #geeksquad-branded, from ... someplace on the internet bc7c03b841864bb9ce30dd5429359cdd *cruzer-autorun.iso 36b872f94e88d9bbf266200c193e50f4 *LPInstaller.exe After running the uninstaller (and removal, re-insertion of the drive), the CD drive portion disappeared. The RemovableDisk partition size increased by the 6MB. After running the installer, which didn't seem to require re-insertion of the drive, the U3-CD-Partition reappeared, and the RemovableDisk was the normal (-6MB) Size.
GrangerX, email@example.com, wrote in with the following very
The utility “LPInstaller.exe” seems to be able to download two
different ISOs, one with autorun, one without (at least the URLs were
in the file, so I went ahead and grabbed both). Also, if you put the
ISOs in the same directory as the LPInstaller.exe, it seems to use
them from there instead of trying to download them, which is faster,
and doesn’t require apache usage.
There also exists a much harder to find executable, called
“U3-Uninstaller.exe”, that disables the CD “domain” (i think is U3′s internal
terminology for the different areas on the drive (I *wish* they’d
release the darn HDK)) by (apparently, at least) burning the
“dummy.iso” file into that domain, and then hiding/disabling the
domain entirely (free space before was: 506,683,392 ; free space after
was: 513,310,720 ). [Yes, several of their internal (debugging?)
messages in the EXE files and their SDK docs mention "Burning" the CD
ISO, so I guess it really *is* a burner, of sorts. :-p ]
My end goal is to be able to use a larger-than-6MB iso, which
currently, I haven’t been able to do. But, I have verified that the
two utilities (“LPInstaller.exe” and “U3-Uninstaller.exe” are
repeatably usable to remove/re-add the U3 functionality, so it should
be safe for people to experiment with, if they have both utils (Note:
I’ve heard from others that this does not work, so be cautious). If
you try to trick it into using a larger ISO, both utilities fail, but
it doesn’t seem to cause trouble once you run the utility as they
intended. I can add or get rid of the U3 functionality as needed now,
My hope is that there’s an offset in the LPInstaller.exe that one
could patch and it would create a differently-sized ISO area, which
could allow more clever things to be done with the devices.
Anyway, thanks for getting things started. Hopefully they’ll release
at least the oft-referenced “U3 Tool” to allow users to modify their
drives, but until then, it’s fun to hack on.
So a lot of the steps I’ve outlined below are actually a bit more
complicated than you really need to do. The Sandisk installer looks in the
local directory for ISOs first, so you won’t have to spoof their website
A spy came in from the cold to write this (completely unverified,
of course, but feels right):
:snip snip:…new controller at the hardware level, where it supports 24 more USB commands than the regular controllers, etc. apparently dividing it up to “memory domains” is dynamic and there are tools out there (windows only) for the manufacturers to resize the virtual CD and the main partition.:snip:
U3 is a platform for developing applications that install to
and execute from USB flash drives. It provides these
applications a means to execute, read, write and clean up after
themselves once the drive is removed. I haven’t actually used
any U3 apps yet, but having bought a “U3 Smart” drive at
OfficeMax (the SanDisk Cruzer Micro 512M), I became interested
in the unique way these U3 drives present themselves as two
separate disks, so that the U3 software is write-protect and can
auto-run on Windows machines. This page documents my attempts
at changing the U3 drive to modify the write-protected partition
and control the autorun feature.
This information is based on the U3 Smart SanDisk Cruzer Micro
512M, and while I’ve taken a lot of care in my procedures here
(I don’t want to buy another drive if I brick this one either!),
I can’t guarantee that it’ll work out so well for you. This
information is immediately applicable to the Cruzer Micro 512M,
and probably works for other Cruzer disks, but probably does not
work on other U3 Smart disks. It should get you looking in the
right direction though.
Two Drives in One!
The first thing you’ll notice when you plug in one of these
drives is that it shows up as two different disks: A USB CDROM
with the title “U3 System” that takes the first available drive
letter (E: in my case), and a USB Removable Disk that takes the
next drive letter (F:).
More detailed information can be found when you plug it in
under Linux and take a look at dmesg:
usb 1-1: new full speed USB device using uhci_hcd and address 6 usb 1-1: configuration #1 chosen from 1 choice scsi7 : SCSI emulation for USB Mass Storage devices usb-storage: device found at 6 usb-storage: waiting for device to settle before scanning Vendor: SanDisk Model: U3 Cruzer Micro Rev: 2.15 Type: Direct-Access ANSI SCSI revision: 02 SCSI device sdb: 990865 512-byte hdwr sectors (507 MB) sdb: Write Protect is off sdb: Mode Sense: 03 00 00 00 sdb: assuming drive cache: write through SCSI device sdb: 990865 512-byte hdwr sectors (507 MB) sdb: Write Protect is off sdb: Mode Sense: 03 00 00 00 sdb: assuming drive cache: write through sdb: sdb1 sd 7:0:0:0: Attached scsi removable disk sdb sd 7:0:0:0: Attached scsi generic sg1 type 0 Vendor: SanDisk Model: U3 Cruzer Micro Rev: 2.15 Type: CD-ROM ANSI SCSI revision: 02 sr0: scsi3-mmc drive: 8x/40x writer xa/form2 cdda tray sr 7:0:0:1: Attached scsi CD-ROM sr0 sr 7:0:0:1: Attached scsi generic sg2 type 5 usb-storage: device scan complete
Note that Linux seems to think the CD drive is a writer.
Working on the side of caution against hosing the drive, I have
not attempted to “burn” to this drive with cdrecord or k3b or
anything. This is doubly true now that I have found a safe way
of changing what’s on this part of the disk, but if you want to
give it a shot (and have a spare Cruzer to try it out on), email
me and let me know what happens . There’s a pretty good
possibility that it’s not identifying the drive correctly.
The CDROM that isn’t
When you mount the CD drive, there’s three files waiting for
you: LaunchPad.zip and LaunchU3.exe (containing the U3
software), and an autorun.inf that executes LaunchU3.exe
whenever you plug in the drive. Here’s the contents of the
autorun.inf after running the latest updates from SanDisk (More
on this later):
[AutoRun] open=LaunchU3.exe -a icon=LaunchU3.exe,0 [Definitions] Launchpad=LaunchPad.exe Vtype=1 [CopyFiles] FileNumber=1 File1=LaunchPad.zip [Update] URL=http://u3.sandisk.com/download/lp_installer.asp?custom=220.127.116.11&brand=cruzer [Comment] brand=cruzer
So, we see that it automatically runs LaunchU3.exe. There’s
a few other bits of information in this file that are handy too,
especially the [Update] section, which wasn’t there before the
built-in updating feature of U3 was executed…
Updating means that something can write to it at least
Let’s visit the SanDisk updating URL in Firefox:
Whups, heh, let’s view the source…
There we go. A URL for a stand-alone installer. When you
download this installer, you’ll notice that it’s only a megabyte
or so, while the CDROM drive is between 5 and 6 megabytes. This
is because the LPInstaller.exe downloads the new ISO file for
the CDROM from the SanDisk website. Let’s fire up Ethereal,
start sniffing, and run the installer to figure out where it’s
getting the ISO from:
From here, you can download the ISO with wget or a web browser
or anything. Mount the ISO and you’ll see the same files (or
potentially newer versions) as you would on the drive’s CDROM.
Make your own ISO, keeping within size limitations. Regarding
this, although the ISO I downloaded from the SanDisk site was
5,752,832 bytes, the size of the CDROM images I get when I use
dd straight from the block device is always 6,291,456 bytes.
It appears the ISO is written into this 6,291,456 byte chunk,
with the remainder padded out with zeros.
Double-plus-make-sure that the ISO you create
is a bit less than 6,291,456 bytes. I don’t know what
will happen if you go over that amount, but there’s a
very good chance that it isn’t pleasant.
Some good ideas for what you could do with the fake CDROM
- Do away with the U3 software entirely
- Auto-run your own programs/scripts
sneakiness without an iPod
- Store files that you want relatively strongly
You can create ISO files using mkisofs from cdrtools, or any
burning software you would like to use.
Once you have an ISO created, you’ll need to set up a web server
to mimic the update site. Here, I’ve installed Apache onto the
windows machine running the installer, recreated the
directory structure leading up to the ISO, and placed the
custom ISO there with the correct name:
Next, change the c:Windowssystem32driversetchosts file
to point u3.sandisk.com to the correct ip address, in this case,
the local host:
127.0.0.1 localhost u3.sandisk.com
Now that everything’s set up, you can run the
LPInstaller.exe, and let it download and install the ISO you
want to the disk. If everything goes well, the next time you
mount the disk, it should be set up how you wanted it.
Taking it further
The above works for SanDisk Cruzers, so if you’re feeling
adventurous, you may be able to develop a similar procedure for
other U3 Smart disks. It would also be nice to figure out how
the installer is talking to the disk, so that a program could be
created to let us more directly manipulate the disk, without
aving to spoof a web server.