start.sh 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. #!/bin/sh
  2. DIR="$( cd "$( dirname "$0" )" && pwd )"
  3. WPAS=$DIR/../../wpa_supplicant/wpa_supplicant
  4. WPACLI=$DIR/../../wpa_supplicant/wpa_cli
  5. HAPD=$DIR/../../hostapd/hostapd
  6. HAPD_AS=$DIR/../../hostapd/hostapd
  7. WLANTEST=$DIR/../../wlantest/wlantest
  8. HLR_AUC_GW=$DIR/../../hostapd/hlr_auc_gw
  9. DATE="$(date +%s)"
  10. if [ -z "$LOGDIR" ] ; then
  11. LOGDIR="$DIR/logs/$DATE"
  12. mkdir -p $LOGDIR
  13. else
  14. if [ -e $LOGDIR/alt-wpa_supplicant/wpa_supplicant/wpa_supplicant ]; then
  15. WPAS=$LOGDIR/alt-wpa_supplicant/wpa_supplicant/wpa_supplicant
  16. fi
  17. if [ -e $LOGDIR/alt-hostapd/hostapd/hostapd ]; then
  18. HAPD=$LOGDIR/alt-hostapd/hostapd/hostapd
  19. fi
  20. if [ -e $LOGDIR/alt-hostapd-as/hostapd/hostapd ]; then
  21. HAPD_AS=$LOGDIR/alt-hostapd-as/hostapd/hostapd
  22. fi
  23. if [ -e $LOGDIR/alt-hlr_auc_gw/hostapd/hlr_auc_gw ]; then
  24. HLR_AUC_GW=$LOGDIR/alt-hlr_auc_gw/hostapd/hlr_auc_gw
  25. fi
  26. fi
  27. if test -w "$DIR/logs" ; then
  28. rm -rf $DIR/logs/current
  29. ln -sf $DATE $DIR/logs/current
  30. fi
  31. if groups | tr ' ' "\n" | grep -q ^admin$; then
  32. GROUP=admin
  33. else
  34. GROUP=adm
  35. fi
  36. for i in 0 1 2; do
  37. sed "s/ GROUP=.*$/ GROUP=$GROUP/" "$DIR/p2p$i.conf" > "$LOGDIR/p2p$i.conf"
  38. done
  39. sed "s/group=admin/group=$GROUP/" "$DIR/auth_serv/as.conf" > "$LOGDIR/as.conf"
  40. sed "s/group=admin/group=$GROUP/;s%LOGDIR%$LOGDIR%" "$DIR/auth_serv/as2.conf" > "$LOGDIR/as2.conf"
  41. if [ "$1" = "valgrind" ]; then
  42. VALGRIND=y
  43. VALGRIND_WPAS="valgrind --log-file=$LOGDIR/valgrind-wlan%d"
  44. VALGRIND_HAPD="valgrind --log-file=$LOGDIR/valgrind-hostapd"
  45. chmod -f a+rx $WPAS
  46. chmod -f a+rx $HAPD
  47. chmod -f a+rx $HAPD_AS
  48. HAPD_AS="valgrind --log-file=$LOGDIR/valgrind-auth-serv $HAPD_AS"
  49. shift
  50. else
  51. unset VALGRIND
  52. VALGRIND_WPAS=
  53. VALGRIND_HAPD=
  54. fi
  55. if [ "$1" = "trace" ]; then
  56. TRACE="T"
  57. shift
  58. else
  59. TRACE=""
  60. fi
  61. $DIR/stop.sh
  62. test -f /proc/modules && sudo modprobe mac80211_hwsim radios=6
  63. sudo ifconfig hwsim0 up
  64. sudo $WLANTEST -i hwsim0 -n $LOGDIR/hwsim0.pcapng -c -dt -L $LOGDIR/hwsim0 &
  65. for i in 0 1 2; do
  66. sudo $(printf -- "$VALGRIND_WPAS" $i) $WPAS -g /tmp/wpas-wlan$i -G$GROUP -Dnl80211 -iwlan$i -c $LOGDIR/p2p$i.conf \
  67. -ddKt$TRACE -f $LOGDIR/log$i &
  68. done
  69. sudo $(printf -- "$VALGRIND_WPAS" 5) $WPAS -g /tmp/wpas-wlan5 -G$GROUP \
  70. -ddKt$TRACE -f $LOGDIR/log5 &
  71. sudo $VALGRIND_HAPD $HAPD -ddKt$TRACE -g /var/run/hostapd-global -G $GROUP -ddKt -f $LOGDIR/hostapd &
  72. sleep 1
  73. sudo chown -f $USER $LOGDIR/hwsim0.pcapng $LOGDIR/hwsim0 $LOGDIR/log* $LOGDIR/hostapd
  74. if [ -x $HLR_AUC_GW ]; then
  75. cp $DIR/auth_serv/hlr_auc_gw.milenage_db $LOGDIR/hlr_auc_gw.milenage_db
  76. sudo $HLR_AUC_GW -u -m $LOGDIR/hlr_auc_gw.milenage_db -g $DIR/auth_serv/hlr_auc_gw.gsm > $LOGDIR/hlr_auc_gw &
  77. fi
  78. touch $LOGDIR/hostapd.db
  79. sudo $HAPD_AS -ddKt $LOGDIR/as.conf $LOGDIR/as2.conf > $LOGDIR/auth_serv &
  80. if [ "x$VALGRIND" = "xy" ]; then
  81. sleep 1
  82. sudo chown -f $USER $LOGDIR/*valgrind*
  83. fi
  84. # wait for programs to be fully initialized
  85. for i in 0 1 2; do
  86. for j in `seq 1 10`; do
  87. if $WPACLI -g /tmp/wpas-wlan$i ping | grep -q PONG; then
  88. break
  89. fi
  90. if [ $j = "10" ]; then
  91. echo "Could not connect to /tmp/wpas-wlan$i"
  92. exit 1
  93. fi
  94. sleep 1
  95. done
  96. done
  97. for j in `seq 1 10`; do
  98. if $WPACLI -g /var/run/hostapd-global ping | grep -q PONG; then
  99. break
  100. fi
  101. if [ $j = "10" ]; then
  102. echo "Could not connect to /var/run/hostapd-global"
  103. exit 1
  104. fi
  105. sleep 1
  106. done
  107. exit 0