mirror of
https://gitlab.com/manzerbredes/ina260-beaglebone-performance.git
synced 2025-04-05 03:46:24 +02:00
138 lines
No EOL
4.9 KiB
Bash
Executable file
138 lines
No EOL
4.9 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
set -e
|
|
|
|
wai=$(dirname $(readlink -f "$0")) # Current script directory
|
|
source ${wai}/config
|
|
|
|
info () {
|
|
echo -e "\033[0;32m$@\033[0m"
|
|
}
|
|
|
|
abort () {
|
|
echo -e "\033[0;31m$@\033[0m"
|
|
exit 1
|
|
}
|
|
|
|
iperf-run () {
|
|
info "---------- Running iperf test ----------"
|
|
iperf -c ${hostip}
|
|
}
|
|
|
|
pure-read () {
|
|
local clean="${1:-1}"
|
|
local inmem="${2:-0}"
|
|
info "---------- Running pure read experiments (inmem=${inmem},clean=${clean}) ----------"
|
|
info "Ensuring that ina260 devices are connected..."
|
|
for dev in $inadev
|
|
do
|
|
bus=$(echo $dev|cut -d: -f1)
|
|
addr=$(echo $dev|cut -d: -f2)
|
|
[ -z $(ls /sys/kernel/ina260/ |grep "${bus}-.*${addr#0x}") ] && echo ina260 $addr | sudo tee "/sys/bus/i2c/devices/i2c-${bus}/new_device"
|
|
[ -z $(ls /sys/kernel/ina260/ |grep "${bus}-.*${addr#0x}") ] && abort "Cannot connect $dev"
|
|
done
|
|
info "Compiling..."
|
|
make -C ${wai}/pure-read -B
|
|
[ $clean -eq 1 ] && rm -f ${wai}/pure_read_bus*.out
|
|
local ndev=$(echo $inadev|wc -w)
|
|
for usen in $(seq 1 $ndev)
|
|
do
|
|
info "Run $nread read over $usen devices"
|
|
local n=0
|
|
unset pids # Erase previous pids
|
|
for dev in $inadev
|
|
do
|
|
local bus=$(echo $dev|cut -d: -f1)
|
|
local addr=$(echo $dev|cut -d: -f2)
|
|
local devicepath=$(realpath /sys/kernel/ina260/${bus}-*${addr#0x})
|
|
local deviceid=$(basename ${devicepath})
|
|
local logfile=${wai}/pure_read_bus${bus}_addr${addr}_usen${usen}_nread${nread}_inmem${inmem}.out
|
|
echo "${bus}:${addr}:${usen}:${nread}:${deviceid}" > ${logfile}
|
|
/usr/bin/time -f "statsline:%P:%M" ${wai}/pure-read/read $deviceid $nread $inmem &>> ${logfile} &
|
|
pids[${i}]=$!
|
|
n=$(( n + 1 ))
|
|
[ $n -eq $usen ] && break
|
|
done
|
|
# Wait for all pids
|
|
for pid in ${pids[*]}; do
|
|
wait $pid
|
|
done
|
|
sync # Ensure that I/O are applied on sdcard
|
|
info "Beaglebone is resting for ${readrest}s"
|
|
sleep ${readrest}
|
|
done
|
|
# Generate the results
|
|
info "Collecting logs..."
|
|
local csv="${wai}/pure_read.csv"
|
|
[ $clean -eq 1 ] && echo "bus,addr,usen,nread,deviceid,startat,endat,inmem,cpu_usage,resident,timestamp,nsecs,power" > "$csv"
|
|
for logfile in ${wai}/pure_read_bus*inmem${inmem}.out
|
|
do
|
|
local bus=$(head -n1 "$logfile"|cut -d: -f1)
|
|
local addr=$(head -n1 "$logfile"|cut -d: -f2)
|
|
local usen=$(head -n1 "$logfile"|cut -d: -f3)
|
|
local nread=$(head -n1 "$logfile"|cut -d: -f4)
|
|
local deviceid="${bus}-${addr}"
|
|
local startat=$(cat "$logfile"|grep startat|cut -d: -f2)
|
|
local endat=$(cat "$logfile"|grep endat|cut -d: -f2)
|
|
local cpu_usage=$(cat "$logfile"|grep statsline|cut -d: -f2|awk '{print(($0+0)/100)}')
|
|
local resident=$(cat "$logfile"|grep statsline|cut -d: -f3|awk '{print(($0+0)*1000)}')
|
|
local infos="${bus},${addr},${usen},${nread},${deviceid},${startat},${endat},${inmem},${cpu_usage},${resident}"
|
|
awk '/Power is/ { print("'${infos}',"$2+0","$3+0","$6+0)}' "$logfile" >> "$csv"
|
|
done
|
|
}
|
|
|
|
zmq () {
|
|
echo "---------- Running zmq experiments ----------"
|
|
info "Disconnecting all ina260..."
|
|
for dev in $(ls /sys/kernel/ina260/)
|
|
do
|
|
dev=$(basename $dev)
|
|
bus=$(echo $dev|cut -d\- -f1)
|
|
addr=$(echo $dev|cut -d\- -f2)
|
|
echo 0x${addr} | sudo tee /sys/bus/i2c/devices/i2c-${bus}/delete_device
|
|
done
|
|
# Setup publisher
|
|
cd ${wai}/ina260-zmq-publisher
|
|
rm -f publisher_*.log
|
|
info "Compiling..."
|
|
make -B
|
|
# Run experiments (add one new ina260 at each loop)
|
|
local n=1
|
|
for dev in $inadev
|
|
do
|
|
info "Run zmq over $n devices for ${zmqduration}s"
|
|
bus=$(echo $dev|cut -d: -f1)
|
|
addr=$(echo $dev|cut -d: -f2)
|
|
[ -z $(ls /sys/kernel/ina260/ |grep "${bus}-.*${addr#0x}") ] && echo ina260 $addr | sudo tee "/sys/bus/i2c/devices/i2c-${bus}/new_device"
|
|
[ -z $(ls /sys/kernel/ina260/ |grep "${bus}-.*${addr#0x}") ] && abort "Cannot connect $dev"
|
|
# Run experiment
|
|
sed "s/^KEY=.*/KEY=usen$n/g" -i config.mk
|
|
make publish &
|
|
sleep ${zmqduration}
|
|
kill -s SIGINT $(cat pid)
|
|
# Wait for all publisher processes to end:
|
|
for pid in $(cat pid)
|
|
do
|
|
while ps -p $pid > /dev/null; do continue; done
|
|
done
|
|
# Done
|
|
n=$(( n + 1 ))
|
|
info "Beaglebone is resting for ${zmqrest}s"
|
|
sleep $zmqrest
|
|
done
|
|
cd ${wai} # Go back to last directory
|
|
}
|
|
|
|
##### Run experiments
|
|
# Network benchmark
|
|
iperf-run
|
|
info "Sleep ${delayiperfpure}s before starting pure-read experiments..."
|
|
sleep ${delayiperfpure}
|
|
# Pure read
|
|
pure-read 1 1 # Do in memory first!
|
|
pure-read 0 0 # This way, we are sure in file has no impact
|
|
# Sleep
|
|
info "Sleep ${delaypurezmq}s before starting zmq experiments..."
|
|
sleep ${delaypurezmq}
|
|
# ZMQ
|
|
zmq |