Booting from a USB Thumbdrive

From AwkwardTV
Revision as of 02:44, 24 August 2007 by Lj0Wc2 (talk | contribs)
Jump to: navigation, search
regionale puglia toshiba 232 radiocompass pescherie a roma oman aspettando godot samuel beckett libri unite it chickenboy chucky odissea per ragazzi tannoy fusion 3 fiabe canzoncine filastrocche kenwood 1000 ultimi cellulari samsung giochi con pompini mp3 usb 1 gb lettori mp3 con hd jil sander sun canon ef 55 200 head liquidmetal doctorcito com efialtes pinko fantasia maroon 5 this love remix bmw cabrio cronaca regionale opel tigra kings of convenience hub passivo spirit packard bell www infonavit peluche mucca sharm el sheik testi notredame cocciante www icooloader password racconti incinte letojanni passat variant leisure grand thef auto gengis kan onde di alex baroni mustek mdc 4000 ufficio portogruaro donne da vendere lg rz-42px11 ancora indizi sul prezzo della playstation 3 la gabbia di ferro visual studio tools per office god of war raccolto in fotografia silico- nicolenarain www webmail uiowa edu www gentemotori it code srg pop www econ univ ts it home theatre con ricevitore digitale sindy loper altalena fisher finanziamento livigno discoteche latino americano video piedi quel dolce corpo di fiona l 400 whole lotta love siti porno titty al arrembaggio kill bill foto bridal chorus parcometro aspesi piumino i sopravvissuti delle ande server proliant hp pergamena india.arie. live in brazil lcd 30 tv e monitor law - der. la prima serie webcam typhoon goldeneye al servizio takes 2 to tango gli avventurieri del pianeta terra gioco giocare pocket 720 ivan i defin scambista egadi i-mate sp3 bluetooth ginnastica in dvd se dio vorra ragazzo madrid hp italia joystick cyborg evo force giochi da giocare golf gpl g3 live in concert pantaloni nike sport donna abbigliamento sassarini roma phuket ciesse flower olimpus scheda xd 1gb dv firewire slk kompressor fix mx immagini di paola perego athlon fx uno nessuno centomila bernard herman u3 cicas gps bluetooth ricevitore lettore divx portatile daewoo croazzia ragazzo nova milanese danilo riccardi video forza chiara perugia mutui net condizionatori lg 12000btu mju 400 olympus amoy raptor western digital hard disk e maxtor diamondmax 10 200gb spartiti in polifonia fontlab american me la bisarca abbigliamento sportivo basket e alla fine arriva polly hard disk 200 gb esterni yoky lettore di schede sd lg frigorifero sul ponte dei sospiri princess macchina pane cassol jennifer lopez concert videocamera sony 403 playstation pad casevacanze locandine walt disney melodica napoletana milano mappa albergo berlino centro polo ralph lauren manica corta trust md 3100 router adsl vpn fotografia 78 bit rifugio segreto uccisione 2 simone maple leaf rag toto copertine film suona fratello scarpa volley computer p4 winnie the pooh gadget ems lisa jerrard ideogramma i 2 fanta genitori unicows lg u 8100 giovanna rei sexy riego gentleman reservas ecologicas texas john contro geronimo i clandestino tre donne sono troppe offerta 2 comune di villa seta privacy avvocato chattando con ragazzi franchising abbigliamento trobles krazy kong liquidi di figa tutte le donne del re mp3 usb sd godzilla - godzilla il re dei mostri alta definizione plasma lallegra compagnia massaggiatrici varese universum moto gp 2005 amplificatori diffusori scarpe paciotti www rosella ferrari it marones robin williams. special collectors edition erica ceramiche navigon 4 dmr e65 panasonic pesca ps2 videogiochi la altagracia il tuo nome in maiuscolo vgn fs215m tre allegri ragazzi morti occhi bassi zainetto toshiba bon prix lettore mp3 con hdd 20 gb testi di gianluca grignani


Not Patchstick

This page is not about Patchstick. I repeat: this page is not about Patchstick. This page just goes into detail about the layout of the partitioning table of a possible USB thumbdrive, which might be used for building something like Patchstick.

The image linked in this article is an empty image. No files. Really.

You have been warned.

A bit of info on how the boot process works

Background reading:

If the system is booted with the "Menu" and "Minus" keys on the remote held down, it checks for a FAT32 or HFS partition with a Partition Type of {5265636F-7665-11AA-AA11-00306543ECAC}, first on a USB storage device, then on the internal HDD. If such a partition is found, it's mounted and a file called "boot.efi" is read from the root folder and executed.

A bit of info about the image

It's simple enough to create a GPT on a USB thumbdrive with the required attributes. I used GNU Parted on Linux, and I'm sure equivalent tools exist for Mac and Windows. The tricky part is making the image in such a way that it'll boot in the AppleTV and be easy to deal with if you don't have a Mac handy. The latter requirement basically rules out HFS/HFS , since Linux support is spotty and Windows support is non-existant, so I chose to use FAT32.

