diff options
| author | Joshua Bakita <jbakita@cs.unc.edu> | 2020-10-17 21:36:21 -0400 |
|---|---|---|
| committer | Joshua Bakita <jbakita@cs.unc.edu> | 2020-10-17 21:36:21 -0400 |
| commit | e5db76ee18640ce27df8756e573ef8b497af4750 (patch) | |
| tree | 8442b5f064f93c02906f4ef48cdb478cf627b4d2 /baseline | |
| parent | ecf6547fdce39b3ec0f333c9b391b0f1c25deba5 (diff) | |
All the TACLeBench runner scripts as used for the (rejected) RTSS'20 submission
Everything without isolation: run_tacle_rtss20.sh
For isolation you have to run the hodgepodge of scripts as before.
Diffstat (limited to 'baseline')
| -rwxr-xr-x | baseline/run_baseline.sh | 108 | ||||
| -rwxr-xr-x | baseline/run_baseline_L3_ONLY.sh | 152 |
2 files changed, 249 insertions, 11 deletions
diff --git a/baseline/run_baseline.sh b/baseline/run_baseline.sh index f7a98fa..c5b67b6 100755 --- a/baseline/run_baseline.sh +++ b/baseline/run_baseline.sh | |||
| @@ -2,11 +2,11 @@ | |||
| 2 | 2 | ||
| 3 | core=$1 | 3 | core=$1 |
| 4 | maxJobs=$2 | 4 | maxJobs=$2 |
| 5 | runID=$3 | 5 | userRunID=$3 |
| 6 | tacleNames=tacleNames.txt | 6 | tacleNames=tacleNames.txt |
| 7 | 7 | ||
| 8 | if [ $# -lt 3 ]; then | 8 | if [ $# -lt 3 ]; then |
| 9 | echo "Usage $0 <core ID> <number of iterations> <run ID> [TACLe names file]" | 9 | echo "Usage $0 <core ID> <number of iterations> <run ID> [TACLe names file] [--contend]" |
| 10 | exit | 10 | exit |
| 11 | fi | 11 | fi |
| 12 | 12 | ||
| @@ -15,6 +15,12 @@ if [ $# -gt 3 ]; then | |||
| 15 | tacleNames=$4 | 15 | tacleNames=$4 |
| 16 | fi | 16 | fi |
| 17 | 17 | ||
| 18 | if [ "$EUID" -ne 0 ] | ||
| 19 | then | ||
| 20 | echo "You need to be root to enable interrupt isolation and real-time execution!" | ||
| 21 | exit | ||
| 22 | fi | ||
| 23 | |||
| 18 | echo "Making sure that binaries are up to date..." | 24 | echo "Making sure that binaries are up to date..." |
| 19 | while read i; do | 25 | while read i; do |
| 20 | make bin/$i | 26 | make bin/$i |
| @@ -32,11 +38,10 @@ do | |||
| 32 | # Skip default_smp_affinity | 38 | # Skip default_smp_affinity |
| 33 | if [ -d $IRQ ]; then | 39 | if [ -d $IRQ ]; then |
| 34 | irqList[$i]=$(cat $IRQ/smp_affinity_list) | 40 | irqList[$i]=$(cat $IRQ/smp_affinity_list) |
| 35 | echo 0 > $IRQ/smp_affinity_list | 41 | echo 0 2> /dev/null > $IRQ/smp_affinity_list |
| 36 | fi | 42 | fi |
| 37 | i=$(( $i + 1 )) | 43 | i=$(( $i + 1 )) |
| 38 | done | 44 | done |
| 39 | echo "Done. Beginning benchmarks..." | ||
| 40 | 45 | ||
| 41 | # Read the names of each benchmark | 46 | # Read the names of each benchmark |
| 42 | j=0 | 47 | j=0 |
| @@ -45,25 +50,106 @@ while read i; do | |||
| 45 | j=$(( $j + 1 )) | 50 | j=$(( $j + 1 )) |
| 46 | done < $tacleNames | 51 | done < $tacleNames |
| 47 | 52 | ||
| 53 | echo "Done. Checking for wbinvd module..." | ||
| 54 | if [[ ! -f "/proc/wbinvd" ]]; then | ||
| 55 | echo "ERROR: wbinvd module not loaded. Exiting..." | ||
| 56 | exit | ||
| 57 | fi | ||
| 58 | |||
| 59 | echo "Done. Setting cores $firstCore and $secondCore to 'performance'..." | ||
| 60 | echo "performance" > /sys/devices/system/cpu/cpu15/cpufreq/scaling_governor | ||
| 61 | echo "performance" > /sys/devices/system/cpu/cpu31/cpufreq/scaling_governo | ||
| 62 | |||
| 63 | # Enable L3 isolation | ||
| 64 | echo "Done. Enabling L3 isolation..." | ||
| 65 | mount -t resctrl resctrl /sys/fs/resctrl | ||
| 66 | mkdir -p /sys/fs/resctrl/benchmarks | ||
| 67 | echo $1 > /sys/fs/resctrl/benchmarks/cpus_list | ||
| 68 | # Reset global bandwith control and remove L3 from global | ||
| 69 | echo "L3:0=ffff;1=ffff;2=ffff;3=0000" > /sys/fs/resctrl/schemata | ||
| 70 | echo "MB:0=2048;1=2048;2=2048;3=2048" > /sys/fs/resctrl/schemata | ||
| 71 | # Alloc L3 to benchmark | ||
| 72 | echo "L3:0=0000;1=0000;2=0000;3=ffff" > /sys/fs/resctrl/benchmarks/schemata | ||
| 73 | echo "MB:0=2048;1=2048;2=2048;3=2048" > /sys/fs/resctrl/benchmarks/schemata | ||
| 74 | echo "Done. Verifying configuration with user..." | ||
| 75 | |||
| 76 | # Generate file name string | ||
| 77 | # We append to this as we parse the environment settings | ||
| 78 | runID=$(date +"%b%d-%H") | ||
| 79 | |||
| 80 | # Confirm configuration with user | ||
| 81 | echo "=== Global Config ===" | ||
| 82 | cat /sys/fs/resctrl/schemata | ||
| 83 | echo "=== Core $1 Config ===" | ||
| 84 | cat /sys/fs/resctrl/benchmarks/schemata | ||
| 85 | if [[ $5 == "--contend" ]]; then | ||
| 86 | if [[ ! -f "/playpen/mc2/imx6q-thrasher/thrasher" ]]; then | ||
| 87 | echo "ERROR: thrasher binary not fonud. Exiting..." | ||
| 88 | exit | ||
| 89 | fi | ||
| 90 | echo "Will run 6 contending tasks" | ||
| 91 | runID=$runID-c | ||
| 92 | else | ||
| 93 | runID=$runID-xc | ||
| 94 | fi | ||
| 95 | if uname -a | grep -q "mc2"; then | ||
| 96 | echo "MC^2 Autodetected. Cache coloring and interleaving will be enabled." | ||
| 97 | runID=$runID-i | ||
| 98 | else | ||
| 99 | echo "MC^2 not detected." | ||
| 100 | runID=$runID-xi | ||
| 101 | fi | ||
| 102 | if pwd | grep -qi dis; then | ||
| 103 | echo "Autodetected DIS. Will use script-level looping." | ||
| 104 | fi | ||
| 105 | echo "Results will be saved as $runID-$userRunID.txt" | ||
| 106 | echo "Press enter to confirm environment, Ctrl-C to exit..." | ||
| 107 | read | ||
| 108 | |||
| 109 | # Start contending tasks | ||
| 110 | if [[ $5 == "--contend" ]]; then | ||
| 111 | echo "Done. Starting 6 contending tasks..." | ||
| 112 | # Run two contending tasks on each other CCX | ||
| 113 | taskset -c 1 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 114 | taskset -c 2 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 115 | taskset -c 5 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 116 | taskset -c 6 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 117 | taskset -c 9 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 118 | taskset -c 10 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 119 | fi | ||
| 120 | sleep 1 # Wait for contending tasks to start | ||
| 121 | echo "Done. Beginning benchmarks..." | ||
| 48 | 122 | ||
| 49 | num_tests=$(wc -l < $tacleNames) | 123 | num_tests=$(wc -l < $tacleNames) |
| 50 | for (( i = 0; i < $num_tests ; i++ )) | 124 | for (( i = 0; i < $num_tests ; i++ )) |
| 51 | do | 125 | do |
| 52 | # Check if we're using LITMUS^RT or not | 126 | # If using DIS, we have to iterate in the script as DIS won't do it for us |
| 53 | if grep -q "#define LITMUS 1" source/extra.h; then | 127 | pwd | grep -qi dis |
| 54 | ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID 1 | 128 | iters=$(python3 -c "print(int(not "$?")*("$maxJobs"-1))") |
| 55 | else | 129 | for ((k=0;k<=iters;k++)); do |
| 56 | chrt -r 97 taskset -c $core ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID 1 | 130 | # Check if we're using LITMUS^RT or not |
| 57 | fi | 131 | if [[ -f source/extra.h ]] && grep -q "#define LITMUS 1" source/extra.h; then |
| 132 | ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID-$userRunID 1 | ||
| 133 | else | ||
| 134 | # Interleave memory allocations between all nodes (only 1 node w/out MC^2) | ||
| 135 | chrt -r 97 numactl --interleave=all taskset -c $core ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID-$userRunID 1 | ||
| 136 | #chrt -r 97 numactl -m 0 taskset -c $core ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID-$userRunID-NOINTERLEAVE 1 | ||
| 137 | fi | ||
| 138 | done | ||
| 58 | echo COMPLETE: ${tacleProg[$i]} | 139 | echo COMPLETE: ${tacleProg[$i]} |
| 59 | done | 140 | done |
| 60 | 141 | ||
| 142 | # End contending tasks | ||
| 143 | if [[ $5 == "--contend" ]]; then | ||
| 144 | killall thrasher | ||
| 145 | fi | ||
| 146 | |||
| 61 | # Put smp_affinty back the way it was | 147 | # Put smp_affinty back the way it was |
| 62 | i=0 | 148 | i=0 |
| 63 | for IRQ in /proc/irq/* | 149 | for IRQ in /proc/irq/* |
| 64 | do | 150 | do |
| 65 | if [ -d $IRQ ]; then | 151 | if [ -d $IRQ ]; then |
| 66 | echo ${irqList[$i]} > $IRQ/smp_affinity_list | 152 | echo ${irqList[$i]} 2> /dev/null > $IRQ/smp_affinity_list |
| 67 | fi | 153 | fi |
| 68 | i=$(( $i + 1 )) | 154 | i=$(( $i + 1 )) |
| 69 | done | 155 | done |
diff --git a/baseline/run_baseline_L3_ONLY.sh b/baseline/run_baseline_L3_ONLY.sh new file mode 100755 index 0000000..4183653 --- /dev/null +++ b/baseline/run_baseline_L3_ONLY.sh | |||
| @@ -0,0 +1,152 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | |||
| 3 | core=$1 | ||
| 4 | maxJobs=$2 | ||
| 5 | userRunID=$3 | ||
| 6 | tacleNames=tacleNames.txt | ||
| 7 | |||
| 8 | if [ $# -lt 3 ]; then | ||
| 9 | echo "Usage $0 <core ID> <number of iterations> <run ID> [TACLe names file] [--contend]" | ||
| 10 | exit | ||
| 11 | fi | ||
| 12 | |||
| 13 | if [ $# -gt 3 ]; then | ||
| 14 | echo "Using alternate list of TACLe benchmarks from $4" | ||
| 15 | tacleNames=$4 | ||
| 16 | fi | ||
| 17 | |||
| 18 | if [ "$EUID" -ne 0 ] | ||
| 19 | then | ||
| 20 | echo "You need to be root to enable interrupt isolation and real-time execution!" | ||
| 21 | exit | ||
| 22 | fi | ||
| 23 | |||
| 24 | echo "Making sure that binaries are up to date..." | ||
| 25 | while read i; do | ||
| 26 | make bin/$i | ||
| 27 | done < $tacleNames | ||
| 28 | echo "Done. Disabling real-time throttling..." | ||
| 29 | |||
| 30 | # Turn off rt throttling | ||
| 31 | echo -1 > /proc/sys/kernel/sched_rt_runtime_us | ||
| 32 | echo "Done. Redirecting all interrupts to core 0..." | ||
| 33 | |||
| 34 | # Redirect all interrupts to core 0 | ||
| 35 | i=0 | ||
| 36 | for IRQ in /proc/irq/* | ||
| 37 | do | ||
| 38 | # Skip default_smp_affinity | ||
| 39 | if [ -d $IRQ ]; then | ||
| 40 | irqList[$i]=$(cat $IRQ/smp_affinity_list) | ||
| 41 | echo 0 2> /dev/null > $IRQ/smp_affinity_list | ||
| 42 | fi | ||
| 43 | i=$(( $i + 1 )) | ||
| 44 | done | ||
| 45 | |||
| 46 | # Read the names of each benchmark | ||
| 47 | j=0 | ||
| 48 | while read i; do | ||
| 49 | tacleProg[$j]=$i | ||
| 50 | j=$(( $j + 1 )) | ||
| 51 | done < $tacleNames | ||
| 52 | |||
| 53 | echo "Done. Checking for wbinvd module..." | ||
| 54 | if [[ ! -f "/proc/wbinvd" ]]; then | ||
| 55 | echo "ERROR: wbinvd module not loaded. Exiting..." | ||
| 56 | exit | ||
| 57 | fi | ||
| 58 | |||
| 59 | # Enable L3 isolation | ||
| 60 | echo "Done. Enabling L3 isolation..." | ||
| 61 | mount -t resctrl resctrl /sys/fs/resctrl | ||
| 62 | mkdir -p /sys/fs/resctrl/benchmarks | ||
| 63 | echo $1 > /sys/fs/resctrl/benchmarks/cpus_list | ||
| 64 | # Reset global bandwith control and remove L3 from global | ||
| 65 | echo "L3:0=ffff;1=ffff;2=ffff;3=0000" > /sys/fs/resctrl/schemata | ||
| 66 | echo "MB:0=2048;1=2048;2=2048;3=2048" > /sys/fs/resctrl/schemata | ||
| 67 | # Alloc L3 to benchmark | ||
| 68 | echo "L3:0=0000;1=0000;2=0000;3=00ff" > /sys/fs/resctrl/benchmarks/schemata | ||
| 69 | echo "MB:0=2048;1=2048;2=2048;3=2048" > /sys/fs/resctrl/benchmarks/schemata | ||
| 70 | echo "Done. Verifying configuration with user..." | ||
| 71 | |||
| 72 | # Generate file name string | ||
| 73 | # We append to this as we parse the environment settings | ||
| 74 | runID=$(date +"%b%d-%H") | ||
| 75 | |||
| 76 | # Confirm configuration with user | ||
| 77 | echo "=== Global Config ===" | ||
| 78 | cat /sys/fs/resctrl/schemata | ||
| 79 | echo "=== Core $1 Config ===" | ||
| 80 | cat /sys/fs/resctrl/benchmarks/cpus_list | ||
| 81 | cat /sys/fs/resctrl/benchmarks/schemata | ||
| 82 | if [[ $5 == "--contend" ]]; then | ||
| 83 | if [[ ! -f "/playpen/mc2/imx6q-thrasher/thrasher" ]]; then | ||
| 84 | echo "ERROR: thrasher binary not fonud. Exiting..." | ||
| 85 | exit | ||
| 86 | fi | ||
| 87 | echo "Will run 6 contending tasks" | ||
| 88 | runID=$runID-c | ||
| 89 | else | ||
| 90 | runID=$runID-xc | ||
| 91 | fi | ||
| 92 | if uname -a | grep -q "mc2"; then | ||
| 93 | echo "MC^2 Autodetected. NOT SUPPORTED. Exiting..." | ||
| 94 | exit | ||
| 95 | else | ||
| 96 | echo "MC^2 not detected. 50% L3 allocation enabled." | ||
| 97 | runID=$runID-i3 | ||
| 98 | fi | ||
| 99 | if pwd | grep -qi dis; then | ||
| 100 | echo "Autodetected DIS. Will use script-level looping." | ||
| 101 | fi | ||
| 102 | echo "Results will be saved as $runID-$userRunID.txt" | ||
| 103 | echo "Press enter to confirm environment, Ctrl-C to exit..." | ||
| 104 | read | ||
| 105 | |||
| 106 | # Start contending tasks | ||
| 107 | if [[ $5 == "--contend" ]]; then | ||
| 108 | echo "Done. Starting 6 contending tasks..." | ||
| 109 | # Run two contending tasks on each other CCX | ||
| 110 | taskset -c 1 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 111 | taskset -c 2 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 112 | taskset -c 5 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 113 | taskset -c 6 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 114 | taskset -c 9 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 115 | taskset -c 10 /playpen/mc2/imx6q-thrasher/thrasher & | ||
| 116 | fi | ||
| 117 | sleep 1 # Wait for contending tasks to start | ||
| 118 | echo "Done. Beginning benchmarks..." | ||
| 119 | |||
| 120 | num_tests=$(wc -l < $tacleNames) | ||
| 121 | for (( i = 0; i < $num_tests ; i++ )) | ||
| 122 | do | ||
| 123 | # If using DIS, we have to iterate in the script as DIS won't do it for us | ||
| 124 | pwd | grep -qi dis | ||
| 125 | iters=$(python3 -c "print(int(not "$?")*("$maxJobs"-1))") | ||
| 126 | for ((k=0;k<=iters;k++)); do | ||
| 127 | # Check if we're using LITMUS^RT or not | ||
| 128 | if [[ -f source/extra.h ]] && grep -q "#define LITMUS 1" source/extra.h; then | ||
| 129 | ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID-$userRunID 1 | ||
| 130 | else | ||
| 131 | # Interleave memory allocations between all nodes (only 1 node w/out MC^2) | ||
| 132 | chrt -r 97 numactl --interleave=all taskset -c $core ./bin/${tacleProg[$i]} ${tacleProg[$i]} $maxJobs $core $runID-$userRunID 1 | ||
| 133 | fi | ||
| 134 | done | ||
| 135 | echo COMPLETE: ${tacleProg[$i]} | ||
| 136 | done | ||
| 137 | |||
| 138 | # End contending tasks | ||
| 139 | if [[ $5 == "--contend" ]]; then | ||
| 140 | killall thrasher | ||
| 141 | fi | ||
| 142 | |||
| 143 | # Put smp_affinty back the way it was | ||
| 144 | i=0 | ||
| 145 | for IRQ in /proc/irq/* | ||
| 146 | do | ||
| 147 | if [ -d $IRQ ]; then | ||
| 148 | echo ${irqList[$i]} 2> /dev/null > $IRQ/smp_affinity_list | ||
| 149 | fi | ||
| 150 | i=$(( $i + 1 )) | ||
| 151 | done | ||
| 152 | |||
