Difference between revisions of "USB flash installation media"

From ArchWiki
Jump to: navigation, search
(Undo revision 272930 by Qewlpal (talk) bad style; "your linux distro"?, "you can do so" what? the tip is about "check[ing] with lsblk that ...")
(See Also: update and add external resources, see also Talk:USB_Flash_Installation_Media#Graphical dd methods for Linux and Windows)
(35 intermediate revisions by 14 users not shown)
Line 11: Line 11:
 
[[zh-CN:USB Installation Media]]
 
[[zh-CN:USB Installation Media]]
 
[[zh-TW:USB Installation Media]]
 
[[zh-TW:USB Installation Media]]
{{Article summary start}}
+
{{Related articles start}}
{{Article summary text|Mutiplatform instructions on creating a bootable USB stick which can be used for installing Arch Linux, system maintenance or for recovery purposes.}}
+
{{Related|CD Burning}}
{{Article summary heading|Related}}
+
{{Related|Archiso}}
{{Article summary wiki|CD Burning}}
+
{{Related articles end}}
{{Article summary end}}
+
This page discusses various mutiplatform methods on how to create a Arch Linux Installer USB drive (also referred to as ''"flash drive", "USB stick", "USB key"'', etc) for booting in BIOS and UEFI systems. The result will be a LiveUSB (LiveCD-like) system that can be used for installing Arch Linux, system maintenance or for recovery purposes, and that, because of the nature of [[Wikipedia:SquashFS|SquashFS]], will discard all changes once the computer shuts down.
  
This page discusses various methods on how to write an Arch Linux release to a USB drive (also referred to as ''"flash drive", "USB stick", "USB key"'', etc). The result will be a LiveCD-like system (''"LiveUSB"'', if you will) that, because of the nature of [[Wikipedia:SquashFS|SquashFS]], will discard all changes once the computer shuts down.
+
If you would like to run a full install of Arch Linux from a USB drive (i.e. with persistent settings), see [[Installing Arch Linux on a USB key]]. If you would like to use your bootable Arch Linux USB stick as a rescue USB, see [[Change Root]].
  
If you would like to run a full install of Arch Linux from a USB drive (i.e. with persistent settings), see [[Installing Arch Linux on a USB key]].
+
== BIOS and UEFI Bootable USB ==
  
{{Note|For [[UEFI]] boot, create a bootable USB stick by following [[UEFI#Create_UEFI_bootable_USB_from_ISO|these]] instructions.}}
+
=== Using dd ===
 +
{{Note|This method is recommended due to its simplicity. If it does not work switch to the alternative method [[#Using manual formatting ]] below.}}
  
== On GNU/Linux ==
+
{{Warning|This will irrevocably destroy all data on {{ic|/dev/sd'''x'''}}.}}
  
=== Overwrite the USB drive ===
+
==== In GNU/Linux ====
  
{{Warning|This will irrevocably destroy all data on {{ic|/dev/sd'''x'''}}.}}
+
{{Tip|Check that the USB flash installation media is '''not''' mounted with {{ic|lsblk}}.}}
{{Warning|This method does not work with UEFI boot.}}
+
  
{{Tip|Check with {{ic|lsblk}} that the USB device is '''not''' mounted (i.e. listed but has no mountpoint), and use {{ic|/dev/sd'''x'''}} instead of {{ic|/dev/sd'''x1'''}}.
+
{{Note|Use {{ic|/dev/sd'''x'''}} instead of {{ic|/dev/sd'''x1'''}}, and adjust '''x''' to reflect the targeted device.}}
'''These are very common mistakes!'''}}
+
  
 
  # dd bs=4M if=/path/to/archlinux.iso of=/dev/sd'''x''' && sync
 
  # dd bs=4M if=/path/to/archlinux.iso of=/dev/sd'''x''' && sync
 +
 +
==== In Windows ====
 +
 +
===== Using Cygwin =====
 +
 +
Make sure your [http://www.cygwin.com/ Cygwin] installation contains the {{ic|dd}} package.
 +
 +
{{Tip|If you do not want to install Cygwin, you can download {{ic|dd}} for Windows from [http://www.chrysocome.net/dd here]. See the next section for more information.}}
 +
 +
Place your image file in your home directory:
 +
 +
C:\cygwin\home\John\
 +
 +
Run cygwin as administrator (required for cygwin to access hardware). To write to your USB drive use the following command:
 +
 +
dd if=image.iso of=\\.\[x]: bs=4M
 +
 +
where image.iso is the path to the iso image file within the {{ic|cygwin}} directory and {{ic|\\.\['''x''']}}: is your USB flash drive where '''x''' is the windows designated letter, e.g. {{ic|\\.\d:}}.
 +
 +
On Cygwin 6.0 find out the correct partition with:
 +
 +
cat /proc/partitions
 +
 +
and write the ISO image with the information from the output. Example:
 +
 +
{{Warning|This will irrevocably delete all files on your USB flash drive, so make sure you do not have any important files on the stick before doing this.}}
 +
 +
dd if=image.iso of=/dev/sdb bs=4M
 +
 +
===== dd for Windows =====
 +
 +
{{Note|Some users have an "isolinux.bin missing or corrupt" problem when booting the media with this method.}}
 +
 +
A GPL licensed dd version for Windows is available at http://www.chrysocome.net/dd. The advantage of this over Cygwin is a smaller download. Use it as shown in instructions for Cygwin above.
 +
 +
To begin, download the latest version of dd for Windows. Once downloaded, extract the archive's contents into Downloads or elsewhere.
 +
 +
Now, launch your {{ic|command prompt}} as an administrator. Next, change directory ({{ic|cd}}) into the Downloads directory.
 +
 +
If your Arch Linux ISO is elsewhere you may need to state the full path, for convenience you may wish to put the Arch Linux ISO into the same folder as the dd executable. The basic format of the command will look like this.
 +
 +
{{bc|<nowiki>dd if=archlinux-2013-XX-xx-dual.iso of=\\.\x: bs=4m</nowiki>}}
 +
{{Warning|This command will replace the drive's contents and its formatting with the ISO's. You will likely be unable to recover its contents in the event of an accidental copy. Be absolutely sure that you are directing dd to the correct drive before executing!}}
 +
Simply replace the various null spots (indicated by an "x") with the correct date and correct drive letter.
 +
 +
Here is a complete example.
 +
{{bc|<nowiki>dd if=ISOs\archlinux-2013.08.01-dual.iso of=\\.\d: bs=4M</nowiki>}}
 +
 +
==== In Mac OS X ====
 +
 +
To be able to use {{ic|dd}} on your USB device on a Mac you have to do some special maneuvers. First of all insert your usb device, OS X will automount it, and in {{ic|Terminal.app}} run:
 +
 +
$ diskutil list
 +
 +
Figure out what your USB device is called with {{ic|mount}} or {{ic|<nowiki>sudo dmesg | tail</nowiki>}} (e.g. {{ic|/dev/disk1}}) and unmount the partitions on the device (i.e., /dev/disk1s1) while keeping the device proper (i.e., /dev/disk1):
 +
 +
$ diskutil unmountDisk /dev/disk1
 +
 +
Now we can continue in accordance with the instructions above (but use {{ic|1=bs=8192}} if you are using the OS X {{ic|dd}}, the number comes from {{ic|1024*8}}).
 +
 +
{{hc|<nowiki>dd if=image.iso of=/dev/disk1 bs=8192</nowiki>|
 +
20480+0 records in
 +
20480+0 records out
 +
167772160 bytes transferred in 220.016918 secs (762542 bytes/sec)
 +
}}
 +
 +
It is probably a good idea to eject your drive before physical removal at this point:
 +
 +
$ diskutil eject /dev/disk1
 +
 
==== How to restore the USB drive ====
 
==== How to restore the USB drive ====
  
Because the ISO image is a hybrid which can either be burned to a disc or directly written to a USB drive, it doesn't include a standard partition table.
+
Because the ISO image is a hybrid which can either be burned to a disc or directly written to a USB drive, it does not include a standard partition table.
  
After you install Arch Linux and you're done with the USB drive, you should zero out its first 512 bytes ''(meaning the boot code from the MBR and the non-standard partition table)'' if you want to restore it to full capacity:
+
After you install Arch Linux and you are done with the USB drive, you should zero out its first 512 bytes ''(meaning the boot code from the MBR and the non-standard partition table)'' if you want to restore it to full capacity:
  
 
  # dd count=1 bs=512 if=/dev/zero of=/dev/sd'''x''' && sync
 
  # dd count=1 bs=512 if=/dev/zero of=/dev/sd'''x''' && sync
Line 56: Line 125:
 
  # dosfslabel /dev/sd'''x1''' USB_STICK
 
  # dosfslabel /dev/sd'''x1''' USB_STICK
  
=== Without overwriting the USB drive ===
+
=== Using manual formatting===
{{Out of date|This section may need an update. See the discussion.|Talk:USB_Flash_Installation_Media#About_making_the_installation_media_without_overwriting}}
+
This method is slightly more complicated than writing the image directly with {{ic|dd}}, but it does keep the drive usable for data storage. Before you begin, make sure that your USB device is formatted as either FAT32, EXT2/3/4 or Btrfs. For [[UEFI]] boot and/or interoperability with other operating systems you should use FAT32. Also, make sure that you have the ''syslinux'' package (version 4.04 or newer) installed.
+
  
'''1.''' Extract the {{ic|arch}} folder from the ISO to the USB drive. For UEFI motherboards follow [[UEFI#Create_UEFI_bootable_USB_from_ISO|these]] instructions.
+
==== In GNU/Linux ====
  
'''2.''' Install the Syslinux bootloader:
+
This method is more complicated than writing the image directly with {{ic|dd}}, but it does keep the flash drive usable for data storage.
  
{{Warning|Be very careful where you point {{ic|dd}} and please use the drive '''itself''' in the following commands, '''not''' the first partition. This is a very common mistake.}}
+
* Make sure that the latest ''syslinux'' package (version 6.02 or newer) is installed on the system.  
  
{{Note|On some distributions {{ic|mbr.bin}} may be available as {{ic|/usr/'''share'''/syslinux/mbr.bin}}.}}
+
* A MBR (msdos) partition table with at least one partition, containing a FAT32 filesystem must be present on the device. If not, create the partition and/or filesystem before continuing.
  
  $ cd /''path/to/folder''/arch/boot/syslinux #Where ''path/to/folder'' is the USB drive's mount point
+
* Mount the ISO image.
  # extlinux --install .                       #Type it exactly as you see it, including the dot (.)
+
  # mkdir -p /mnt/iso
# dd bs=440 conv=notrunc count=1 if=/usr/lib/syslinux/mbr.bin of=/dev/sd'''x'''
+
  # mount -o loop archlinux-2013.10.01-dual.iso /mnt/iso
# parted /dev/sd'''x''' toggle 1 boot
+
  
'''3.''' Adjust the configuration files:
+
{{Note|In any of the following commands, adjust {{ic|/dev/sd'''X'''1}} according to your system.}}
 +
* Mount the FAT32 filesystem on the USB flash device, and copy the contents of the isofile to it.
 +
# mkdir -p /mnt/usb
 +
# mount /dev/sd'''X'''1 /mnt/usb
 +
# cp -a /mnt/iso/* /mnt/usb
 +
# sync
 +
# umount /mnt/{usb,iso}
  
{{Warning|Failure to label the drive "{{ic|ARCH_2013XX}}" (with the appropriate release month) or to use an [[UUID]] (to re-label it to whatever you like) '''will''' get you the infamous "30 seconds" error.}}
+
* Adjust the configuration files archiso_sys32 and archiso_sys64. This step is not required when using [[Archboot]] instead of [[Archiso]]. This command replaces the {{ic|1=archisolabel=ARCH_2013XX}} part with your equivalent of {{ic|1=archiso'''device'''=/dev/disk/by-uuid/47FA-4071}} in both files.
 +
{{Warning|Failure to label the drive "{{ic|ARCH_2013XX}}" (with the appropriate release month) or to use an [[UUID]] (to re-label it to whatever you like) prevents booting from the created medium.}}
  
Here's how you can replace the {{ic|1=archisolabel=ARCH_2013XX}} part with your equivalent of {{ic|1=archiso'''device'''=/dev/disk/by-uuid/47FA-4071}} for both config files at the same time, using a single command:
+
$ sed -i "s|label=ARCH_.*|device=/dev/disk/by-uuid/$(blkid -o value -s UUID /dev/sd'''X'''1)|" archiso_sys{32,64}.cfg
  
{{Note|Adjust {{ic|/dev/sd'''x1'''}} before running it, else it will become blank (since drive {{ic|sd'''x'''}} doesn't exist).}}
+
{{Note|Again, adjust {{ic|/dev/sd'''X'''1}}.}}
  
$ sed -i "s|label=ARCH_.*|device=/dev/disk/by-uuid/$(blkid -o value -s UUID /dev/sd'''x1''')|" archiso_sys{32,64}.cfg
+
* Install Syslinux to the flash drive by following [[Syslinux#Manual_install]]. Overwrite the existing syslinux modules ({{ic|*.c32}} files) present in the USB (from the ISO) with the ones from the syslinux package. This is necessary to avoid boot failure because of a possible version mismatch.
  
If the ''syslinux'' package on your distribution is older than version 4.06, as a workaround for FAT32 filesystems (unnecessary for EXT4), the {{ic|APPEND}} line from {{ic|syslinux.cfg}} should also be replaced:
+
* Mark the partition as active by following [[Syslinux#MBR_partition_table]]
  
$ sed -i "s|../../|/arch|" syslinux.cfg
+
==== In Windows ====
 +
 
 +
{{Note|
 +
* Do not use any '''Bootable USB Creator utility''' for creating the UEFI bootable USB. Do not use ''dd for Windows'' to dd the ISO to the USB drive.
 +
 
 +
* In the below commands '''X:''' is assumed to be the USB flash drive in Windows.
 +
 
 +
* Windows used backward slash {{ic|\}} as path-separator, so the same is used in the below commands.
 +
 
 +
* All commands should be run in Windows command prompt '''as administrator'''.
 +
 
 +
* {{ic|>}} denotes the Windows command prompt.
 +
}}
 +
 
 +
* Partition and format the USB drive using [http://rufus.akeo.ie/ Rufus USB partitioner]. Select partition scheme option as '''MBR for BIOS and UEFI''' and File system as '''FAT32'''. Uncheck "Create a bootable disk using ISO image" and "Create extended label and icon files" options. Use
 +
 
 +
* Change the '''Volume Label''' of the USB flash drive {{ic|X:}} to match the LABEL mentioned in {{ic|1=archisolabel=}} part in {{ic|<ISO>\loader\entries\archiso-x86_64.conf}}. This step is required for Official ISO ([[Archiso]]) but not required for [[Archboot]].
 +
 
 +
* Extract the ISO (similar to extracting ZIP archive) to the USB flash drive (using [http://7-zip.org/ 7-Zip].  
 +
 
 +
* Download latest official syslinux 6.xx binaries (zip file) from https://www.kernel.org/pub/linux/utils/boot/syslinux/  and extract it.
 +
 
 +
* Run the following command (in Windows cmd prompt, as admin):
 +
 
 +
{{Note|Use {{ic|X:\boot\syslinux\}} for Archboot iso.}}
 +
 
 +
> cd bios\
 +
> for /r %Y in (*.c32) do copy "%Y" "X:\arch\boot\syslinux\" /y
 +
> copy mbr\*.bin X:\arch\boot\syslinux\ /y
 +
 
 +
* Install Syslinux to the USB by running (use {{ic|win64\syslinux64.exe}} for x64 Windows):
 +
 
 +
{{Note|Use {{ic|/boot/syslinux}} for Archboot iso.}}
 +
 
 +
> cd bios\
 +
> win32\syslinux.exe -d /arch/boot/syslinux -i -a -m X:
 +
 
 +
{{Note|
 +
* The above step install Syslinux {{ic|ldlinux.sys}} to the USB partition VBR, sets the partition as active/boot in the MBR partition table and write the MBR boot code to the 1st 400-byte boot code region of the USB.
 +
 
 +
* The {{ic|-d}} switch expects path with forward slash path-separator like in *unix systems.
 +
}}
 +
 
 +
== Other Methods for BIOS systems ==
 +
{{Out of date|Can someone verify these work/are even needed to be mentioned?|section=Other Methods for BIOS systems}}
 +
=== In GNU/Linux ===
 +
 
 +
==== Using UNetbootin ====
  
====Using UNetbootin====
 
 
UNetbootin can be used on any Linux distribution or Windows to copy your iso to a USB device. However, Unetbootin overwrites syslinux.cfg, so it creates a USB device that does not boot properly. For this reason, '''Unetbootin is not recommended''' -- please use {{ic|dd}} or one of the other methods discussed in this topic.
 
UNetbootin can be used on any Linux distribution or Windows to copy your iso to a USB device. However, Unetbootin overwrites syslinux.cfg, so it creates a USB device that does not boot properly. For this reason, '''Unetbootin is not recommended''' -- please use {{ic|dd}} or one of the other methods discussed in this topic.
 
{{Warning|UNetbootin writes over the default {{ic|syslinux.cfg}}; this must be restored before the USB device will boot properly.}}
 
{{Warning|UNetbootin writes over the default {{ic|syslinux.cfg}}; this must be restored before the USB device will boot properly.}}
Line 112: Line 231:
 
In {{ic|/dev/sd'''x1'''}} you must replace '''x''' with the first free letter after the last letter in use on the system where you are installing Arch Linux (e.g. if you have two hard drives, use {{ic|c}}.). You can make this change during the first phase of boot by pressing {{ic|Tab}} when the menu is shown.
 
In {{ic|/dev/sd'''x1'''}} you must replace '''x''' with the first free letter after the last letter in use on the system where you are installing Arch Linux (e.g. if you have two hard drives, use {{ic|c}}.). You can make this change during the first phase of boot by pressing {{ic|Tab}} when the menu is shown.
  
== On Mac OS X ==
+
=== In Windows ===
  
To be able to use {{ic|dd}} on your USB device on a Mac you have to do some special maneuvers. First of all insert your usb device, OS X will automount it, and in {{ic|Terminal.app}} run:
+
==== Win32 Disk Imager ====
  
$ diskutil list
 
 
Figure out what your USB device is called with {{ic|mount}} or {{ic|<nowiki>sudo dmesg | tail</nowiki>}} (e.g. {{ic|/dev/disk1}}) and unmount the partitions on the device (i.e., /dev/disk1s1) while keeping the device proper (i.e., /dev/disk1):
 
 
$ diskutil unmountDisk /dev/disk1
 
 
Now we can continue in accordance with the instructions above (but use {{ic|1=bs=8192}} if you are using the OS X {{ic|dd}}, the number comes from {{ic|1024*8}}).
 
 
{{hc|<nowiki>dd if=image.iso of=/dev/disk1 bs=8192</nowiki>|
 
20480+0 records in
 
20480+0 records out
 
167772160 bytes transferred in 220.016918 secs (762542 bytes/sec)
 
}}
 
 
It is probably a good idea to eject your drive before physical removal at this point:
 
 
$ diskutil eject /dev/disk1
 
 
== On Windows ==
 
 
=== Win32 Disk Imager ===
 
 
{{Warning|This will destroy all information on your USB flash drive!}}
 
{{Warning|This will destroy all information on your USB flash drive!}}
 
First, download the program from [http://sourceforge.net/projects/win32diskimager/ here]. Next, extract the archive and run the executable. Now, select the Arch Linux ISO under the {{ic|Image File}} section and the USB flash device letter (for example, [D:\]) under the {{ic|Device}} section. Finally, click {{ic|Write}} when ready.
 
First, download the program from [http://sourceforge.net/projects/win32diskimager/ here]. Next, extract the archive and run the executable. Now, select the Arch Linux ISO under the {{ic|Image File}} section and the USB flash device letter (for example, [D:\]) under the {{ic|Device}} section. Finally, click {{ic|Write}} when ready.
Line 142: Line 240:
 
{{Note|After installation, you may need to restore the USB flash drive following a process as outlined [[USB_Installation_Media#How_to_restore_the_USB_drive|here]].}}
 
{{Note|After installation, you may need to restore the USB flash drive following a process as outlined [[USB_Installation_Media#How_to_restore_the_USB_drive|here]].}}
  
=== USBWriter for Windows ===
+
==== USBWriter for Windows ====
  
 
Download the program from http://sourceforge.net/projects/usbwriter/ and run it. Select the arch image file, the target USB stick, and click on the {{ic|write}} button. Now you should be able to boot from the usb stick and install Arch Linux from it.
 
Download the program from http://sourceforge.net/projects/usbwriter/ and run it. Select the arch image file, the target USB stick, and click on the {{ic|write}} button. Now you should be able to boot from the usb stick and install Arch Linux from it.
  
=== The Flashnul Way ===
+
==== The Flashnul way ====
  
 
[http://shounen.ru/soft/flashnul/ flashnul] is an utility to verify the functionality and maintenance of Flash-Memory (USB-Flash, IDE-Flash, SecureDigital, MMC, MemoryStick, SmartMedia, XD, CompactFlash etc).
 
[http://shounen.ru/soft/flashnul/ flashnul] is an utility to verify the functionality and maintenance of Flash-Memory (USB-Flash, IDE-Flash, SecureDigital, MMC, MemoryStick, SmartMedia, XD, CompactFlash etc).
Line 170: Line 268:
 
{{Note|Confirmed that you need to use drive letter as opposed to number. flashnul 1rc1, Windows 7 x64.}}
 
{{Note|Confirmed that you need to use drive letter as opposed to number. flashnul 1rc1, Windows 7 x64.}}
  
=== The Cygwin Way ===
+
==== Loading the installation media from RAM ====
  
Make sure your [http://www.cygwin.com/ Cygwin] installation contains the {{ic|dd}} package.
 
 
{{Tip|If you do not want to install Cygwin, you can download {{ic|dd}} for Windows from [http://www.chrysocome.net/dd here]. See the next section for more information.}}
 
 
Place your image file in your home directory:
 
 
C:\cygwin\home\John\
 
 
Run cygwin as administrator (required for cygwin to access hardware). To write to your USB drive use the following command:
 
 
dd if=image.iso of=\\.\[x]: bs=4M
 
 
where image.iso is the path to the iso image file within the {{ic|cygwin}} directory and {{ic|\\.\['''x''']}}: is your USB flash drive where '''x''' is the windows designated letter, e.g. {{ic|\\.\d:}}.
 
 
On Cygwin 6.0 find out the correct partition with:
 
 
cat /proc/partitions
 
 
and write the ISO image with the information from the output. Example:
 
 
{{Warning|This will irrevocably delete all files on your USB flash drive, so make sure you do not have any important files on the stick before doing this.}}
 
 
dd if=image.iso of=/dev/sdb bs=4M
 
 
=== dd for Windows ===
 
 
{{Note|Some users have an "isolinux.bin missing or corrupt" problem when booting the media with this method.}}
 
 
A GPL licensed dd version for Windows is available at http://www.chrysocome.net/dd. The advantage of this over Cygwin is a smaller download. Use it as shown in instructions for Cygwin above.
 
 
To begin, download the latest version of dd for Windows. Once downloaded, extract the archive's contents into Downloads or elsewhere.
 
 
Now, launch your {{ic|command prompt}} as an administrator. Next, change directory ({{ic|cd}}) into the Downloads directory.
 
 
If your Arch Linux ISO is elsewhere you may need to state the full path, for convenience you may wish to put the Arch Linux ISO into the same folder as the dd executable. The basic format of the command will look like this.
 
 
{{bc|<nowiki>dd if=archlinux-2013-XX-xx-dual.iso of=\\.\x: bs=4m</nowiki>}}
 
{{Warning|This command will replace the drive's contents and its formatting with the ISO's. You will likely be unable to recover its contents in the event of an accidental copy. Be absolutely sure that you are directing dd to the correct drive before executing!}}
 
Simply replace the various null spots (indicated by an "x") with the correct date and correct drive letter.
 
 
Here is a complete example.
 
{{bc|<nowiki>dd if=ISOs\archlinux-2013.08.01-dual.iso of=\\.\d: bs=4M</nowiki>}}
 
 
=== Loading the installation media from RAM ===
 
 
This method uses [[Syslinux]] and a [[Ramdisk]] ([http://www.syslinux.org/wiki/index.php/MEMDISK MEMDISK]) to load the entire Arch Linux ISO image into RAM. Since this will be running entirely from system memory, you will need to make sure the system you will be installing this on has an adequate amount. A minimum amount of RAM between 500 MB and 1 GB should suffice for a MEMDISK based, Arch Linux install.
 
This method uses [[Syslinux]] and a [[Ramdisk]] ([http://www.syslinux.org/wiki/index.php/MEMDISK MEMDISK]) to load the entire Arch Linux ISO image into RAM. Since this will be running entirely from system memory, you will need to make sure the system you will be installing this on has an adequate amount. A minimum amount of RAM between 500 MB and 1 GB should suffice for a MEMDISK based, Arch Linux install.
  
 
For more information on Arch Linux system requirements as well as those for MEMDISK see the [[Beginners' Guide]] and [http://www.etherboot.org/wiki/bootingmemdisk#preliminaries here].
 
For more information on Arch Linux system requirements as well as those for MEMDISK see the [[Beginners' Guide]] and [http://www.etherboot.org/wiki/bootingmemdisk#preliminaries here].
 
{{Tip|Once the installer has completed loading you can simply remove the USB stick and even use it on a different machine to start the process all over again. Utilizing MEMDISK also allows booting and installing Arch Linux to and from the same USB flash drive.}}
 
{{Tip|Once the installer has completed loading you can simply remove the USB stick and even use it on a different machine to start the process all over again. Utilizing MEMDISK also allows booting and installing Arch Linux to and from the same USB flash drive.}}
====Preparing the USB flash drive====
+
 
 +
===== Preparing the USB flash drive =====
 +
 
 
Begin by formatting the USB flash drive as '''FAT32'''. Then create the following folders on the newly formatted drive.
 
Begin by formatting the USB flash drive as '''FAT32'''. Then create the following folders on the newly formatted drive.
 
* {{ic|Boot}}
 
* {{ic|Boot}}
 
** {{ic|Boot/ISOs}}
 
** {{ic|Boot/ISOs}}
 
** {{ic|Boot/Settings}}
 
** {{ic|Boot/Settings}}
====Copy the needed files to the USB flash drive====
+
 
 +
===== Copy the needed files to the USB flash drive =====
 +
 
 
Next copy the ISO that you would like to boot to the {{ic|Boot/ISOs}} folder. After that, extract from the following files from the latest release of {{pkg|syslinux}} from [http://www.kernel.org/pub/linux/utils/boot/syslinux/ here] and copy them into the following folders.
 
Next copy the ISO that you would like to boot to the {{ic|Boot/ISOs}} folder. After that, extract from the following files from the latest release of {{pkg|syslinux}} from [http://www.kernel.org/pub/linux/utils/boot/syslinux/ here] and copy them into the following folders.
 
* {{ic|./win32/syslinux.exe}} to the Desktop or Downloads folder on your system.
 
* {{ic|./win32/syslinux.exe}} to the Desktop or Downloads folder on your system.
 
* {{ic|./memdisk/memdisk}} to the {{ic|Settings}} folder on your USB flash drive.
 
* {{ic|./memdisk/memdisk}} to the {{ic|Settings}} folder on your USB flash drive.
====Create the configuration file====
+
 
 +
===== Create the configuration file =====
 +
 
 
After copying the needed files, navigate to the USB flash drive, /boot/Settings and create a {{ic|syslinux.cfg}} file.
 
After copying the needed files, navigate to the USB flash drive, /boot/Settings and create a {{ic|syslinux.cfg}} file.
 
{{Warning|On the {{ic|INITRD}} line, be sure to use the name of the ISO file that you copied to your {{ic|ISOs}} folder!}}
 
{{Warning|On the {{ic|INITRD}} line, be sure to use the name of the ISO file that you copied to your {{ic|ISOs}} folder!}}
Line 241: Line 301:
 
         APPEND iso}}
 
         APPEND iso}}
 
For more information on Syslinux see the [[Syslinux|Arch Wiki article]].
 
For more information on Syslinux see the [[Syslinux|Arch Wiki article]].
====Final steps====
+
 
Finally, create a {{ic|*.bat}} file where {{ic|syslinux.exe}} is located and run it ("Run as administrator" if you're on Vista or Windows 7):
+
===== Final steps =====
 +
 
 +
Finally, create a {{ic|*.bat}} file where {{ic|syslinux.exe}} is located and run it ("Run as administrator" if you are on Vista or Windows 7):
 
{{hc|C:\Documents and Settings\username\Desktop\install.bat|
 
{{hc|C:\Documents and Settings\username\Desktop\install.bat|
 
@echo off
 
@echo off
 
syslinux.exe -m -a -d /Boot/Settings X:}}
 
syslinux.exe -m -a -d /Boot/Settings X:}}
  
=== Add to a MULTIBOOT Live USB ===
+
==== Universal USB Installer ====
  
The Windows tool [http://www.pendrivelinux.com/yumi-multiboot-usb-creator/ YUMI MultiBoot Live USB Creator] can be used to quickly create a Live USB media with multiple Installers of many Linux distros. Once created, Installers can be added or removed without reformatting the USB drive.
+
The Windows tool [http://www.pendrivelinux.com/universal-usb-installer-easy-as-1-2-3/] can be used to quickly create a Live USB media with multiple Installers of many Linux distros. Once created, Installers can be added or removed without reformatting the USB drive.
  
 
== Troubleshooting ==
 
== Troubleshooting ==
{{Note|For the [[#Boot the entire ISO from RAM|MEMDISK Method]], if you get the famous "30 seconds" error trying to boot the i686 version, press the {{Keypress|Tab}} key over the {{ic|Boot Arch Linux (i686)}} entry and add {{ic|vmalloc&#61;448M}} at the end. For reference: ''If your image is bigger than 128MiB and you have a 32-bit OS, then you have to increase the maximum memory usage of vmalloc''. [http://www.syslinux.org/wiki/index.php/MEMDISK#-_memdiskfind_in_combination_with_phram_and_mtdblock (*)]}}
 
  
{{Note|If you get the "30 seconds" error due to the {{ic|/dev/disk/by-label/ARCH_XXXXXX}} not mounting, try renaming your USB media to {{ic|ARCH_XXXXXX}} (e.g. {{ic|ARCH_201302}}).}}
+
* For the [[#Loading the installation media from RAM|MEMDISK Method]], if you get the famous "30 seconds" error trying to boot the i686 version, press the {{ic|Tab}} key over the {{ic|Boot Arch Linux (i686)}} entry and add {{ic|vmalloc&#61;448M}} at the end. For reference: ''If your image is bigger than 128MiB and you have a 32-bit OS, then you have to increase the maximum memory usage of vmalloc''. [http://www.syslinux.org/wiki/index.php/MEMDISK#-_memdiskfind_in_combination_with_phram_and_mtdblock]
 +
 
 +
* If you get the "30 seconds" error due to the {{ic|/dev/disk/by-label/ARCH_XXXXXX}} not mounting, try renaming your USB media to {{ic|ARCH_XXXXXX}} (e.g. {{ic|ARCH_201302}}).
  
 
== See Also ==
 
== See Also ==
  
* [http://www.gentoo.org/doc/en/liveusb.xml Gentoo liveusb document]
+
* [https://wiki.gentoo.org/wiki/LiveUSB/HOWTO Gentoo wiki - LiveUSB/HOWTO]
 +
* [https://fedoraproject.org/wiki/How_to_create_and_use_Live_USB Fedora wiki - How to create and use Live USB]
 +
* [http://en.opensuse.org/SDB:Live_USB_stick openSUSE wiki - SDB:Live USB stick]

Revision as of 04:02, 1 February 2014

Related articles

This page discusses various mutiplatform methods on how to create a Arch Linux Installer USB drive (also referred to as "flash drive", "USB stick", "USB key", etc) for booting in BIOS and UEFI systems. The result will be a LiveUSB (LiveCD-like) system that can be used for installing Arch Linux, system maintenance or for recovery purposes, and that, because of the nature of SquashFS, will discard all changes once the computer shuts down.

If you would like to run a full install of Arch Linux from a USB drive (i.e. with persistent settings), see Installing Arch Linux on a USB key. If you would like to use your bootable Arch Linux USB stick as a rescue USB, see Change Root.

BIOS and UEFI Bootable USB

Using dd

Note: This method is recommended due to its simplicity. If it does not work switch to the alternative method #Using manual formatting below.
Warning: This will irrevocably destroy all data on /dev/sdx.

In GNU/Linux

Tip: Check that the USB flash installation media is not mounted with lsblk.
Note: Use /dev/sdx instead of /dev/sdx1, and adjust x to reflect the targeted device.
# dd bs=4M if=/path/to/archlinux.iso of=/dev/sdx && sync

In Windows

Using Cygwin

Make sure your Cygwin installation contains the dd package.

Tip: If you do not want to install Cygwin, you can download dd for Windows from here. See the next section for more information.

Place your image file in your home directory:

C:\cygwin\home\John\

Run cygwin as administrator (required for cygwin to access hardware). To write to your USB drive use the following command:

dd if=image.iso of=\\.\[x]: bs=4M

where image.iso is the path to the iso image file within the cygwin directory and \\.\[x]: is your USB flash drive where x is the windows designated letter, e.g. \\.\d:.

On Cygwin 6.0 find out the correct partition with:

cat /proc/partitions

and write the ISO image with the information from the output. Example:

Warning: This will irrevocably delete all files on your USB flash drive, so make sure you do not have any important files on the stick before doing this.
dd if=image.iso of=/dev/sdb bs=4M
dd for Windows
Note: Some users have an "isolinux.bin missing or corrupt" problem when booting the media with this method.

A GPL licensed dd version for Windows is available at http://www.chrysocome.net/dd. The advantage of this over Cygwin is a smaller download. Use it as shown in instructions for Cygwin above.

To begin, download the latest version of dd for Windows. Once downloaded, extract the archive's contents into Downloads or elsewhere.

Now, launch your command prompt as an administrator. Next, change directory (cd) into the Downloads directory.

If your Arch Linux ISO is elsewhere you may need to state the full path, for convenience you may wish to put the Arch Linux ISO into the same folder as the dd executable. The basic format of the command will look like this.

dd if=archlinux-2013-XX-xx-dual.iso of=\\.\x: bs=4m
Warning: This command will replace the drive's contents and its formatting with the ISO's. You will likely be unable to recover its contents in the event of an accidental copy. Be absolutely sure that you are directing dd to the correct drive before executing!

Simply replace the various null spots (indicated by an "x") with the correct date and correct drive letter.

Here is a complete example.

dd if=ISOs\archlinux-2013.08.01-dual.iso of=\\.\d: bs=4M

In Mac OS X

To be able to use dd on your USB device on a Mac you have to do some special maneuvers. First of all insert your usb device, OS X will automount it, and in Terminal.app run:

$ diskutil list

Figure out what your USB device is called with mount or sudo dmesg | tail (e.g. /dev/disk1) and unmount the partitions on the device (i.e., /dev/disk1s1) while keeping the device proper (i.e., /dev/disk1):

$ diskutil unmountDisk /dev/disk1

Now we can continue in accordance with the instructions above (but use bs=8192 if you are using the OS X dd, the number comes from 1024*8).

dd if=image.iso of=/dev/disk1 bs=8192
20480+0 records in
20480+0 records out
167772160 bytes transferred in 220.016918 secs (762542 bytes/sec)

It is probably a good idea to eject your drive before physical removal at this point:

$ diskutil eject /dev/disk1

How to restore the USB drive

Because the ISO image is a hybrid which can either be burned to a disc or directly written to a USB drive, it does not include a standard partition table.

After you install Arch Linux and you are done with the USB drive, you should zero out its first 512 bytes (meaning the boot code from the MBR and the non-standard partition table) if you want to restore it to full capacity:

# dd count=1 bs=512 if=/dev/zero of=/dev/sdx && sync

Then create a new partition table (e.g. "msdos") and filesystem (e.g. EXT4, FAT32) using gparted, or from a terminal:

  • For EXT2/3/4 (adjust accordingly), it would be:
# cfdisk /dev/sdx
# mkfs.ext4 /dev/sdx1
# e2label /dev/sdx1 USB_STICK
  • For FAT32, install the dosfstools package and run:
# cfdisk /dev/sdx
# mkfs.vfat -F32 /dev/sdx1
# dosfslabel /dev/sdx1 USB_STICK

Using manual formatting

In GNU/Linux

This method is more complicated than writing the image directly with dd, but it does keep the flash drive usable for data storage.

  • Make sure that the latest syslinux package (version 6.02 or newer) is installed on the system.
  • A MBR (msdos) partition table with at least one partition, containing a FAT32 filesystem must be present on the device. If not, create the partition and/or filesystem before continuing.
  • Mount the ISO image.
# mkdir -p /mnt/iso
# mount -o loop archlinux-2013.10.01-dual.iso /mnt/iso
Note: In any of the following commands, adjust /dev/sdX1 according to your system.
  • Mount the FAT32 filesystem on the USB flash device, and copy the contents of the isofile to it.
# mkdir -p /mnt/usb
# mount /dev/sdX1 /mnt/usb
# cp -a /mnt/iso/* /mnt/usb
# sync
# umount /mnt/{usb,iso}
  • Adjust the configuration files archiso_sys32 and archiso_sys64. This step is not required when using Archboot instead of Archiso. This command replaces the archisolabel=ARCH_2013XX part with your equivalent of archisodevice=/dev/disk/by-uuid/47FA-4071 in both files.
Warning: Failure to label the drive "ARCH_2013XX" (with the appropriate release month) or to use an UUID (to re-label it to whatever you like) prevents booting from the created medium.
$ sed -i "s|label=ARCH_.*|device=/dev/disk/by-uuid/$(blkid -o value -s UUID /dev/sdX1)|" archiso_sys{32,64}.cfg
Note: Again, adjust /dev/sdX1.
  • Install Syslinux to the flash drive by following Syslinux#Manual_install. Overwrite the existing syslinux modules (*.c32 files) present in the USB (from the ISO) with the ones from the syslinux package. This is necessary to avoid boot failure because of a possible version mismatch.

In Windows

Note:
  • Do not use any Bootable USB Creator utility for creating the UEFI bootable USB. Do not use dd for Windows to dd the ISO to the USB drive.
  • In the below commands X: is assumed to be the USB flash drive in Windows.
  • Windows used backward slash \ as path-separator, so the same is used in the below commands.
  • All commands should be run in Windows command prompt as administrator.
  • > denotes the Windows command prompt.
  • Partition and format the USB drive using Rufus USB partitioner. Select partition scheme option as MBR for BIOS and UEFI and File system as FAT32. Uncheck "Create a bootable disk using ISO image" and "Create extended label and icon files" options. Use
  • Change the Volume Label of the USB flash drive X: to match the LABEL mentioned in archisolabel= part in <ISO>\loader\entries\archiso-x86_64.conf. This step is required for Official ISO (Archiso) but not required for Archboot.
  • Extract the ISO (similar to extracting ZIP archive) to the USB flash drive (using 7-Zip.
  • Run the following command (in Windows cmd prompt, as admin):
Note: Use X:\boot\syslinux\ for Archboot iso.
> cd bios\
> for /r %Y in (*.c32) do copy "%Y" "X:\arch\boot\syslinux\" /y
> copy mbr\*.bin X:\arch\boot\syslinux\ /y
  • Install Syslinux to the USB by running (use win64\syslinux64.exe for x64 Windows):
Note: Use /boot/syslinux for Archboot iso.
> cd bios\
> win32\syslinux.exe -d /arch/boot/syslinux -i -a -m X:
Note:
  • The above step install Syslinux ldlinux.sys to the USB partition VBR, sets the partition as active/boot in the MBR partition table and write the MBR boot code to the 1st 400-byte boot code region of the USB.
  • The -d switch expects path with forward slash path-separator like in *unix systems.

Other Methods for BIOS systems

Tango-view-refresh-red.pngThis article or section is out of date.Tango-view-refresh-red.png

Reason: Can someone verify these work/are even needed to be mentioned? (Discuss in Talk:USB flash installation media#Other Methods for BIOS systems)

In GNU/Linux

Using UNetbootin

UNetbootin can be used on any Linux distribution or Windows to copy your iso to a USB device. However, Unetbootin overwrites syslinux.cfg, so it creates a USB device that does not boot properly. For this reason, Unetbootin is not recommended -- please use dd or one of the other methods discussed in this topic.

Warning: UNetbootin writes over the default syslinux.cfg; this must be restored before the USB device will boot properly.

Edit syslinux.cfg:

sysconfig.cfg
default menu.c32
prompt 0
menu title Archlinux Installer
timeout 100

label unetbootindefault
menu label Archlinux_x86_64
kernel /arch/boot/x86_64/vmlinuz
append initrd=/arch/boot/x86_64/archiso.img archisodevice=/dev/sdx1 ../../

label ubnentry0
menu label Archlinux_i686
kernel /arch/boot/i686/vmlinuz
append initrd=/arch/boot/i686/archiso.img archisodevice=/dev/sdx1 ../../

In /dev/sdx1 you must replace x with the first free letter after the last letter in use on the system where you are installing Arch Linux (e.g. if you have two hard drives, use c.). You can make this change during the first phase of boot by pressing Tab when the menu is shown.

In Windows

Win32 Disk Imager

Warning: This will destroy all information on your USB flash drive!

First, download the program from here. Next, extract the archive and run the executable. Now, select the Arch Linux ISO under the Image File section and the USB flash device letter (for example, [D:\]) under the Device section. Finally, click Write when ready.

Tip: By default, the Win32 Disk Imager's file-browser assumes disk image files end with a .img extension. However, you can simply change the Files of type drop-down list to *.* and continue on to selecting your Arch Linux ISO.
Note: After installation, you may need to restore the USB flash drive following a process as outlined here.

USBWriter for Windows

Download the program from http://sourceforge.net/projects/usbwriter/ and run it. Select the arch image file, the target USB stick, and click on the write button. Now you should be able to boot from the usb stick and install Arch Linux from it.

The Flashnul way

flashnul is an utility to verify the functionality and maintenance of Flash-Memory (USB-Flash, IDE-Flash, SecureDigital, MMC, MemoryStick, SmartMedia, XD, CompactFlash etc).

From a command prompt, invoke flashnul with -p, and determine which device index is your USB drive, e.g.:

C:\>flashnul -p
Avaible physical drives:
Avaible logical disks:
C:\
D:\
E:\

When you have determined which device is the correct one, you can write the image to your drive, by invoking flashnul with the device index, -L, and the path to your image, e.g:

C:\>flashnul E: -L path\to\arch.iso

As long as you are really sure you want to write the data, type yes, then wait a bit for it to write. If you get an access denied error, close any Explorer windows you have open.

If under Vista or Win7, you should open the console as administrator, or else flashnul will fail to open the stick as a block device and will only be able to write via the drive handle windows provides

Note: Confirmed that you need to use drive letter as opposed to number. flashnul 1rc1, Windows 7 x64.

Loading the installation media from RAM

This method uses Syslinux and a Ramdisk (MEMDISK) to load the entire Arch Linux ISO image into RAM. Since this will be running entirely from system memory, you will need to make sure the system you will be installing this on has an adequate amount. A minimum amount of RAM between 500 MB and 1 GB should suffice for a MEMDISK based, Arch Linux install.

For more information on Arch Linux system requirements as well as those for MEMDISK see the Beginners' Guide and here.

Tip: Once the installer has completed loading you can simply remove the USB stick and even use it on a different machine to start the process all over again. Utilizing MEMDISK also allows booting and installing Arch Linux to and from the same USB flash drive.
Preparing the USB flash drive

Begin by formatting the USB flash drive as FAT32. Then create the following folders on the newly formatted drive.

  • Boot
    • Boot/ISOs
    • Boot/Settings
Copy the needed files to the USB flash drive

Next copy the ISO that you would like to boot to the Boot/ISOs folder. After that, extract from the following files from the latest release of syslinux from here and copy them into the following folders.

  • ./win32/syslinux.exe to the Desktop or Downloads folder on your system.
  • ./memdisk/memdisk to the Settings folder on your USB flash drive.
Create the configuration file

After copying the needed files, navigate to the USB flash drive, /boot/Settings and create a syslinux.cfg file.

Warning: On the INITRD line, be sure to use the name of the ISO file that you copied to your ISOs folder!
/Boot/Settings/syslinux.cfg
DEFAULT arch_iso

LABEL arch_iso
        MENU LABEL Arch Setup
        LINUX memdisk
        INITRD /Boot/ISOs/archlinux-2013.08.01-dual.iso
        APPEND iso

For more information on Syslinux see the Arch Wiki article.

Final steps

Finally, create a *.bat file where syslinux.exe is located and run it ("Run as administrator" if you are on Vista or Windows 7):

C:\Documents and Settings\username\Desktop\install.bat
@echo off
syslinux.exe -m -a -d /Boot/Settings X:

Universal USB Installer

The Windows tool [1] can be used to quickly create a Live USB media with multiple Installers of many Linux distros. Once created, Installers can be added or removed without reformatting the USB drive.

Troubleshooting

  • For the MEMDISK Method, if you get the famous "30 seconds" error trying to boot the i686 version, press the Tab key over the Boot Arch Linux (i686) entry and add vmalloc=448M at the end. For reference: If your image is bigger than 128MiB and you have a 32-bit OS, then you have to increase the maximum memory usage of vmalloc. [2]
  • If you get the "30 seconds" error due to the /dev/disk/by-label/ARCH_XXXXXX not mounting, try renaming your USB media to ARCH_XXXXXX (e.g. ARCH_201302).

See Also