mirror of
https://github.com/torvalds/linux.git
synced 2024-11-19 18:41:48 +00:00
481eaec37e
This adds micro-benchmarks useful for tuning virtio ring layouts. Three layouts are currently implemented: - virtio 0.9 compatible one - an experimental extension bypassing the ring index, polling ring itself instead - an experimental extension bypassing avail and used ring completely Typical use: sh run-on-all.sh perf stat -r 10 --log-fd 1 -- ./ring It doesn't depend on the kernel directly, but it's handy to have as much virtio stuff as possible in one tree. Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
25 lines
630 B
Bash
Executable File
25 lines
630 B
Bash
Executable File
#!/bin/sh
|
|
|
|
#use last CPU for host. Why not the first?
|
|
#many devices tend to use cpu0 by default so
|
|
#it tends to be busier
|
|
HOST_AFFINITY=$(cd /dev/cpu; ls|grep -v '[a-z]'|sort -n|tail -1)
|
|
|
|
#run command on all cpus
|
|
for cpu in $(cd /dev/cpu; ls|grep -v '[a-z]'|sort -n);
|
|
do
|
|
#Don't run guest and host on same CPU
|
|
#It actually works ok if using signalling
|
|
if
|
|
(echo "$@" | grep -e "--sleep" > /dev/null) || \
|
|
test $HOST_AFFINITY '!=' $cpu
|
|
then
|
|
echo "GUEST AFFINITY $cpu"
|
|
"$@" --host-affinity $HOST_AFFINITY --guest-affinity $cpu
|
|
fi
|
|
done
|
|
echo "NO GUEST AFFINITY"
|
|
"$@" --host-affinity $HOST_AFFINITY
|
|
echo "NO AFFINITY"
|
|
"$@"
|