summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTobias Powalowski <tpowa@archlinux.org>2006-05-08 22:46:07 +0200
committerTobias Powalowski <tpowa@archlinux.org>2006-05-08 22:46:07 +0200
commit9114900c15b343c2e5585abe34d0e259f8d86478 (patch)
tree16eac8a79633f0e07ea0d0656b4798a45257919b
parent7c6776156d4b9513510827feecc64bc85ff88e64 (diff)
downloadmkinitcpio-9114900c15b343c2e5585abe34d0e259f8d86478.tar.gz
mkinitcpio-9114900c15b343c2e5585abe34d0e259f8d86478.tar.xz
'added firmware and keymap hooks'
git-svn-id: http://projects.archlinux.org/svn/initramfs/mkinitcpio@85 880c04e9-e011-0410-abf7-b926e227c9cd
-rw-r--r--hooks/keymap21
-rw-r--r--install/firmware24
-rw-r--r--install/keymap43
-rw-r--r--install/udev1
4 files changed, 89 insertions, 0 deletions
diff --git a/hooks/keymap b/hooks/keymap
new file mode 100644
index 0000000..d00df9b
--- /dev/null
+++ b/hooks/keymap
@@ -0,0 +1,21 @@
+# vim: set ft=sh:
+run_hook ()
+{
+ msg -n ":: Loading keymap..."
+ . /keymap
+ if [ "$KEYMAP" != "" ]; then
+ /bin/loadkeys -q $KEYMAP
+ fi
+ # If locale is *.utf set console to Unicode mode
+ if [ "$UTF8" = "yes" ]; then
+ /bin/kbd_mode -u
+ /bin/dumpkeys | /bin/loadkeys --unicode
+ echo -ne "\e%G" >> /dev/console
+ fi
+ if [ "$CONSOLEMAP" != "" ]; then
+ /bin/setfont -m $CONSOLEMAP $CONSOLEFONT -C /dev/console
+ else
+ /bin/setfont $CONSOLEFONT -C /dev/console
+ fi
+ msg "done."
+}
diff --git a/install/firmware b/install/firmware
new file mode 100644
index 0000000..ca78b80
--- /dev/null
+++ b/install/firmware
@@ -0,0 +1,24 @@
+# vim: set ft=sh:
+
+install ()
+{
+ MODULES=""
+ BINARIES=""
+ FILES=""
+ SCRIPT=""
+ if [ -e /lib/firmware ]; then
+ for i in /lib/firmware/*; do
+ add_file $i
+ done
+ else
+ err "No firmware files found!"
+ fi
+}
+
+help ()
+{
+cat<<HELPEOF
+ This hook adds the firmware files that are placed at /lib/firmware/
+ to the image.
+HELPEOF
+}
diff --git a/install/keymap b/install/keymap
new file mode 100644
index 0000000..03c5a98
--- /dev/null
+++ b/install/keymap
@@ -0,0 +1,43 @@
+# vim: set ft=sh:
+
+install ()
+{
+ MODULES=""
+ BINARIES=""
+ FILES=""
+ SCRIPT="keymap"
+ KEYMAP_FILE="$(mktemp /tmp/keymap.XXXXXX)"
+ add_file /bin/loadkeys /bin/loadkeys
+ add_file /usr/bin/dumpkeys.static /bin/dumpkeys
+ add_file /usr/bin/kbd_mode.static /bin/kdb_mode
+ add_file /usr/bin/setfont.static /bin/setfont
+ grep "KEYMAP=" /etc/rc.conf >> ${KEYMAP_FILE}
+ grep "CONSOLEFONT=" /etc/rc.conf >> ${KEYMAP_FILE}
+ grep "CONSOLEMAP=" /etc/rc.conf >> ${KEYMAP_FILE}
+ if [ "`echo $LOCALE | /bin/grep -i utf`" ]; then
+ echo UTF8="yes" >> ${KEYMAP_FILE}
+ fi
+ . ${KEYMAP_FILE}
+ add_file ${KEYMAP_FILE} /keymap
+ [ "$CONSOLEFONT" != "" ] && add_file /usr/share/kbd/consolefonts/$(grep "CONSOLEFONT=" /etc/rc.conf | awk -FCONSOLEFONT= '{print $2}')*
+ [ "$CONSOLEMAP" != "" ] && add_file /usr/share/kbd/unimaps/$(grep "CONSOLEMAP=" /etc/rc.conf | awk -FCONSOLEMAP= '{print $2}')*
+ if [ "$KEYMAP" != "" ]; then
+ for i in $(find /usr/share/kbd/ -name "$(grep "KEYMAP=" /etc/rc.conf | awk -FKEYMAP= '{print $2}' | awk -F- '{print $1}')*.map.gz")
+ do add_file $i
+ done
+ for i in $(echo /usr/share/kbd/keymaps/include/*); do
+ add_file $i
+ done
+ for i in $(echo /usr/share/kbd/keymaps/*/include/*); do
+ add_file $i
+ done
+ fi
+}
+
+help ()
+{
+cat<<HELPEOF
+ This hook loads the specified keymap and consolefont from rc.conf,
+ during early userspace.
+HELPEOF
+}
diff --git a/install/udev b/install/udev
index bfe4a1b..a6a75ea 100644
--- a/install/udev
+++ b/install/udev
@@ -12,6 +12,7 @@ install ()
add_file /lib/initcpio/udev/udev.rules /etc/udev/rules.d/udev.rules
add_file /lib/initcpio/udev/start_udev /etc/start_udev
add_file /lib/initcpio/udev/modalias_ieee1394 /lib/udev/modalias_ieee1394
+ add_file /lib/initcpio/udev/firmware_helper /lib/udev/firmware_helper
}
help ()