root.sh 5.88 KB
Newer Older
Guido Gunther's avatar
Guido Gunther committed
1
#!/bin/bash
2
3
4
5
6
#
# Copyright (C) 2017 Purism SPC
#
# SPDX-License-Identifier: GPL-3.0+
#
Pedro Vicente's avatar
Pedro Vicente committed
7

8

Angus Ainslie's avatar
Angus Ainslie committed
9
10
11
# distro and basedir set by calling script 
basedir=$1
image_name=$2
Angus Ainslie's avatar
Angus Ainslie committed
12
cwd=`pwd`
13
qemu="${basedir}/usr/bin/qemu-arm-static"
14
15
stamp=$basedir/var/log/gitrev.log

Angus Ainslie's avatar
Angus Ainslie committed
16

17
18
19
20
21
22
for env_var in distro pureos_board packages; do
    if [ -z "${!env_var}" ]; then
	echo "Must pass in \$${env_var} via the environment" 1>&2
	exit 1
    fi
done
23

Pedro Vicente's avatar
Pedro Vicente committed
24
set -e
Guido Gunther's avatar
Guido Gunther committed
25
set -u
26

27

Guido Gunther's avatar
Guido Gunther committed
28
mirror=deb.debian.org
Guido Gunther's avatar
Guido Gunther committed
29

30
31
32
33
echo "Configuring ${distro} in ${basedir} for board ${pureos_board}"

case ${pureos_board} in 
  imx6)
Guido Gunther's avatar
Guido Gunther committed
34
    fdt_file=imx6qp-nitrogen6_max_purism.dtb
35
36
37
38
39
40
41
42
    ;;
  imx8)
    echo "board type ${pureos_board} not configured yet"
    ;;
  qemu)
    echo "board type ${pureos_board} not configured yet"
    exit 1
    ;;
43
  *)
44
45
46
47
    echo "unrecognized board type ${pureos_board}"
    exit 1
    ;;
esac
Pedro Vicente's avatar
Pedro Vicente committed
48

Guido Gunther's avatar
Guido Gunther committed
49

50
51
52
53
54
55
56
# bindmount qemu into the rootfs so we can chroot into it if needed
function setup_qemu()
{
    [ -f ${qemu} ] || cp /usr/bin/qemu-arm-static "${qemu}"
}


Guido Gunther's avatar
Guido Gunther committed
57
58
59
60
61
62
63
64
65
66
67
function setup_kernel()
{
    local link="$(basename $basedir/boot/vmlinuz-*)"
    rm -f "${basedir}/boot/zImage"
    ln -s "${link}" "${basedir}/boot/zImage"

    mkdir -p "${basedir}/boot/dtbs"
    cp "${basedir}"/usr/lib/linux-image-*/${fdt_file} "${basedir}/boot/dtbs/"
}


