inside.sh 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. #!/bin/sh
  2. # mount all kinds of things
  3. mount tmpfs -t tmpfs /etc
  4. # we need our own /dev/rfkill, and don't want device access
  5. mount tmpfs -t tmpfs /dev
  6. mount tmpfs -t tmpfs /tmp
  7. # some sockets go into /var/run, and / is read-only
  8. mount tmpfs -t tmpfs /var/run
  9. mount proc -t proc /proc
  10. mount sysfs -t sysfs /sys
  11. # needed for tracing
  12. mount debugfs -t debugfs /sys/kernel/debug
  13. # reboot on any sort of crash
  14. sysctl kernel.panic_on_oops=1
  15. sysctl kernel.panic=1
  16. # get extra command line variables from /proc/cmdline
  17. TESTDIR=$(sed 's/.*testdir=\([^ ]*\) .*/\1/' /proc/cmdline)
  18. TIMEWARP=$(sed 's/.*timewarp=\([^ ]*\) .*/\1/' /proc/cmdline)
  19. EPATH=$(sed 's/.*EPATH=\([^ ]*\) .*/\1/' /proc/cmdline)
  20. ARGS=$(sed 's/.*ARGS=//' /proc/cmdline)
  21. # create /dev entries we need
  22. mknod -m 660 /dev/ttyS0 c 4 64
  23. mknod -m 660 /dev/random c 1 8
  24. mknod -m 660 /dev/urandom c 1 9
  25. mknod -m 666 /dev/null c 1 3
  26. test -f /sys/class/misc/rfkill/dev && \
  27. mknod -m 660 /dev/rfkill c $(cat /sys/class/misc/rfkill/dev | tr ':' ' ')
  28. ln -s /proc/self/fd/0 /dev/stdin
  29. ln -s /proc/self/fd/1 /dev/stdout
  30. ln -s /proc/self/fd/2 /dev/stderr
  31. # create dummy sudo - everything runs as uid 0
  32. mkdir /tmp/bin
  33. cat > /tmp/bin/sudo << EOF
  34. #!/bin/bash
  35. exec "\$@"
  36. EOF
  37. chmod +x /tmp/bin/sudo
  38. # and put it into $PATH, as well as our extra-$PATH
  39. export PATH=/tmp/bin:$EPATH:$PATH
  40. # some tests assume adm/admin group(s) exist(s)
  41. echo 'adm:x:0:' > /etc/group
  42. echo 'admin:x:0:' >> /etc/group
  43. # root should exist
  44. echo 'root:x:0:0:root:/tmp:/bin/bash' > /etc/passwd
  45. # local network is needed for some tests
  46. ip link set lo up
  47. # create logs mountpoint and mount the logshare
  48. mkdir /tmp/logs
  49. mount -t 9p -o trans=virtio,rw logshare /tmp/logs
  50. if [ "$TIMEWARP" = "1" ] ; then
  51. (
  52. while sleep 1 ; do
  53. date --set "@$(($(date +%s) + 19))"
  54. done
  55. ) &
  56. fi
  57. # check if we're rebooting due to a kernel panic ...
  58. if grep -q 'Kernel panic' /tmp/logs/console ; then
  59. echo "KERNEL CRASHED!" >/dev/ttyS0
  60. else
  61. # finally run the tests
  62. export USER=0
  63. export LOGDIR=/tmp/logs
  64. export DBFILE=$LOGDIR/results.db
  65. export PREFILL_DB=y
  66. # some tests need CRDA, install a simple uevent helper
  67. # and preload the 00 domain it will have asked for already
  68. echo $TESTDIR/vm/uevent.sh > /sys/kernel/uevent_helper
  69. COUNTRY=00 crda
  70. cd $TESTDIR
  71. ./run-all.sh $ARGS >/dev/ttyS0 2>&1
  72. if test -d /sys/kernel/debug/gcov ; then
  73. cp -ar /sys/kernel/debug/gcov /tmp/logs/
  74. # these are broken as they're updated while being read ...
  75. find /tmp/logs/gcov/ -wholename '*kernel/gcov/*' -print0 | xargs -0 rm
  76. fi
  77. #bash </dev/ttyS0 >/dev/ttyS0 2>&1
  78. fi
  79. # and shut down the machine again
  80. halt -f -p