5.1. Opstart af installationsprogrammet på 32-bit hard-float ARMv7

5.1.1. Formater for opstartsaftryk

På ARM-baserede systemer bruges i de fleste tilfælde et af to formater for opstartsaftryk: a) gængse Linux zImage-formatkerner (vmlinuz) i samarbejde med gængse Linux initial-ramdisk (initrd.gz) eller b) uImage-formatkerner (uImage) i samarbejde med tilsvarende initial ramdisk (uInitrd).

uImage/uInitrd er aftryksformater designet for firmwaren U-Boot, som bruges på mange ARM-baserede systemer (hovedsagelig 32-bit). Ældre versioner af U-Boot kan kun opstarte filer i uImage/uInitrd-formatet, så de bruges ofte på ældre armel-systemer. Nyere versioner af U-Boot kan - udover opstarte uImages/uInitrds - også opstarte standardkerner med Linux og ramdisk-aftryk, men kommandosyntaksen til dette er en smule anderledes end at starte fra uImages.

For systemer der bruger en kerne for flere platforme, udover kerne og initiel ramdisk, er en såkaldt enhedstræfil krævet (eller enhedstræ blob, dtb). Den er specifik for hvert understøttet system og indeholder en beskrivelse af det specifikke udstyr. Dtb'en skal angives på enheden af firmwaren, men i praksis skal en ny ofte indlæses.

5.1.2. Konsolkonfiguration

Netboot tarball (Afsnit 5.1.3.2, “Pre-built netboot tarball”), og installationsaftrykket for SD-kort (Afsnit 5.1.5, “Using pre-built SD-card images with the installer”) bruger standardkonsollen (platformspecifik), som er defineret af U-Boot i variablen console. I de fleste tilfælde er det en seriel konsol, så på de fleste platforme skal du som standard brug et serielt konsolkabel for at bruge installationsprogrammet.

På platforme som også understøtter en videokonsol, så kan du ændre U-Boot variablen console tilsvarende, hvis du ønsker, at installationsprogrammet skal starte på videokonsollen.

5.1.3. Opstart med TFTP

Opstart fra netværket kræver, at du har en netværksforbindelse og en TFTP-netværksopstartsserver (og sandsynligvis også en DHCP-, RARP- eller BOOTP-server for automatisk netværkskonfiguration).

Opsætningen på serversiden for understøttelse af netværksopstart er beskrevet i Afsnit 4.3, “Forberedelse af filer for TFTP-netopstart”.

5.1.3.1. TFTP-opstart i U-Boot

Netværksopstart på systemer, der bruger firmwaren U-Boot, består af tre trin: a) konfiguration af netværket, b) indlæsning af aftrykket (kerne/initiel ramdisk/dtb) i hukommelsen og c) faktisk kørsel af den tidligere indlæste kode.

Først skal du konfigurere netværket, enten automatisk via DHCP ved at køre

setenv autoload no
dhcp

eller manuelt ved at indstille flere miljøparametre

setenv ipaddr <ip-adresse for klienten>
setenv netmask <netmaske>
setenv serverip <ip-adresse for tftp-serveren>
setenv dnsip <ip-adresse for navneserveren>
setenv gatewayip <ip-adresse for standardadgangspunktet>

Hvis du foretrækker det kan du foretage disse indstillinger ved at køre

saveenv

Efterfølgende skal du indlæse aftrykkene (kerne/intiel ramdisk/dtb) i hukommelsen. Dette gøres med kommandoen tftpboot, som skal have adressen hvor aftrykket skal lagres i hukommelsen. Desværre kan hukommelseskortet variere fra system til system, så der er ingen generel regel om, hvilke adresser som kan bruges.

On some systems, U-Boot predefines a set of environment variables with suitable load addresses: kernel_addr_r, ramdisk_addr_r and fdt_addr_r. You can check whether they are defined by running

printenv kernel_addr_r ramdisk_addr_r fdt_addr_r