Windows has had some level of support for GPT disks for some time now, but it uses the Partition Type indicator to determine the type of the filesystem. Since we have to set this to the value for a recovery partition, Windows will refuse to recognize the partition as FAT32, although Linux will happily mount it anyways.

My first thought was to get rid of the "Protective MBR" partition table that GPT uses to hide itself from older partitioning tools and replace it with a valid MBR partition table that points to the FAT32 partition. Thus, the drive would have two partition tables, each pointing to the same partition. With this in place, the thumbdrive was mountable both in Linux and Windows, but the AppleTV apparently checks for the 0xEE partition in the MBR before trying to use the GPT.

In the end, I was able to create a MBR that contains the 0xEE partition required to get the AppleTV to load the GPT, but instead of setting the protective partition to fill the disk, I made it very small, then added a second partition in the MBR's remaining space that points to the FAT32 partition. Now, it's visible to Windows (MBR table), Linux (either table), and the AppleTV (GPT). You should be able to plug a thumbdrive initialized with this image into any Windows box (I've only tested with Vista Ultimate 64-bit) and copy over the necessary files from the AppleTV recovery partition (boot.efi,, BootLogo.png, and mach_kernel.prelink). After that, you can plug the thumbdrive into the AppleTV and reboot it while holding down "Menu" and "Minus" on the remote to boot from the thumbdrive.

Note that as is, the recovery partition image won't boot completely from USB, since the kernel basically cuts its own head off when it disables USB.

The image itself (sized for 256MB Flash)

The original image was posted as a base-64 text chunk within this page, it is now mirrored below. The complete image is only about 6K compressed. All you need to do is decompress the image, then write it to a storage device of your choice.

Note: This is a raw disk image, and will expand to 257,949,696 bytes. Your storage device will have to meet this minimum requirement to use this particular image.

Writing the Image

Mac OS X and other *NIX or *NIX like Operating Systems

You must have a Memory stick larger than 512MB of free post formated space for this to work.

Insert your storage device / thumb-drive / USB stick but don't mount it. If your OS automounts the image (like OS X does) you'll need to unmount before you write to it.

$ mount
/dev/disk1s1 on /Volumes/UNTITLED (local, nodev, nosuid) <-- mounted partition on the thumb drive.  /dev/disk1 would be the thumbdrive itself.  See note below!

Unmount (as root) For those using OS X gui, find NetInfo Manager in the Utilities folder, click "Security" at the top menu, then "Authenticate." A dialogue box will pop up which asks for the administrator's short name and password. Notice the command for un-mounting is UMOUNT with no 'n' after the 'U.' This is the command, not a typo. Unmount with:-

 # umount /Volumes/UNTITLED 

then use dd to write the image to the storage device (change /dev/disk1 to be the device that corresponds to your OS and device).

 $ dd if=Hybrid.img of=/dev/disk1 bs=1m

Important Note: You want to write to the device that correponds to the entire thumbdrive - not one of its partitions. If you write the image to an existing partition, the all-important partition tables won't be written properly. On Mac OS / Darwin, this will be something like /dev/diskX rather than dev/diskXs1. On Linux, the device will probably be /dev/sdX for a USB device. (Note that SATA hard drives will probably also appear as /dev/sdX - use fdisk -l /dev/sdX to make sure you have the right device before writing to it!)

If your storage device has a pretty LED you'll see some activity, once finished you'll see something like:

503808 0 records in
503808 0 records out
257949696 bytes transferred in 439.220493 secs (587290 bytes/sec)

The drive will more than likely mount once the above process is complete - unmount it and proceed with your install on the Apple TV.


Download dd for Windows and follow the steps above for writing the image. You don't need to worry about the unmounting part. Windows device identifiers are quite different from BSD / Linux identifiers, so look at the examples on the linked page for how to write to a USB Mass Storage device.

With dd.exe and the Hybrid.img file in the same folder type the following command to find out the name of your USB drive.

dd --list

You should see a bunch of output similiar to:

 link to \\?\Device\HarddiskVolume1
 fixed media
 Mounted on \\.\c:

 link to \\?\Device\CdRom0 CD-ROM
 Mounted on \\.\r:
 link to \\?\Device\Harddisk1\DP(1)0-0 3 removable media
 Mounted on \\.\d:

We are interested in the device mounted to where your USB drive is (d: in this case).

We then do:

dd if=Hybrid.img of=\\?\Device\Harddisk1\Partition0 bs=1M --size --progress

The important part is writing to the Partition0 part of the drive.

You could also just download a Linux LiveCD.

Download the image (Mirrors)

Here - dobedobedoh

Here - anourkey

Here - Galphanet (Swiss server)

Here (choose right click, save as) - MrZarquon

Here (choose right Click Save As), please be gentle on this server, use as a last resort!

MD5: a00685206de5cf5a313ec62594d2ff9e Hybrid.img.bz2 (compressed)

MD5: 1533fdfb2503851a545cf1955c2daea6 Hybrid.img (uncompressed)