12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- #!/bin/sh
- mount tmpfs -t tmpfs /etc
- mount tmpfs -t tmpfs /dev
- mount tmpfs -t tmpfs /tmp
- mount tmpfs -t tmpfs /var/run
- mount proc -t proc /proc
- mount sysfs -t sysfs /sys
- mount debugfs -t debugfs /sys/kernel/debug
- sysctl kernel.panic_on_oops=1
- sysctl kernel.panic=1
- TESTDIR=$(sed 's/.*testdir=\([^ ]*\) .*/\1/' /proc/cmdline)
- TIMEWARP=$(sed 's/.*timewarp=\([^ ]*\) .*/\1/' /proc/cmdline)
- EPATH=$(sed 's/.*EPATH=\([^ ]*\) .*/\1/' /proc/cmdline)
- ARGS=$(sed 's/.*ARGS=//' /proc/cmdline)
- mknod -m 660 /dev/ttyS0 c 4 64
- mknod -m 660 /dev/random c 1 8
- mknod -m 660 /dev/urandom c 1 9
- mknod -m 666 /dev/null c 1 3
- test -f /sys/class/misc/rfkill/dev && \
- mknod -m 660 /dev/rfkill c $(cat /sys/class/misc/rfkill/dev | tr ':' ' ')
- ln -s /proc/self/fd/0 /dev/stdin
- ln -s /proc/self/fd/1 /dev/stdout
- ln -s /proc/self/fd/2 /dev/stderr
- mkdir /tmp/bin
- cat > /tmp/bin/sudo << EOF
- #!/bin/bash
- exec "\$@"
- EOF
- chmod +x /tmp/bin/sudo
- export PATH=/tmp/bin:$EPATH:$PATH
- echo 'adm:x:0:' > /etc/group
- echo 'admin:x:0:' >> /etc/group
- echo 'root:x:0:0:root:/tmp:/bin/bash' > /etc/passwd
- ip link set lo up
- mkdir /tmp/logs
- mount -t 9p -o trans=virtio,rw logshare /tmp/logs
- if [ "$TIMEWARP" = "1" ] ; then
- (
- while sleep 1 ; do
- date --set "@$(($(date +%s) + 19))"
- done
- ) &
- fi
- if grep -q 'Kernel panic' /tmp/logs/console ; then
- echo "KERNEL CRASHED!" >/dev/ttyS0
- else
-
- export USER=0
- export LOGDIR=/tmp/logs
- export DBFILE=$LOGDIR/results.db
- export PREFILL_DB=y
-
-
- echo $TESTDIR/vm/uevent.sh > /sys/kernel/uevent_helper
- COUNTRY=00 crda
- cd $TESTDIR
- ./run-all.sh $ARGS >/dev/ttyS0 2>&1
- if test -d /sys/kernel/debug/gcov ; then
- cp -ar /sys/kernel/debug/gcov /tmp/logs/
-
- find /tmp/logs/gcov/ -wholename '*kernel/gcov/*' -print0 | xargs -0 rm
- fi
-
- fi
- halt -f -p
|