If they are not defined, you have to check your system's documentation for appropriate values and set them manually. For systems based on Allwinner SunXi SOCs (e.g. the Allwinner A10, architecture name sun4i or the Allwinner A20, architecture name sun7i), you can e.g. use the following values:

setenv kernel_addr_r 0x46000000
setenv fdt_addr_r 0x47000000
setenv ramdisk_addr_r 0x48000000

Når indlæsningsadresserne er defineret, så kan du indlæse aftrykket i hukommelsen fra den tidligere definerede tftp-server med

tftpboot ${kernel_addr_r} <filnavn for kerneaftrykket>
tftpboot ${fdt_addr_r} <filnavn for dtb'en>
tftpboot ${ramdisk_addr_r} <filnavn for det initielle ramdisk-aftryk>

Tredjeparten indstiller kernens kommandolinje og kører den indlæste kode. U-boot videresender indholdet af miljøvariablen bootargs som kommandolinje til kernen, så eventuelle parametre for kernen og installationsprogrammet - såsom konsolenheden (se Afsnit 5.3.1, “Opstartskonsol”) eller forudfyldte indstillinger (se Afsnit 5.3.2, “Parametre for Debian-installationsprogrammet” og Appendiks B, Automatisering af installationen med preseeding (forhåndskonfiguration)) - kan sættes med en kommando som

setenv bootargs console=ttyS0,115200 rootwait panic=10

Den præcise kommando til at køre den tidligere indlæste kode afhænger af det anvendte aftryksformat. Med uImage/uInitrd er kommandoen

bootm ${kernel_addr_r} ${ramdisk_addr_r} ${fdt_addr_r}

og med standardaftryk for Linux er det

bootz ${kernel_addr_r} ${ramdisk_addr_r}:${filesize} ${fdt_addr_r}

Bemærk: Når der opstartes standardaftryk for Linux, så er det vigtigt at indlæse det oprindelige ramdisk-aftryk efter kernen og dtb'en, da U-Boot angiver filstørrelsesvariablen til størrelsen på den sidst indlæste fil og kommandoen bootz kræver størrelsen af ramdisk-aftrykket for at fungere korrekt. I tilfælde hvor der opstartes en platformspecifik kerne, d.v.s. en kerne uden enhedstræ, udelades parameteren ${fdt_addr_r}.

5.1.3.2. Pre-built netboot tarball

Debian provides a pre-built tarball ( .../images/netboot/netboot.tar.gz ) that can simply be unpacked on your tftp server and contains all files necessary for netbooting. It also includes a boot script that automates all steps to load the installer. Modern U-Boot versions contain a tftp autoboot feature that becomes active if there is no bootable local storage device (MMC/SD, USB, IDE/SATA/SCSI) and then loads this boot script from the tftp server. Prerequisite for using this feature is that you have a dhcp server in your network which provides the client with the address of the tftp server.

Hvis du ønsker at udløse tftp autoboot-funktionen fra U-Boot-kommandolinjen, så kan du bruge den følgende kommando:

run bootcmd_dhcp

For manuelt at indlæse opstartsskriptet leveret med tarball'en, så kan du alternativt udstede de følgende kommandoer ved U-Boot-prompten:

setenv autoload no
dhcp
tftpboot ${scriptaddr} /debian-installer/armhf/tftpboot.scr
source ${scriptaddr}

5.1.4. Opstart fra et USB-hukommelsesdrev i U-Boot

Mange moderne U-Boot-versioner har USB-understøttelse og tillader opstart fra USB-lagerenheder såsom USB-drev. Desværre er de præcise trin krævet for dette forskellige fra enhed til enhed.

U-Boot v2014.10 har introduceret en fælles kommandolinjehåndtering og autoboot-ramme. Dette giver mulighed for at bygge generiske opstartsaftryk, som fungerer på ethvert system, der implementerer denne ramme. debian-installer understøtter installation fra et USB-drev på sådanne systemer, men desværre har ikke alle platforme adopteret denne nye ramme endnu.

