Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
Beide Seiten der vorigen RevisionVorhergehende ÜberarbeitungNächste Überarbeitung | Vorhergehende ÜberarbeitungNächste ÜberarbeitungBeide Seiten der Revision | ||
software:linux:emdebian:rootfs_erstellen [2014-10-08 15:26] – graf | software:linux:emdebian:rootfs_erstellen [2014-10-09 10:00] – graf | ||
---|---|---|---|
Zeile 3: | Zeile 3: | ||
Der Speicherort des Root-Filesystems ist im Kernel fix einprogrammiert und lässt sich ändern mit //rdev//. Zum Root-Filesystem gehören einige wenige Toplevel-Verzeichnisse und die darin enthaltenen Unterverzeichnisse. | Der Speicherort des Root-Filesystems ist im Kernel fix einprogrammiert und lässt sich ändern mit //rdev//. Zum Root-Filesystem gehören einige wenige Toplevel-Verzeichnisse und die darin enthaltenen Unterverzeichnisse. | ||
- | <box red right 35% | **Wichtig**> | + | <box red right 60% | **Wichtig**> |
- | Ein Root-Filesystem kann mit Multistrap sehr einfach und elegant erstellt werden. Allerdings sind die Speicheranforderungen relativ hoch. | + | Ein Root-Filesystem kann mit Multistrap sehr einfach und elegant erstellt werden. Allerdings sind die Speicheranforderungen relativ hoch. Mit Buildroot reduziert sich die Grösse stark, allerdings bedingt das einen grösseren Aufwand (siehe weiter unten). Die Unterschiede werden in diesem [[http:// |
</ | </ | ||
Zeile 25: | Zeile 25: | ||
==== Erstellen ==== | ==== Erstellen ==== | ||
- | Achtung: Problem mit Ubuntu: siehe [[https:// | + | - Multistrap-Konfiguration im aktuellen Arbeitsverzeichnis erstellen (Achtung: Problem mit Ubuntu: siehe [[https:// |
- | - Multistrap Konfiguration erstellen: < | + | ... |
- | arch=powerpc | + | |
- | directory=/ | + | |
- | cleanup=true | + | |
- | retainsources= | + | |
- | noauth=true | + | |
- | unpack=true | + | |
- | bootstrap=Grip | + | |
- | aptsources=Grip Debian | + | |
[Grip] | [Grip] | ||
- | packages=ifupdown procps iputils-ping module-init-tools openssh-server nano | + | ... |
- | source=http:// | + | |
- | keyring=emdebian-archive-keyring | + | |
- | suite=wheezy-grip | + | |
[Debian] | [Debian] | ||
- | packages= | + | ... |
- | source=http:// | + | |
- | keyring=debian-archive-keyring | + | |
- | suite=wheezy | + | |
</ | </ | ||
- | - Root File System bootstrappen: | + | - Root File System bootstrappen. Dies erstellt ein Grundsystem im Verzeichnis ''/ |
- | ==== Automatisches Build Skript | + | - Skript für automatische Konfiguration erstellen: < |
- | Das folgende Skript erstellt automatisch ein neues RootFS-Image. | + | export DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true |
- | < | + | export LC_ALL=C LANGUAGE=C LANG=C |
- | #!/bin/bash | + | / |
+ | dpkg --configure -a | ||
+ | mount proc -t proc /proc | ||
+ | dpkg --configure -a</ | ||
+ | - Konfigurationsskript ausführbar machen: < | ||
+ | - schroot Konfiguration erstellen: < | ||
+ | description=My schroot Configuration for Emdebian Grip Wheezy | ||
+ | aliases=my-emdebian | ||
+ | type=directory | ||
+ | directory=/ | ||
+ | root-groups=root | ||
+ | users=$USER | ||
+ | groups=sbuild</ | ||
+ | - Untere Adresslimitierung für Qemu deaktivieren: | ||
+ | - Qemu-Binary in das eben erstellte Root-Filesystem kopieren: < | ||
+ | - chroot Umgebung betreten (in Arbeitsverzeichnis ausführen): | ||
+ | - Konfigurationsskipt ausführen: < | ||
+ | - Root Passwort festlegen: | ||
+ | - APT Cache löschen: < | ||
+ | - chroot Umgebung wieder verlassen: < | ||
+ | - Mount-Punkte festlegen: < | ||
+ | / | ||
+ | proc / | ||
+ | ...</ | ||
+ | - Serielles Terminal konfigurieren (board-spezifisch). | ||
+ | * Editieren von ''/ | ||
+ | * Sicherstellen, | ||
+ | - Netzwerkkonfiguration (passend für NTB-Netz): < | ||
+ | iface lo inet loopback | ||
- | MULTISTRAP_CONFIG=myConfig.grip.multistrap # give name of configuration | + | auto eth0 |
- | ROOTFS_DIR=/ | + | iface eth0 inet static |
- | ROOTFS_IMG=rootfs.jffs2 # choose a suitable file system format | + | |
- | FILE_DIR=files | + | |
- | DEV_TABLE=device_table | + | |
+ | - Hostname konfigurieren: | ||
+ | - Bash primary promt string (PS1-String) anpassen: < | ||
+ | - Die Zeile: < | ||
+ | - Ersetzen durch: < | ||
+ | - Qemu-Binary im erstellten Root FS wieder löschen: < | ||
+ | - Device Node Tabelle im aktuellen Arbeitsverzeichnis erstellen (board-spezifisch): | ||
+ | / | ||
+ | ...</ | ||
+ | - Dateisystemabbild erzeugen: < | ||
+ | <WRAP center round tip 80%> | ||
+ | Man kann das Image mit etwas Handarbeit verkleinern, | ||
+ | </ | ||
- | set -e | ||
- | echo " | + | ==== Automatisches Build Skript ==== |
- | if [ ! -d $ROOTFS_DIR ]; then mkdir -p $ROOTFS_DIR; | + | Ein Root-Filesystem kann auch mit einem automatischen Build-Script erstellt werden. Das folgende {{: |
- | export MULTISTRAP_OUTPUT_DIR=$ROOTFS_DIR | + | |
- | multistrap | + | |
- | + | ||
- | echo " | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | if [ ! -d $ROOTFS_DIR/ | + | |
- | # more folders ... | + | |
- | + | ||
- | echo " | + | |
- | cp -v $FILE_DIR/ | + | |
- | cp -v $FILE_DIR/ | + | |
- | cp -v $FILE_DIR/ | + | |
- | touch $ROOTFS_DIR/ | + | |
- | # more config files ... | + | |
- | + | ||
- | echo " | + | |
- | cp -v $FILE_DIR/ | + | |
- | cp -v $FILE_DIR/ | + | |
- | cp -v $FILE_DIR/ | + | |
- | cp -v $FILE_DIR/ | + | |
- | # more scripts ... | + | |
- | + | ||
- | echo " | + | |
- | if [ ! -L $ROOTFS_DIR/ | + | |
- | if [ ! -L $ROOTFS_DIR/ | + | |
- | if [ ! -L $ROOTFS_DIR/ | + | |
- | if [ ! -L $ROOTFS_DIR/ | + | |
- | + | ||
- | echo " | + | |
- | mkfs.jffs2 -n -e 0x20000 -p 0x20000 -D $DEV_TABLE -l -d $ROOTFS_DIR -o $ROOTFS_IMG | + | |
- | echo "All done!" | + | ===== Buildroot ===== |
- | </code> | + | Wir benutzen [[http:// |
+ | TODO |