Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.

Link zu dieser Vergleichsansicht

Beide Seiten der vorigen RevisionVorhergehende Überarbeitung
Nächste Überarbeitung
Vorhergehende Überarbeitung
Letzte ÜberarbeitungBeide Seiten der Revision
software:linux:emdebian:rootfs_erstellen [2014-10-08 16:36] grafsoftware:linux:emdebian:rootfs_erstellen [2014-10-09 11:51] 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://mind.be/content/Presentation_Emdedded-distro-shootout.pdf|Artikel]] gut gezeigt.
 </box> </box>
  
Zeile 25: Zeile 25:
  
 ==== Erstellen ==== ==== Erstellen ====
-FIXME Achtung: Problem mit Ubuntu: siehe [[https://bugs.launchpad.net/ubuntu/+source/multistrap/+bug/1313787]] +  - Multistrap-Konfiguration im aktuellen Arbeitsverzeichnis erstellen (Achtung: Problem mit Ubuntu: siehe [[https://bugs.launchpad.net/ubuntu/+source/multistrap/+bug/1313787]], ''/usr/sbin/multistrap'' muss abgeändert werden): <code>nano myBoard.multistrap</code> <file - myBoard.multistrap> [General]
-  - Multistrap-Konfiguration im aktuellen Arbeitsverzeichnis erstellen: <code>nano myBoard.multistrap</code> <file - myBoard.multistrap> [General]+
 ... ...
  
Zeile 53: Zeile 52:
 groups=sbuild</file> groups=sbuild</file>
   - Untere Adresslimitierung für Qemu deaktivieren: <code>echo 0 > /proc/sys/vm/mmap_min_addr</code>   - Untere Adresslimitierung für Qemu deaktivieren: <code>echo 0 > /proc/sys/vm/mmap_min_addr</code>
-  - Qemu-Binary in das eben erstellte Root-Filesystem kopieren: FIXME<code>cp /usr/bin/qemu-ppc-static /opt/multistrap/usr/bin/</code>+  - Qemu-Binary in das eben erstellte Root-Filesystem kopieren (Achtung: hier muss das passende Binary ausgewählt werden): <code>cp /usr/bin/qemu-ppc-static /opt/multistrap/usr/bin/</code>
   - chroot Umgebung betreten (in Arbeitsverzeichnis ausführen): <code>schroot -c my-emdebian-grip</code>   - chroot Umgebung betreten (in Arbeitsverzeichnis ausführen): <code>schroot -c my-emdebian-grip</code>
-  - Konfigurationsskipt ausführen: FIXME<code>(my-emdebian-grip)$ /autoconfig.sh</code>+  - Konfigurationsskipt ausführen: <code>(my-emdebian-grip)$ /autoconfig.sh</code>
   - Root Passwort festlegen: <code>(my-emdebian-grip)$ passwd</code>   - Root Passwort festlegen: <code>(my-emdebian-grip)$ passwd</code>
   - APT Cache löschen: <code>(my-emdebian-grip)$ apt-get clean</code>   - APT Cache löschen: <code>(my-emdebian-grip)$ apt-get clean</code>
Zeile 78: Zeile 77:
     - Die Zeile: <code>PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '</code>     - Die Zeile: <code>PS1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ '</code>
     - Ersetzen durch: <code>PS1='[MY_TARGET] \u@\h:\w\$ '</code>     - Ersetzen durch: <code>PS1='[MY_TARGET] \u@\h:\w\$ '</code>
-  - Qemu-Binary im erstellten Root FS wieder löschen: <code>rm /opt/multistrap/usr/bin/qemu-ppc-static</code> +  - Qemu-Binary im erstellten Root FS wieder löschen (Achtung: hier muss wiederum das passende Binary ausgewählt werden): <code>rm /opt/multistrap/usr/bin/qemu-ppc-static</code> 
-  - Device Node Tabelle erstellen (board-spezifisch): <code># nano device_table</code> <file - device_table># name type mode uid gid major minor start inc count+  - Device Node Tabelle im aktuellen Arbeitsverzeichnis erstellen (board-spezifisch): <code># nano device_table</code> <file - device_table># name type mode uid gid major minor start inc count
 /dev/console c 600 0 0 5 1 0 0 - /dev/console c 600 0 0 5 1 0 0 -
 ...</file> ...</file>
 +  - Dateisystemabbild erzeugen: <code># mkfs.jffs2 -n -e 0x40000 -p 0x40000 -b -d /opt/multistrap -D device_table -o my-rfs.jffs2</code> 
 +<WRAP center round tip 80%> 
 +Man kann das Image mit etwas Handarbeit verkleinern, indem vor dem Erzeugen des Images z.B. folgende Verzeichnisse gelöscht werden: ''/var/cache/'', ''/var/lib/dpkg/info/'', ''/usr/share/zoneinfo/'', ''/usr/share/perl/'', ''/usr/share/perl5/'', ''/usr/share/doc/''
 +</WRAP>
  
  
 ==== Automatisches Build Skript ==== ==== Automatisches Build Skript ====
-Das folgende Skript erstellt automatisch ein neues RootFS-Image. +Ein Root-Filesystem kann auch mit einem automatischen Build-Script erstellt werdenDas folgende {{:software:linux:emdebian:buildscript.sh|Skript}} zeigt ein Beispiel.
-<code bash> +
-#!/bin/bash +
- +
-MULTISTRAP_CONFIG=myConfig.grip.multistrap # give name of configuration file +
-ROOTFS_DIR=/opt/multistrap +
-ROOTFS_IMG=rootfs.jffs2 # choose a suitable file system format +
-FILE_DIR=files +
-DEV_TABLE=device_table +
- +
-set -+
- +
-echo "Multistrapping... " +
-if [ ! -d $ROOTFS_DIR ]; then mkdir -p $ROOTFS_DIR; fi +
-export MULTISTRAP_OUTPUT_DIR=$ROOTFS_DIR +
-multistrap -f $MULTISTRAP_CONFIG +
- +
-echo "Create missing folders on rootfs..." +
-if [ ! -d $ROOTFS_DIR/etc/network ]; then mkdir -p $ROOTFS_DIR/etc/network; fi +
-if [ ! -d $ROOTFS_DIR/etc/init.d ]; then mkdir -p $ROOTFS_DIR/etc/init.d; fi +
-if [ ! -d $ROOTFS_DIR/etc/dhcp3 ]; then mkdir -p $ROOTFS_DIR/etc/dhcp3; fi +
-if [ ! -d $ROOTFS_DIR/etc/apt/apt.conf.d/ ]; then mkdir -p $ROOTFS_DIR/etc/apt/apt.conf.d; fi +
-if [ ! -d $ROOTFS_DIR/lib/modules/2.6.31 ]; then mkdir -p $ROOTFS_DIR/lib/modules/2.6.31; fi +
-if [ ! -d $ROOTFS_DIR/dev/shm ]; then mkdir -p $ROOTFS_DIR/dev/shm; fi +
-if [ ! -d $ROOTFS_DIR/usr/share/man/man1 ]; then mkdir -p $ROOTFS_DIR/usr/share/man/man1; fi +
-if [ ! -d $ROOTFS_DIR/usr/share/man/man7 ]; then mkdir -p $ROOTFS_DIR/usr/share/man/man7; fi +
-# more folders ... +
- +
-echo "Copying config files to rootfs..." +
-cp -v $FILE_DIR/fstab $ROOTFS_DIR/etc/ +
-cp -v $FILE_DIR/hostname $ROOTFS_DIR/etc/ +
-cp -v $FILE_DIR/passwd $ROOTFS_DIR/etc/ +
-touch $ROOTFS_DIR/lib/modules/2.6.31/modules.dep +
-# more config files ... +
- +
-echo "Copying scripts to rootfs..." +
-cp -v $FILE_DIR/kversion $ROOTFS_DIR/opt/ntb/ +
-cp -v $FILE_DIR/hwversion $ROOTFS_DIR/opt/ntb/ +
-cp -v $FILE_DIR/hwclockfirst.sh $ROOTFS_DIR/etc/init.d/hwclockfirst.sh +
-cp -v $FILE_DIR/serial_config $ROOTFS_DIR/opt/ntb/ +
-# more scripts ... +
- +
-echo "Creating missing links on rootfs..." +
-if [ ! -L $ROOTFS_DIR/etc/mtab ]; then ln -v -s /proc/mounts $ROOTFS_DIR/etc/mtab; fi +
-if [ ! -L $ROOTFS_DIR/etc/rcS.d/S99smartmeter-init.sh ]; then ln -v -s ../init.d/smartmeter-init.sh $ROOTFS_DIR/etc/rcS.d/S99smartmeter-init.sh; fi +
-if [ ! -L $ROOTFS_DIR/etc/resolv.conf ]; then ln -v -s /var/run/resolv.conf $ROOTFS_DIR/etc/resolv.conf; fi +
-if [ ! -L $ROOTFS_DIR/etc/adjtime ]; then ln -v -s /var/local/adjtime $ROOTFS_DIR/etc/adjtime; fi +
- +
-echo "Generating rootfs image file..." +
-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://buildroot.uclibc.org/|Buildroot]] für die Erstellung eines Root-Filesystems. 
 +TODO