For at bygge et USB-drev, der kan startes op fra, til installation af Debian udpakkes hd-media-tarball'en (se Afsnit 4.2.1, “Her kan du finde installationsaftryk”) til et USB-drev formateret med et filsystem, der understøtter U-Boot-versionen på din enhed. For moderne U-Boot-versioner, fungerer enhver FAT16/FAT32/ext2/ext3/ext4 normalt. Kopier så ISO-aftryksfilen fra den første Debian-installations-cd eller dvd til drevet.

Autoboot-rammen i moderne U-Boot-versioner fungerer på samme måde som indstillingerne for opstartsrækkefølgen i en PC BIOS, dvs. den kontrollerer en liste over mulige opstartsenheder for et gyldigt opstartsaftryk og starer den første den finder. Hvis der ikke er et operativsystem installeret, vil indsættelse af USB-drevet og opstart af systemet resultere i en start af installationsprogrammet. Du kan også igangsætte USB-opstartsprocessen fra u-boot-prompten ved at indtaste kommandoen run bootcmd_usb0.

Et problem som kan fremkomme, når der startes op fra et USB-drev, mens der anvendes en seriel konsol er en konsols baudhastighedsforskel. Hvis en konsolvariabel er defineret i U-Boot, sender debian-installer-opstartskriptet automatisk den til kernen for at sætte den primære konsolenhed og, hvis anvendelig, konsollens baudhastighed. Desværre varierer håndteringen af konsollens variabler fra platform til platform - på nogle platforme inkluderer konsolvariablen baudhastigheden (som i console=ttyS0,115200), mens på andre platforme indeholder konsolvariablen kun enheden (som i console=ttyS0). Det sidste tilfælde fører til et forvansket konsolresultat, når standardbauthastigheden er forskellig mellem U-Boot og kernen. Moderen U-Boot-versioner bruger ofte 115200 baud mens kernen stadig har en standard å de traditionelle 9600 baud. Hvis dette opstår, så skal du manuelt sætte konsolvariablen til at indeholde den korrekte baudhastighed for dit system og så starte installationsprogrammet med kommandoen run bootcmd_usb0.

5.1.5. Using pre-built SD-card images with the installer

For a number of systems, Debian provides SD card images that contain both U-Boot and the debian-installer. These images are provided in two variants - one for downloading the software packages over the network (available at .../images/netboot/SD-card-images/ ) and one for offline installations using a Debian CD/DVD (available at .../images/hd-media/SD-card-images/ ). To save space and network bandwidth, the images consist of two parts - a system-dependent part named firmware.<system-type>.img.gz, and a system-independent part named partition.img.gz.

To create a complete image from the two parts on Linux systems, you can use zcat as follows:

zcat firmware.<system-type>.img.gz partition.img.gz 
> complete_image.img

On Windows systems, you have to first decompress the two parts separately, which can be done e.g. by using 7-Zip, and then concatenate the decompressed parts together by running the command

copy /b firmware.<system-type>.img + partition.img complete_image.img

in a Windows CMD.exe window.

Write the resulting image onto an SD card, e.g. by running the following command on a Linux system:

cat complete_image.img 
> /dev/SD_CARD_DEVICE

After plugging the SD card into the target system and powering the system up, the installer is loaded from the SD card. If you use the hd-media variant for offline installations, you must provide the installer with access to the first Debian CD/DVD on a separate medium, which can e.g. be a CD/DVD ISO image on a USB stick.

When you come to the partitioning step in the installer (see Afsnit 6.3.3, “Partitionering og valg af monteringspunkt”), you can delete or replace any previous partitions on the card. Once the installer is started, it runs completely in the system's main memory and does not need to access the SD card anymore, so you can use the full card for installing Debian. The easiest way to create a proper partition layout on the SD card is to let the installer automatically create one for you (see Afsnit 6.3.3.2, “Vejledt partitionering”).