2011-06-18 21:38:58 +00:00
|
|
|
INDEX
|
|
|
|
-----
|
|
|
|
|
2011-06-22 01:56:57 +00:00
|
|
|
* Boot parameters (initramfs stage)
|
|
|
|
* hooks/archiso
|
2011-12-02 03:44:02 +00:00
|
|
|
* hooks/archiso_pxe_common
|
2011-06-22 01:56:57 +00:00
|
|
|
* hooks/archiso_pxe_nbd
|
2011-12-03 21:08:57 +00:00
|
|
|
* hooks/archiso_pxe_http
|
2011-12-02 03:44:02 +00:00
|
|
|
* hooks/archiso_pxe_nfs
|
2011-06-22 01:56:57 +00:00
|
|
|
* hooks/archiso_loop_mnt
|
|
|
|
* Boot parameters (only for configs/releng)
|
|
|
|
* etc/rc.conf
|
2012-04-25 03:55:27 +00:00
|
|
|
* Transfer ISO file to target medium (configs/releng)
|
|
|
|
* To -> CD / DVD / BD
|
|
|
|
* To -> USB-key / SD / HDD / SSD
|
|
|
|
* PC-BIOS (MBR)
|
|
|
|
* PC-BIOS (ISOHYBRID-MBR)
|
|
|
|
* PC-EFI (GPT) [x86_64 only]
|
2012-04-25 03:55:27 +00:00
|
|
|
* Alternative boot methods (configs/releng)
|
|
|
|
* ISO in loopback mode
|
|
|
|
* ISO in memdisk mode
|
|
|
|
* Network booting (PXE) [first stage]
|
|
|
|
* DHCP + TFTP
|
|
|
|
* DHCP + HTTP
|
|
|
|
* HTTP/NFS/NBD [second stage]
|
2011-06-28 05:07:24 +00:00
|
|
|
* Build requirements
|
2011-06-18 21:38:58 +00:00
|
|
|
* Image types generated by mkarchiso.
|
|
|
|
* File format for aitab.
|
|
|
|
* Why the /isolinux and /arch/boot/syslinux directories?
|
2012-03-12 14:35:57 +00:00
|
|
|
* Know issues
|
2011-06-18 21:38:58 +00:00
|
|
|
* Building the most basic Arch Linux live media. (configs/baseline)
|
|
|
|
* Building official Arch Linux live media. (configs/releng)
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-06-22 01:56:57 +00:00
|
|
|
*** Boot parameters (initramfs stage)
|
|
|
|
|
|
|
|
** hooks/archiso
|
|
|
|
|
|
|
|
* archisolabel= Set the filesystem label where archiso files reside.
|
|
|
|
Default: (unset)
|
|
|
|
* archisodevice= Set the device node where archiso medium is located.
|
|
|
|
Default: "/dev/disk/by-label/${archisolabel}"
|
|
|
|
* archisobasedir= Set the base directory where all files reside.
|
|
|
|
Default: "arch"
|
|
|
|
* aitab= Set the path for "aitab" file.
|
|
|
|
Default: ${archisobasedir}/aitab
|
|
|
|
* copytoram= If set to "y" or just "copytoram" without arguments,
|
|
|
|
all SquashFS are copied to "RAM".
|
|
|
|
Default: (unset)
|
2011-08-12 03:10:44 +00:00
|
|
|
* checksum= If set to "y" or just "checksum" without arguments,
|
|
|
|
performs a self-test of all files inside ${install_dir},
|
|
|
|
and continue booting if ok.
|
|
|
|
Default: (unset)
|
2011-10-24 00:24:17 +00:00
|
|
|
* cow_label= Set the filesystem label where COW (dm-snapshot)
|
|
|
|
files must be stored.
|
|
|
|
Default: (unset)
|
|
|
|
* cow_device= Set the device node where COW (dm-snapshot) files
|
|
|
|
must be stored.
|
|
|
|
Default: (unset) or "/dev/disk/by-label/${cow_label}"
|
|
|
|
* cow_directory= Set a directory inside ${cow_device}.
|
|
|
|
Default: "/persistent_${archisolabel}/${arch}"
|
|
|
|
* cow_persistent= Set if snapshots are persistent "P" or non-persistent "N".
|
|
|
|
Default: "N" (if no ${cow_device} is used) otherwise "P".
|
2011-06-22 01:56:57 +00:00
|
|
|
* cowspace_size= Set the size of tmpfs /cowspace. This space is used for
|
|
|
|
Copy-On-Write files of dm-snapshot.
|
|
|
|
Size is in bytes (suffix with "k", "m" and "g") or
|
|
|
|
in percentage of available RAM.
|
|
|
|
Default: "75%"
|
2011-10-24 00:24:17 +00:00
|
|
|
* copytoram_size= Set the size of tmpfs. This space is used for
|
2011-06-22 01:56:57 +00:00
|
|
|
copy of all SquashFS images used, if copytoram=y.
|
|
|
|
Size is in bytes (suffix with "k", "m" and "g") or
|
|
|
|
in percentage of available RAM.
|
|
|
|
Default: "75%"
|
2011-08-09 19:28:52 +00:00
|
|
|
* dm_snap_prefix= Set a prefix for device-mapper snapshot node names.
|
|
|
|
Default: "arch"
|
2011-06-22 01:56:57 +00:00
|
|
|
* arch= Force an architecture type (i686 | x86_64).
|
|
|
|
Do not set it for normal operations.
|
|
|
|
Useful for running a 64 bit kernel / 32 bit userspace.
|
|
|
|
Default: (architecture of running kernel)
|
|
|
|
|
|
|
|
|
2011-11-28 15:28:03 +00:00
|
|
|
** hooks/archiso_pxe_common
|
2011-06-22 01:56:57 +00:00
|
|
|
|
|
|
|
* ip= This parameter is setup automatically by PXELINUX
|
|
|
|
when option "IPAPPEND" is set to 1 or 2 in config.
|
|
|
|
ip=<client-ip>:<boot-server-ip>:<gw-ip>:<netmask>
|
|
|
|
Default: (set via PXE server)
|
|
|
|
* BOOTIF= This parameter is setup automatically by PXELINUX
|
|
|
|
when option "IPAPPEND" is set to 2 or 3 in config.
|
|
|
|
BOOTIF=<hardware-address-of-boot-interface>
|
|
|
|
Default: (set via PXELINUX)
|
2012-05-19 19:16:17 +00:00
|
|
|
* copy_resolvconf= Copy /etc/resolv.conf from initramfs to live-enviroment.
|
|
|
|
Set to "n" to skip them.
|
|
|
|
Default: "y"
|
2011-11-28 15:28:03 +00:00
|
|
|
|
2011-11-28 15:28:03 +00:00
|
|
|
|
2011-11-28 15:28:03 +00:00
|
|
|
** hooks/archiso_pxe_nbd
|
|
|
|
|
2011-07-07 18:24:24 +00:00
|
|
|
* archiso_nbd_name= Set NBD export name used by the server.
|
|
|
|
Default: archiso
|
2011-11-28 15:28:03 +00:00
|
|
|
* archiso_nbd_srv= Set an IP address where NBD reside.
|
2011-12-02 03:44:02 +00:00
|
|
|
If ${pxeserver} is used, PXE IP will be used.
|
|
|
|
Default: (unset)
|
2011-06-22 01:56:57 +00:00
|
|
|
|
|
|
|
|
2011-12-03 21:08:57 +00:00
|
|
|
** hooks/archiso_pxe_http
|
2011-11-28 15:28:03 +00:00
|
|
|
|
2011-12-03 21:20:43 +00:00
|
|
|
* archiso_http_srv= Set an HTTP URL (must end with /) where ${archisobasedir}
|
2011-12-03 20:45:45 +00:00
|
|
|
is found with all *.sfs files.
|
|
|
|
In the IP/domain part if ${pxeserver} is used, use PXE IP.
|
2011-11-28 15:28:03 +00:00
|
|
|
Default: (unset)
|
2011-12-03 21:20:43 +00:00
|
|
|
* archiso_http_spc= Set the size of tmpfs where *.sfs files are downloaded.
|
2011-11-28 15:28:03 +00:00
|
|
|
Default: "75%"
|
|
|
|
|
|
|
|
|
[archiso] Add PXE NFS support
It add support for using *.sfs images via NFS.
It must be located after archiso_pxe_nbd in mkinitcpio.conf, in that way
NBD is the default.
New boot parameters:
archiso_nfs_srv=IP:/path
Set the NFS IP and path. Accepts ${pxeserver} as IP.
archiso_nfs_opt= Sets NFS mount opts (comma separated)
Defaults to:
port = as given by server portmap daemon
rsize = 1024
wsize = 1024
timeo = 7
retrans = 3
acregmin = 3
acregmax = 60
acdirmin = 30
acdirmax = 60
flags = hard, nointr, noposix, cto, ac
:: Running Hook [archiso_pxe_common]
IP-Config: eth0 hardware address 52:54:00:12:34:57 mtu 1500
IP-Config: eth0 guessed broadcast address 192.168.0.255
IP-Config: eth0 guessed nameserver address 192.168.0.218
IP-Config: eth0 complete (from 192.168.0.218):
address: 192.168.0.90 broadcast: 192.168.0.255 netmask: 255.255.255.0
gateway: 192.168.0.218 dns0 : 192.168.0.218 dns1 : 0.0.0.0
rootserver: 192.168.0.218 rootpath:
filename :
:: Running Hook [archiso_pxe_nbd]
:: Running Hook [archiso_pxe_curl]
:: Running Hook [archiso_pxe_nfs]
:: Mounting '192.168.0.77:/mnt/iso'
...
192.168.0.77:/mnt/iso/ on /run/archiso/bootmnt type nfs (rw,relatime,vers=3,rsize=524288,wsize=524288,namlen=255,hard,nolock,proto=tcp,port=65535,timeo=7,retrans=3,sec=sys,local_lock=all,addr=192.168.0.77)
...
My /etc/exports
/mnt/iso 192.168.0.90(ro,no_subtree_check,no_root_squash)
2011-11-28 15:28:03 +00:00
|
|
|
** hooks/archiso_pxe_nfs
|
|
|
|
|
|
|
|
* archiso_nfs_srv= Set the NFS-IP:/path of the server
|
|
|
|
In the IP part if ${pxeserver} is used, PXE IP will be used.
|
|
|
|
Default: (unset)
|
|
|
|
* archiso_nfs_opt= Set NFS mount options separated by comma.
|
|
|
|
Default: (unset, see below)
|
|
|
|
These are the implicit options:
|
|
|
|
port = as given by server portmap daemon
|
|
|
|
rsize = 1024
|
|
|
|
wsize = 1024
|
|
|
|
timeo = 7
|
|
|
|
retrans = 3
|
|
|
|
acregmin = 3
|
|
|
|
acregmax = 60
|
|
|
|
acdirmin = 30
|
|
|
|
acdirmax = 60
|
|
|
|
flags = hard, nointr, noposix, cto, ac
|
|
|
|
|
|
|
|
|
2011-06-22 01:56:57 +00:00
|
|
|
** hooks/archiso_loop_mnt
|
|
|
|
|
2011-10-24 00:24:17 +00:00
|
|
|
* img_label= Set the filesystem label where archiso-image.iso.
|
2011-06-22 01:56:57 +00:00
|
|
|
Default: (unset)
|
2011-10-24 00:24:17 +00:00
|
|
|
* img_dev= Device where archiso-image.iso reside.
|
|
|
|
Default: (unset) or "/dev/disk/by-label/${img_label}"
|
2011-06-22 01:56:57 +00:00
|
|
|
* img_loop= Full path where archiso-image.iso is located on ${img_dev}
|
|
|
|
Default: (unset)
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-04-25 03:55:27 +00:00
|
|
|
*** Transfer ISO image to target medium (configs/releng)
|
|
|
|
|
2012-07-31 22:52:09 +00:00
|
|
|
ISO images names consist of: archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
|
|
|
|
Where:
|
|
|
|
<YYYY> Year
|
|
|
|
<MM> Month
|
|
|
|
<DD> Day
|
|
|
|
<ARCH> i686 | x86_64 | dual(*)
|
|
|
|
|
|
|
|
(*) "dual" includes both i686 and x86_64 architectures.
|
|
|
|
|
|
|
|
|
|
|
|
** To -> CD / DVD / BD
|
|
|
|
|
|
|
|
Note: All ISO images are booteable on a PC-BIOS via "El Torito" in no-emulation mode,
|
|
|
|
All x86_64 ISO images are booteable on a PC-EFI via "El Torito" in no-emulation mode.
|
|
|
|
|
|
|
|
Nomeclature:
|
|
|
|
<B> scsibus number
|
|
|
|
<T> target number
|
|
|
|
<L> lun number
|
|
|
|
(Note: see cdrecord -scanbus, for these numbers)
|
|
|
|
|
|
|
|
|
|
|
|
1) Write it directly using your favorite recording program.
|
2012-07-31 22:52:09 +00:00
|
|
|
# cdrecord dev=<B>,<T>,<L> -dao archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
** To -> USB Flash Drive (USB-key) / Memory card (SD) /
|
|
|
|
Hard-Disk Drive (HDD) / Solid-State Drive (SSD)
|
|
|
|
|
|
|
|
Note: These steps are the general workflow, you can skip some of them,
|
|
|
|
using another filesystem if your bootloader supports it,
|
|
|
|
installing to another directory than "arch/" or using more than
|
|
|
|
one partition. Just ensure that main boot params options
|
|
|
|
(archisolabel= and archisobasedir=) are set correctly according to your setup.
|
|
|
|
|
|
|
|
Nomeclature:
|
|
|
|
<DEV-TARGET>: Device node of the drive where ISO contents should be copied
|
|
|
|
(example: /dev/sdx)
|
|
|
|
<DEV-TARGET-N>: Device node of the partition on <DEV-TARGET>
|
|
|
|
(example: /dev/sdx1)
|
|
|
|
<MNT-TARGET-N>: Mount point path where <DEV-TARGET-N> is mounted
|
|
|
|
(example: /mnt/sdx/1)
|
2012-07-31 22:52:09 +00:00
|
|
|
<ISO-SOURCE>: Path to the ISO file archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
|
|
|
(example: ~/archlinux-2012.07.22-x86_64.iso)
|
2012-04-25 03:55:27 +00:00
|
|
|
<FS-LABEL>: Represents the filesystem label of the <ISO-SOURCE>
|
2012-07-31 22:52:09 +00:00
|
|
|
(example: ARCH_201207 [for all ~/archlinux-2012.07.*.iso])
|
2012-04-25 03:55:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
* PC-BIOS (MBR):
|
|
|
|
|
|
|
|
Note: Using here a MBR partition mode as example, but GPT should also works
|
|
|
|
if machine firmware is not broken.
|
|
|
|
Just ensure that partition is set with attribute "2: legacy BIOS bootable"
|
|
|
|
and use gptmbr.bin instead of mbr.bin for syslinux.
|
|
|
|
|
|
|
|
1) Create one partition entry in MBR (of type "b" for FAT32 or "83" for EXTFS)
|
|
|
|
and mark it as "active" (bootable).
|
|
|
|
# fdisk <DEV-TARGET>
|
|
|
|
|
|
|
|
2) Create a FAT32 or EXTFS filesystem on such partition and setup a label.
|
|
|
|
# mkfs.vfat -F 32 -n <FS-LABEL> <DEV-TARGET-N>
|
|
|
|
# mkfs.ext4 -L <FS-LABEL> <DEV-TARGET-N>
|
|
|
|
|
|
|
|
3) Mount target filesystem.
|
|
|
|
# mount <DEV-TARGET-N> <MNT-TARGET-N>
|
|
|
|
|
|
|
|
4) Extract ISO image on target filesystem.
|
|
|
|
# bsdtar -x --exclude=isolinux/ --exclude=EFI/ -f <ISO-SOURCE> -C <MNT-TARGET-N>
|
|
|
|
|
|
|
|
5) Install syslinux bootloader on target filesystem.
|
|
|
|
# extlinux -i <MNT-TARGET-N>/arch/boot/syslinux
|
|
|
|
|
|
|
|
6) Unmount target filesystem.
|
|
|
|
# umount <MNT-TARGET-N>
|
|
|
|
|
|
|
|
7) Install syslinux MBR boot code on target drive.
|
|
|
|
# dd bs=440 count=1 conv=notrunc if=/usr/lib/syslinux/mbr.bin of=<DEV-TARGET>
|
|
|
|
|
|
|
|
|
|
|
|
* PC-BIOS (ISOHYBRID-MBR):
|
|
|
|
|
|
|
|
Note: This method is the most easily, quick and dirty, but is the most limited
|
|
|
|
if you want to use your target medium for other purposes.
|
|
|
|
|
|
|
|
1) Dump ISO file to target medium.
|
|
|
|
# dd if=<ISO-SOURCE> of=<DEV-TARGET>
|
|
|
|
|
|
|
|
|
|
|
|
* PC-EFI (GPT) [x86_64 only]
|
|
|
|
|
|
|
|
Note: Using here a GPT partition mode as example, but MBR should also works
|
|
|
|
if machine firmware is not broken.
|
|
|
|
|
|
|
|
1) Create one partition entry in GPT (of type "ef00")
|
|
|
|
# gdisk <DEV-TARGET>
|
|
|
|
|
|
|
|
2) Create a FAT32 filesystem on such partition and setup a label.
|
|
|
|
# mkfs.vfat -F 32 -n <FS-LABEL> <DEV-TARGET-N>
|
|
|
|
|
|
|
|
3) Mount target filesystem.
|
|
|
|
# mount <DEV-TARGET-N> <MNT-TARGET-N>
|
|
|
|
|
|
|
|
4) Extract ISO image on target filesystem.
|
|
|
|
# bsdtar -x --exclude=isolinux/ --exclude=arch/boot/syslinux/ -f <ISO-SOURCE> -C <MNT-TARGET-N>
|
|
|
|
|
|
|
|
5) Extract efiboot.img on EFI/ on target filesystem.
|
|
|
|
# mcopy -s -i <MNT-TARGET-N>/EFI/archiso/efiboot.img ::/EFI <MNT-TARGET-N>/
|
|
|
|
|
|
|
|
6) Remove uneeded efiboot.img
|
|
|
|
# rm <MNT-TARGET-N>/EFI/archiso/efiboot.img
|
|
|
|
|
|
|
|
7) Unmount target filesystem.
|
|
|
|
# umount <MNT-TARGET-N>
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-04-25 03:55:27 +00:00
|
|
|
*** Alternative boot methods (configs/releng)
|
|
|
|
|
|
|
|
** ISO in loopback mode.
|
|
|
|
|
|
|
|
Note: Described method is for using with GRUB2.
|
2012-07-31 22:52:09 +00:00
|
|
|
GRUB2 is installed on target media and archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
is at path <TARGET-PATH> on disk <D> and partition <P>,
|
|
|
|
where filesystem is labeled as <TARGET-FS-LABEL>.
|
|
|
|
|
|
|
|
menuentry "Arch Linux (x86_64)" {
|
2012-07-31 22:52:09 +00:00
|
|
|
set isofile="/<TARGET-PATH>/archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso"
|
2012-04-25 03:55:27 +00:00
|
|
|
loopback loop (hd<D>,<P>)$isofile
|
|
|
|
linux (loop)/arch/boot/x86_64/vmlinuz archisolabel=<FS-LABEL> img_label=<TARGET-FS-LABEL> img_loop=$isofile
|
|
|
|
initrd (loop)/arch/boot/x86_64/archiso.img
|
|
|
|
}
|
|
|
|
|
|
|
|
menuentry "Arch Linux (i686)" {
|
2012-07-31 22:52:09 +00:00
|
|
|
set isofile="/<TARGET-PATH>/archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso"
|
2012-04-25 03:55:27 +00:00
|
|
|
loopback loop (hd<D>,<P>)$isofile
|
|
|
|
linux (loop)/arch/boot/i686/vmlinuz archisolabel=<FS-LABEL> img_label=<TARGET-FS-LABEL> img_loop=$isofile
|
|
|
|
initrd (loop)/arch/boot/i686/archiso.img
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
** ISO in memdisk mode.
|
|
|
|
|
|
|
|
Note: Described method is for using with SYSLINUX. Anyway MEMDISK from SYSLINUX can work
|
|
|
|
with other bootloaders.
|
2012-07-31 22:52:09 +00:00
|
|
|
SYSLINUX is installed on target media and archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
is at path <TARGET-PATH>.
|
|
|
|
On 32-bit systems, is needed to pass vmalloc=nnM to the kernel, where nn is the size
|
|
|
|
of the ISO image plus 64 MiB (or 128 MiB).
|
|
|
|
|
|
|
|
|
|
|
|
LABEL arch_x64
|
|
|
|
LINUX memdisk
|
2012-07-31 22:52:09 +00:00
|
|
|
INITRD /<TARGET-PATH>/archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
APPEND iso
|
|
|
|
|
|
|
|
LABEL arch_x32
|
|
|
|
LINUX memdisk
|
2012-07-31 22:52:09 +00:00
|
|
|
INITRD /<TARGET-PATH>/archlinux-<YYYY>.<MM>.<DD>-<ARCH>.iso
|
2012-04-25 03:55:27 +00:00
|
|
|
APPEND iso
|
|
|
|
|
|
|
|
|
|
|
|
** Network booting (PXE).
|
|
|
|
|
|
|
|
All ISOs are ready to act as PXE server, some manual steps are needed
|
|
|
|
to setup the desired PXE boot mode.
|
|
|
|
Alternatively it is possible to use an existing PXE server following the same logic.
|
|
|
|
Note: Setup network first, adjust IP adresses, and respect all slashes "/".
|
|
|
|
|
|
|
|
First stage is for loading kernel and initramfs via PXE, two methods described here:
|
|
|
|
|
|
|
|
* DHCP + TFTP
|
|
|
|
|
|
|
|
Note: All NIC firmwares should support this.
|
|
|
|
|
|
|
|
# dnsmasq --port=0 \
|
|
|
|
--enable-tftp \
|
|
|
|
--tftp-root=/run/archiso/bootmnt \
|
|
|
|
--dhcp-range=192.168.0.2,192.168.0.254,86400 \
|
|
|
|
--dhcp-boot=/arch/boot/syslinux/gpxelinux.0 \
|
|
|
|
--dhcp-option-force=209,boot/syslinux/archiso.cfg \
|
|
|
|
--dhcp-option-force=210,/arch/
|
|
|
|
|
|
|
|
* DHCP + HTTP
|
|
|
|
|
|
|
|
Note: Not all NIC firmware supports HTTP and DNS (if domain name is used).
|
|
|
|
At least this works with iPXE and gPXE.
|
|
|
|
|
|
|
|
# dnsmasq --port=0 \
|
|
|
|
--dhcp-range=192.168.0.2,192.168.0.254,86400 \
|
|
|
|
--dhcp-boot=http://192.168.0.7/arch/boot/syslinux/gpxelinux.0 \
|
|
|
|
--dhcp-option-force=209,boot/syslinux/archiso.cfg \
|
|
|
|
--dhcp-option-force=210,http://192.168.0.7/arch/
|
|
|
|
|
|
|
|
|
|
|
|
Once the kernel is started from PXE, SquashFS files and other misc files
|
|
|
|
inside "arch" directory must be loaded (second stage). One of the following
|
|
|
|
methods can be used to serve the rest of live-medium.
|
|
|
|
|
|
|
|
* HTTP
|
|
|
|
|
|
|
|
# darkhttpd /run/archiso/bootmnt
|
|
|
|
|
|
|
|
|
|
|
|
* NFS
|
|
|
|
|
|
|
|
# echo "/run/archiso/bootmnt 192.168.0.*(ro,no_subtree_check,no_root_squash)" >> /etc/exports
|
|
|
|
# rc.d start rpcbind nfs-common nfs-server
|
|
|
|
|
|
|
|
|
|
|
|
* NBD
|
|
|
|
|
2012-07-31 22:52:09 +00:00
|
|
|
Note: Adjust ARCH_201207 as needed.
|
2012-04-25 03:55:27 +00:00
|
|
|
|
|
|
|
# cat << EOF > /tmp/nbd-server.conf
|
|
|
|
[generic]
|
|
|
|
[archiso]
|
|
|
|
readonly = true
|
2012-07-31 22:52:09 +00:00
|
|
|
exportname = /dev/disk/by-label/ARCH_201207
|
2012-04-25 03:55:27 +00:00
|
|
|
EOF
|
|
|
|
# nbd-server -C /tmp/nbd-server.conf
|
|
|
|
|
|
|
|
|
|
|
|
|
2011-06-28 05:07:24 +00:00
|
|
|
*** Build requirements
|
|
|
|
|
|
|
|
** For mkarchiso script needs these packages (build host):
|
|
|
|
+ squashfs-tools for mksquashfs
|
2011-08-29 04:47:57 +00:00
|
|
|
+ libisoburn for xorriso
|
2012-07-20 20:31:20 +00:00
|
|
|
+ btrfs-progs for mkfs.btrfs (optional)
|
2011-06-28 05:07:24 +00:00
|
|
|
|
[configs/releng] Add UEFI boot support via Linux >= 3.3 EFI boot stub on x86_64
Makes an efiboot.img (FAT16) for "El Torito" (additional).
Under an EFI-system, implies that this .ISO works only if is used
as "CD-ROM/DVD-ROM" not in ISO-HYBRID-MBR mode.
If you want, an EFI-ready USB-key, just unpack this "<ISO>/EFI/efiboot.img" (FAT16) to
"<USB-key-FAT-formatted>/EFI" then copy "<ISO>/arch" and setup the filesystem label.
An aditional EFI shell is provided with an startup script for automatic booting
until EFI_STUB supports "linux.conf" to pass boot parms to kernel.
Anyway I think that is a good idea to keep this shell, so can customize boot parms,
or for doing other tasks on systems without an EFI-shell.
RFCv1: Initial efiboot.img build with vmlinuz.efi (Linux with EFI_STUB enabled)
and archiso.img (initramfs).
RFCv2: Use an startup.nsh with EFI-Shell 2.0 (generated from build.sh) for automatic boot.
RFCv3: Use and older EFI-Shell 1.0 instead of 2.0, since not all UEFI-systems
are compatible with 2.3+ specs.
RFCv4: The script "startup.nsh" improved by Keshav P R, using a for-loop
(see notes below from original commit), now that has more than 1-line,
I moved it to an independent file and is parsed by build.sh.
----
About startup.nsh:
Author: Keshav P R <the.ridikulus.rat@gmail.com>
Date: Thu Apr 5 10:33:20 2012 +0530
[configs/releng] Search in all existing UEFI FS mountpoints for archiso efistub kernel file
There is no guarantee that the efistub kernel will always be in fs0:
(similar to the case inside linux OS where the sda, sdb confusion exists,
hence the need for UUIDs), especially when USB (instead os CD/ISO) is
used for booting.
Hence loop through all possible fs mountpoints (in UEFI) in startup.nsh
and try to launch the first mountpoint that contains the archiso files.
Cd's into the fs%m:\EFI\archiso directory also may remove future issues
with efistub's linux.conf where the efistub might have problems
identifying the directory from which the kernel was launched.
Also add an helpful echo message showing the user the UEFI PATH to the
archiso kernel file being launched by startup.nsh .
Hopefully this should work in both CD and USB. Tested in Tianocore
UDK/EDK2 DuetPkg X64 UEFI 2.3.1 firmware with EdkShellBinPkg's Shell.
----
Signed-off-by: Gerardo Exequiel Pozzi <vmlinuz386@yahoo.com.ar>
2012-04-11 00:01:12 +00:00
|
|
|
** For configs/releng build.sh needs theses packages (build host):
|
|
|
|
+ dosfstools for mkfs.vfat
|
2012-07-24 13:24:45 +00:00
|
|
|
+ patch for patch
|
2012-07-25 18:05:55 +00:00
|
|
|
+ lynx for fetching the latest installation guide
|
[configs/releng] Add UEFI boot support via Linux >= 3.3 EFI boot stub on x86_64
Makes an efiboot.img (FAT16) for "El Torito" (additional).
Under an EFI-system, implies that this .ISO works only if is used
as "CD-ROM/DVD-ROM" not in ISO-HYBRID-MBR mode.
If you want, an EFI-ready USB-key, just unpack this "<ISO>/EFI/efiboot.img" (FAT16) to
"<USB-key-FAT-formatted>/EFI" then copy "<ISO>/arch" and setup the filesystem label.
An aditional EFI shell is provided with an startup script for automatic booting
until EFI_STUB supports "linux.conf" to pass boot parms to kernel.
Anyway I think that is a good idea to keep this shell, so can customize boot parms,
or for doing other tasks on systems without an EFI-shell.
RFCv1: Initial efiboot.img build with vmlinuz.efi (Linux with EFI_STUB enabled)
and archiso.img (initramfs).
RFCv2: Use an startup.nsh with EFI-Shell 2.0 (generated from build.sh) for automatic boot.
RFCv3: Use and older EFI-Shell 1.0 instead of 2.0, since not all UEFI-systems
are compatible with 2.3+ specs.
RFCv4: The script "startup.nsh" improved by Keshav P R, using a for-loop
(see notes below from original commit), now that has more than 1-line,
I moved it to an independent file and is parsed by build.sh.
----
About startup.nsh:
Author: Keshav P R <the.ridikulus.rat@gmail.com>
Date: Thu Apr 5 10:33:20 2012 +0530
[configs/releng] Search in all existing UEFI FS mountpoints for archiso efistub kernel file
There is no guarantee that the efistub kernel will always be in fs0:
(similar to the case inside linux OS where the sda, sdb confusion exists,
hence the need for UUIDs), especially when USB (instead os CD/ISO) is
used for booting.
Hence loop through all possible fs mountpoints (in UEFI) in startup.nsh
and try to launch the first mountpoint that contains the archiso files.
Cd's into the fs%m:\EFI\archiso directory also may remove future issues
with efistub's linux.conf where the efistub might have problems
identifying the directory from which the kernel was launched.
Also add an helpful echo message showing the user the UEFI PATH to the
archiso kernel file being launched by startup.nsh .
Hopefully this should work in both CD and USB. Tested in Tianocore
UDK/EDK2 DuetPkg X64 UEFI 2.3.1 firmware with EdkShellBinPkg's Shell.
----
Signed-off-by: Gerardo Exequiel Pozzi <vmlinuz386@yahoo.com.ar>
2012-04-11 00:01:12 +00:00
|
|
|
|
2011-06-28 05:07:24 +00:00
|
|
|
** For these hooks needs these packages (on target root-image)
|
|
|
|
* archiso
|
|
|
|
+ (none)
|
|
|
|
* archiso_loop_mnt
|
|
|
|
+ (none)
|
2011-11-28 15:28:03 +00:00
|
|
|
* archiso_pxe_common
|
2011-06-28 05:07:24 +00:00
|
|
|
+ mkinitcpio-nfs-utils for ipconfig
|
2011-11-28 15:28:03 +00:00
|
|
|
* archiso_pxe_nbd
|
2011-06-28 05:07:24 +00:00
|
|
|
+ nbd for nbd-client
|
2011-12-03 21:08:57 +00:00
|
|
|
* archiso_pxe_http
|
2011-11-28 15:28:03 +00:00
|
|
|
+ curl for curl
|
[archiso] Add PXE NFS support
It add support for using *.sfs images via NFS.
It must be located after archiso_pxe_nbd in mkinitcpio.conf, in that way
NBD is the default.
New boot parameters:
archiso_nfs_srv=IP:/path
Set the NFS IP and path. Accepts ${pxeserver} as IP.
archiso_nfs_opt= Sets NFS mount opts (comma separated)
Defaults to:
port = as given by server portmap daemon
rsize = 1024
wsize = 1024
timeo = 7
retrans = 3
acregmin = 3
acregmax = 60
acdirmin = 30
acdirmax = 60
flags = hard, nointr, noposix, cto, ac
:: Running Hook [archiso_pxe_common]
IP-Config: eth0 hardware address 52:54:00:12:34:57 mtu 1500
IP-Config: eth0 guessed broadcast address 192.168.0.255
IP-Config: eth0 guessed nameserver address 192.168.0.218
IP-Config: eth0 complete (from 192.168.0.218):
address: 192.168.0.90 broadcast: 192.168.0.255 netmask: 255.255.255.0
gateway: 192.168.0.218 dns0 : 192.168.0.218 dns1 : 0.0.0.0
rootserver: 192.168.0.218 rootpath:
filename :
:: Running Hook [archiso_pxe_nbd]
:: Running Hook [archiso_pxe_curl]
:: Running Hook [archiso_pxe_nfs]
:: Mounting '192.168.0.77:/mnt/iso'
...
192.168.0.77:/mnt/iso/ on /run/archiso/bootmnt type nfs (rw,relatime,vers=3,rsize=524288,wsize=524288,namlen=255,hard,nolock,proto=tcp,port=65535,timeo=7,retrans=3,sec=sys,local_lock=all,addr=192.168.0.77)
...
My /etc/exports
/mnt/iso 192.168.0.90(ro,no_subtree_check,no_root_squash)
2011-11-28 15:28:03 +00:00
|
|
|
* archiso_pxe_nfs
|
|
|
|
+ mkinitcpio-nfs-utils for nfsmount
|
2011-10-24 00:24:18 +00:00
|
|
|
* archiso_shutdown
|
|
|
|
+ (none)
|
2011-06-28 05:07:24 +00:00
|
|
|
|
|
|
|
|
2011-06-18 21:38:58 +00:00
|
|
|
*** Image types generated by mkarchiso.
|
|
|
|
|
|
|
|
* image-name.sfs SquashFS image with all files directly on it.
|
|
|
|
* image-name.fs.sfs SquashFS with only one file inside (image-name.fs),
|
|
|
|
which is an image of some type of filesystem
|
|
|
|
(ext4, ext3, ext2, xfs), all files reside on it.
|
|
|
|
|
|
|
|
|
|
|
|
*** File format for aitab.
|
|
|
|
|
|
|
|
The aitab file holds information about the filesystems images that must be
|
|
|
|
created by mkarchiso and mounted at initramfs stage from the archiso hook.
|
|
|
|
It consists of some fields which define the behaviour of images.
|
|
|
|
|
|
|
|
# <img> <mnt> <arch> <sfs_comp> <fs_type> <fs_size>
|
|
|
|
|
|
|
|
<img> Image name without extension (.fs .fs.sfs .sfs).
|
|
|
|
<mnt> Mount point.
|
|
|
|
<arch> Architecture { i686 | x86_64 | any }.
|
|
|
|
<sfs_comp> SquashFS compression type { gzip | lzo | xz }.
|
2012-07-23 14:51:00 +00:00
|
|
|
<fs_type> Set the filesystem type of the image
|
|
|
|
{ ext4 | ext3 | ext2 | xfs | btrfs }.
|
2011-06-18 21:38:58 +00:00
|
|
|
A special value of "none" denotes no usage of a filesystem.
|
|
|
|
In that case all files are pushed directly to SquashFS filesystem.
|
|
|
|
<fs_size> An absolute value of file system image size in MiB.
|
|
|
|
(example: 100, 1000, 4096, etc)
|
|
|
|
A relative value of file system free space [in percent].
|
|
|
|
{1%..99%} (example 50%, 10%, 7%).
|
|
|
|
This is an estimation, and calculated in a simple way.
|
|
|
|
Space used + 10% (estimated for metadata overhead) + desired %
|
|
|
|
|
|
|
|
|
|
|
|
*** Why the /isolinux and /arch/boot/syslinux directories?
|
|
|
|
|
|
|
|
The /isolinux directory holds files needed for the ISOLINUX boot loader
|
|
|
|
module of SYSLINUX. ISOLINUX can not find config files on
|
|
|
|
/arch/boot/syslinux, like other boot loaders modules (EXTLINUX, SYSLINUX, etc).
|
|
|
|
When make your custom boot-pendrive, you need to copy /arch directory to it.
|
|
|
|
/isolinux/isolinux.cfg just holds /arch/boot/syslinux/syslinux.cfg
|
|
|
|
|
|
|
|
|
2012-03-12 14:35:57 +00:00
|
|
|
*** Know issues
|
|
|
|
|
|
|
|
** On shutdown there are two steps that [FAIL]:
|
|
|
|
"Unmounting Swap-backed Filesystems" and "Unmounting Non-API Filesystems",
|
|
|
|
These filesystem are in use at this stage by archiso, but...
|
|
|
|
This is not a real issue since, all mounted filesystem, loopback devices
|
|
|
|
and device mapper devices made by archiso will be "free" on "shutdown tmpfs"
|
|
|
|
(A.K.A deinitramfs), build at initramfs by [archiso_shutdown] initcpio hook.
|
|
|
|
|
2011-06-18 21:38:58 +00:00
|
|
|
|
|
|
|
*** Building the most basic Arch Linux live media. (configs/baseline)
|
|
|
|
|
2012-03-16 05:08:21 +00:00
|
|
|
* Install needed packages.
|
2012-04-17 22:37:44 +00:00
|
|
|
# pacman -S git make squashfs-tools libisoburn rsync --needed
|
2011-06-18 21:38:58 +00:00
|
|
|
|
2012-03-16 05:08:21 +00:00
|
|
|
* Install archiso.
|
|
|
|
# git clone git://projects.archlinux.org/archiso.git
|
2012-08-03 20:35:08 +00:00
|
|
|
# make -C archiso install
|
2011-06-18 21:38:58 +00:00
|
|
|
|
|
|
|
* Build a basic iso.
|
2012-03-16 05:08:21 +00:00
|
|
|
# /usr/share/archiso/configs/baseline/build.sh
|
2011-06-18 21:38:58 +00:00
|
|
|
|
|
|
|
Note: If you want to customize, just see the configs/releng directory which is
|
|
|
|
used to build official images with much more things.
|
|
|
|
|
|
|
|
|
|
|
|
*** Building official Arch Linux live media. (configs/releng)
|
|
|
|
|
2012-03-16 05:08:21 +00:00
|
|
|
* Install needed packages.
|
2012-07-31 22:52:09 +00:00
|
|
|
# pacman -S git make squashfs-tools libisoburn dosfstools lynx patch --needed
|
2011-06-22 01:56:57 +00:00
|
|
|
|
2012-03-16 05:08:21 +00:00
|
|
|
* Install archiso.
|
|
|
|
# git clone git://projects.archlinux.org/archiso.git
|
2012-08-03 20:35:08 +00:00
|
|
|
# make -C archiso install
|
2011-06-22 01:56:57 +00:00
|
|
|
|
2012-03-16 20:40:48 +00:00
|
|
|
* Build them!
|
2012-07-31 22:52:09 +00:00
|
|
|
# /usr/share/archiso/configs/releng/build.sh build all
|
2011-06-22 01:56:57 +00:00
|
|
|
|
2012-03-16 20:40:48 +00:00
|
|
|
Note: See build.sh -h for more options.
|