68
69
function setup_uboot()
{
Guido Gunther's avatar
Guido Gunther committed
70
    sed -e "s/##DTBNAME##/${fdt_file}/" data/boot-${pureos_board}.txt.in > $basedir/boot/boot.txt
Guido Gunther's avatar
Guido Gunther committed
71
72
    mkimage -A arm -T script -O linux -d $basedir/boot/boot.txt $basedir/boot/boot.scr
    ln -fs boot.scr $basedir/boot/6x_bootscript
73

Guido Gunther's avatar
Guido Gunther committed
74
    [ ! -d files/uboot-${pureos_board} ] || cp -a files/uboot-${pureos_board}/* $basedir/boot/
75
76
77
}


78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
function build_tarball()
{
   tarball="$(basename ${image_name} .img)".tar.xz
   pwd=$PWD

   echo -n "Taring up rootfs to $PWD/$tarball..."
   tar --acl \
       --exclude='./run/*' \
       --exclude='./dev/*' \
       --exclude='./sys/*' \
       --exclude='./proc/*' \
       -acf $PWD/$tarball -C $basedir .
   echo "Done."
}


94
function cleanup_chroot()
95
{
96
97
    chroot $basedir apt-get clean

98
99
100
101
    rm $basedir/etc/resolv.conf
    mv $basedir/etc/resolv.conf.bak $basedir/etc/resolv.conf
    rm $basedir/usr/sbin/policy-rc.d

102
103
104
105
    umount $basedir/dev/pts
    umount $basedir/dev
    umount $basedir/sys
    umount $basedir/proc
106
107
108
109
110

    # existence of stamp indicates success
    if [ -f $stamp ]; then
      build_tarball
    fi
111
112
113
}


114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
function prepare_chroot()
{
    trap cleanup_chroot EXIT

    mount -t proc chproc $basedir/proc
    mount -t sysfs chsys $basedir/sys
    mount -t devtmpfs chdev $basedir/dev || mount --bind /dev $basedir/dev
    mount -t devpts chpts $basedir/dev/pts
    echo -e '#!/bin/sh\nexit 101' > $basedir/usr/sbin/policy-rc.d
    chmod 755 $basedir/usr/sbin/policy-rc.d
    mv $basedir/etc/resolv.conf $basedir/etc/resolv.conf.bak
    cp /etc/resolv.conf $basedir/etc
}


129
130
131
132
133
134
function create_stamp()
{
    git log --format=format:%H -1 > $stamp
}


135
136
function setup_gui()
{
Guido Gunther's avatar
Guido Gunther committed
137
138
139
140
    # Allow purism user to launch weston from the console, etc.
    for group in weston-launch video audio; do
        chroot $basedir adduser purism $group
    done
Guido Gunther's avatar
Guido Gunther committed
141
    # Will move into a debian package once we have build infra
Guido Gunther's avatar
Guido Gunther committed
142
    cp data/weston.service $basedir/etc/systemd/system/
Guido Gunther's avatar
Guido Gunther committed
143
    chroot $basedir systemctl enable weston.service
144
145
}

146

Guido Gunther's avatar
Guido Gunther committed
147
148
149
150
151
152
153
154
155
156
157
158
function setup_journal()
{
    # Enable systemd journal
    chroot $basedir mkdir -p /var/log/journal
    chroot $basedir systemd-tmpfiles --create --prefix /var/log/journal
    chroot $basedir apt-get -y remove rsyslog
    for l in daemon messages syslog kern mail user; do
        chroot $basedir rm -f /var/log/${l}.*
    done
}


159
160
# We have to do this because task packages don't work with debootstrap
# (and won't).  See https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=841649
161
162
163
# other packages are better installed late to not confuse deboostrap about
# systemd and systemd-shim (e.g. libpam-systemd)
function install_pkgs()
164
165
166
167
168
169
170
171
172
173
{
    # Inspired by https://linux-sunxi.org/Mainline_Debian_HowTo
    (
        export DEBIAN_FRONTEND=noninteractive
        export DEBCONF_NONINTERACTIVE_SEEN=true
        export LC_ALL=C
        export LANGUAGE=C
        export LANG=C

        chroot $basedir apt-get -y update
174
        chroot $basedir apt-get -y install $packages
175
176
177
    )
}

178

179

180
181
182
183
# create the directories so that this script can be tested without the generated filesystem
mkdir -p $basedir/etc/apt/apt.conf.d/
mkdir -p $basedir/etc/network

Pedro Vicente's avatar
Pedro Vicente committed
184
cat << EOF > $basedir/etc/apt/sources.list
185
186
187
188
deb http://$mirror/debian $distro main contrib non-free
deb-src http://$mirror/debian $distro main contrib non-free
deb http://$mirror/debian $distro-updates main contrib non-free
deb-src http://$mirror/debian $distro-updates main contrib non-free
Pedro Vicente's avatar
Pedro Vicente committed
189
190
191
192
deb http://security.debian.org/debian-security $distro/updates main contrib non-free
deb-src http://security.debian.org/debian-security $distro/updates main contrib non-free
EOF

Angus Ainslie's avatar
Angus Ainslie committed
193
cat << EOT > $basedir/etc/apt/apt.conf.d/71-no-recommends
Pedro Vicente's avatar
Pedro Vicente committed
194
195
196
197
	APT::Install-Recommends "0";
	APT::Install-Suggests "0";
EOT

198
echo "pureos" > $basedir/etc/hostname
Pedro Vicente's avatar
Pedro Vicente committed
199
200
201
202
203
204
205
206
207
208
209
210
211
212


cat << EOF > $basedir/etc/hosts
127.0.0.1       pureos   localhost
::1             localhost ip6-localhost ip6-loopback
fe00::0         ip6-localnet
ff00::0         ip6-mcastprefix
ff02::1         ip6-allnodes
ff02::2         ip6-allrouters
EOF

cat << EOF > $basedir/etc/network/interfaces
auto lo
iface lo inet loopback
213

Pedro Vicente's avatar
Pedro Vicente committed
214
215
216
217
allow-hotplug eth0
iface eth0 inet dhcp
EOF

218
219
220
221
222
223
224

# Don't setup resolv.conf if it's a symlink
# DHCP will later handle this just fine
if [ -f $basedir/etc/resolv.conf ]; then
    cat <<EOF > $basedir/etc/resolv.conf
    nameserver 208.67.220.220
    nameserver 208.67.222.222
Pedro Vicente's avatar
Pedro Vicente committed
225
EOF
226
fi
Pedro Vicente's avatar
Pedro Vicente committed
227
228
229
230
231
232
233
234
235

export MALLOC_CHECK_=0 # workaround for LP: #520465
export LC_ALL=C
export DEBIAN_FRONTEND=noninteractive

cat << EOF > $basedir/debconf.set
console-common console-data/keymap/policy select Select keymap from full list
console-common console-data/keymap/full select en-latin1-nodeadkeys
EOF
236

237
prepare_chroot
238
setup_qemu
239
install_pkgs
Guido Gunther's avatar
Guido Gunther committed
240
setup_kernel
241
setup_uboot
242
setup_gui
Guido Gunther's avatar
Guido Gunther committed
243
setup_journal
244
create_stamp