aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--README.md9
-rwxr-xr-xrpi2-gen-image.sh68
2 files changed, 60 insertions, 17 deletions
diff --git a/README.md b/README.md
index 0fb8a67..f0ece3c 100644
--- a/README.md
+++ b/README.md
@@ -35,11 +35,18 @@ Set system host name. It's recommended that the host name is unique in the corre
Set system `root` password. The same password is used for the created user `pi`. It's **STRONGLY** recommended that you choose a custom password.
##### `DEFLOCAL`="en_US.UTF-8"
-Set default system locale and keyboard layout. This setting can also be changed inside the running OS using the `dpkg-reconfigure locales` command. The script variant `minbase` (ENABLE_MINBASE=true) doesn't install `locales`.
+Set default system locale. This setting can also be changed inside the running OS using the `dpkg-reconfigure locales` command. The script variant `minbase` (ENABLE_MINBASE=true) doesn't install `locales`.
##### `TIMEZONE`="Europe/Berlin"
Set default system timezone. All available timezones can be found in the `/usr/share/zoneinfo/` directory. This setting can also be changed inside the running OS using the `dpkg-reconfigure tzdata` command.
+#### Keyboard settings:
+These options are used to configure keyboard layout in `/etc/default/keyboard` for console and Xorg. These settings can also be changed inside the running OS using the `dpkg-reconfigure keyboard-configuration` command.
+##### `XKBMODEL`=""
+##### `XKBLAYOUT`=""
+##### `XKBVARIANT`=""
+##### `XKBOPTIONS`=""
+
#### Networking settings
These settings are used to set up networking configuration in `/etc/systemd/network/eth.network`.
diff --git a/rpi2-gen-image.sh b/rpi2-gen-image.sh
index 012d4ca..2c88f3a 100755
--- a/rpi2-gen-image.sh
+++ b/rpi2-gen-image.sh
@@ -45,6 +45,10 @@ HOSTNAME=${HOSTNAME:=rpi2-${RELEASE}}
PASSWORD=${PASSWORD:=raspberry}
DEFLOCAL=${DEFLOCAL:="en_US.UTF-8"}
TIMEZONE=${TIMEZONE:="Europe/Berlin"}
+XKBMODEL=${XKBMODEL:=""}
+XKBLAYOUT=${XKBLAYOUT:=""}
+XKBVARIANT=${XKBVARIANT:=""}
+XKBOPTIONS=${XKBOPTIONS:=""}
# Network settings
ENABLE_DHCP=${ENABLE_DHCP:=true}
@@ -84,7 +88,7 @@ ENABLE_IPTABLES=${ENABLE_IPTABLES:=false}
R=${BUILDDIR}/chroot
# Packages required for bootstrapping
-REQUIRED_PACKAGES="debootstrap debian-archive-keyring qemu-user-static dosfstools rsync bmap-tools whois git-core"
+REQUIRED_PACKAGES="debootstrap debian-archive-keyring qemu-user-static binfmt-support dosfstools rsync bmap-tools whois git-core"
# Missing packages that need to be installed
MISSING_PACKAGES=""
@@ -140,7 +144,7 @@ mkdir -p $R
if [ "$ENABLE_MINBASE" = true ] ; then
APT_INCLUDES="${APT_INCLUDES},vim-tiny,netbase,net-tools"
else
- APT_INCLUDES="${APT_INCLUDES},locales"
+ APT_INCLUDES="${APT_INCLUDES},locales,keyboard-configuration,console-setup"
fi
# Add dbus package, recommended if using systemd
@@ -187,16 +191,11 @@ if [ "$ENABLE_XORG" = true ] ; then
APT_INCLUDES="${APT_INCLUDES},xorg"
fi
-# Set empty proxy string
-if [ -z "$APT_PROXY" ] ; then
- APT_PROXY="http://"
-fi
-
# Base debootstrap (unpack only)
if [ "$ENABLE_MINBASE" = true ] ; then
- debootstrap --arch=armhf --variant=minbase --foreign --include=${APT_INCLUDES} $RELEASE $R ${APT_PROXY}${APT_SERVER}/debian
+ http_proxy=${APT_PROXY} debootstrap --arch=armhf --variant=minbase --foreign --include=${APT_INCLUDES} $RELEASE $R http://${APT_SERVER}/debian
else
- debootstrap --arch=armhf --foreign --include=${APT_INCLUDES} $RELEASE $R ${APT_PROXY}${APT_SERVER}/debian
+ http_proxy=${APT_PROXY} debootstrap --arch=armhf --foreign --include=${APT_INCLUDES} $RELEASE $R http://${APT_SERVER}/debian
fi
# Copy qemu emulator binary to chroot
@@ -216,7 +215,7 @@ mount --bind /dev/pts $R/dev/pts
# Use proxy inside chroot
if [ -z "$APT_PROXY" ] ; then
- echo "Acquire::http::Proxy \"$APT_PROXY\"" >> $R/etc/apt/apt.conf.d/10proxy
+ echo "Acquire::http::Proxy \"$APT_PROXY\";" >> $R/etc/apt/apt.conf.d/10proxy
fi
# Pin package flash-kernel to repositories.collabora.co.uk
@@ -230,12 +229,6 @@ EOM
echo ${TIMEZONE} >$R/etc/timezone
LANG=C chroot $R dpkg-reconfigure -f noninteractive tzdata
-# Set up default locales to "en_US.UTF-8" default
-if [ "$ENABLE_MINBASE" = false ] ; then
- LANG=C chroot $R sed -i "/${DEFLOCAL}/s/^#//" /etc/locale.gen
- LANG=C chroot $R locale-gen ${DEFLOCAL}
-fi
-
# Upgrade collabora package index and install collabora keyring
echo "deb https://repositories.collabora.co.uk/debian ${RELEASE} rpi2" >$R/etc/apt/sources.list
LANG=C chroot $R apt-get -qq -y update
@@ -259,6 +252,49 @@ EOM
LANG=C chroot $R apt-get -qq -y update
LANG=C chroot $R apt-get -qq -y -u dist-upgrade
+# Set up default locale and keyboard configuration
+if [ "$ENABLE_MINBASE" = false ] ; then
+ # Set locale choice in debconf db, even though dpkg-reconfigure ignores and overwrites them due to some bug
+ # https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=684134 https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=685957
+ # ... so we have to set locales manually
+ if [ "$DEFLOCAL" = "en_US.UTF-8" ] ; then
+ LANG=C chroot $R echo "locales locales/locales_to_be_generated multiselect ${DEFLOCAL} UTF-8" | debconf-set-selections
+ else
+ # en_US.UTF-8 should be available anyway : https://www.debian.org/doc/manuals/debian-reference/ch08.en.html#_the_reconfiguration_of_the_locale
+ LANG=C chroot $R echo "locales locales/locales_to_be_generated multiselect en_US.UTF-8 UTF-8, ${DEFLOCAL} UTF-8" | debconf-set-selections
+ LANG=C chroot $R sed -i "/en_US.UTF-8/s/^#//" /etc/locale.gen
+ fi
+ LANG=C chroot $R sed -i "/${DEFLOCAL}/s/^#//" /etc/locale.gen
+ LANG=C chroot $R echo "locales locales/default_environment_locale select ${DEFLOCAL}" | debconf-set-selections
+ LANG=C chroot $R locale-gen
+ LANG=C chroot $R update-locale LANG=${DEFLOCAL}
+
+ # Keyboard configuration, if requested
+ if [ "$XKBMODEL" != "" ] ; then
+ LANG=C chroot $R sed -i "s/^XKBMODEL.*/XKBMODEL=\"${XKBMODEL}\"/" /etc/default/keyboard
+ fi
+ if [ "$XKBLAYOUT" != "" ] ; then
+ LANG=C chroot $R sed -i "s/^XKBLAYOUT.*/XKBLAYOUT=\"${XKBLAYOUT}\"/" /etc/default/keyboard
+ fi
+ if [ "$XKBVARIANT" != "" ] ; then
+ LANG=C chroot $R sed -i "s/^XKBVARIANT.*/XKBVARIANT=\"${XKBVARIANT}\"/" /etc/default/keyboard
+ fi
+ if [ "$XKBOPTIONS" != "" ] ; then
+ LANG=C chroot $R sed -i "s/^XKBOPTIONS.*/XKBOPTIONS=\"${XKBOPTIONS}\"/" /etc/default/keyboard
+ fi
+ LANG=C chroot $R dpkg-reconfigure -f noninteractive keyboard-configuration
+ # Set up font console
+ case "${DEFLOCAL}" in
+ *UTF-8)
+ LANG=C chroot $R sed -i 's/^CHARMAP.*/CHARMAP="UTF-8"/' /etc/default/console-setup
+ ;;
+ *)
+ LANG=C chroot $R sed -i 's/^CHARMAP.*/CHARMAP="guess"/' /etc/default/console-setup
+ ;;
+ esac
+ LANG=C chroot $R dpkg-reconfigure -f noninteractive console-setup
+fi
+
# Kernel installation
# Install flash-kernel last so it doesn't try (and fail) to detect the platform in the chroot
LANG=C chroot $R apt-get -qq -y --no-install-recommends install linux-image-3.18.0-trunk-rpi2