#include <unistd.h>
#include <sched.h>
#include <ust/marker.h>
+#include <time.h>
static int nr_cpus;
static unsigned long nr_events;
-pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER;
void do_stuff(void)
{
int v;
FILE *file;
- int lock;
v = 1;
- lock = pthread_mutex_lock(&mutex);
- file = fopen("/tmp/bench.txt", "a");
+ file = fopen("/dev/null", "a");
fprintf(file, "%d", v);
fclose(file);
- lock = pthread_mutex_unlock(&mutex);
+ time(NULL);
#ifdef MARKER
trace_mark(ust, event, "event %d", v);
return NULL;
}
-
void usage(char **argv) {
printf("Usage: %s nr_cpus nr_events\n", argv[0]);
}
echo "ust benchmark"
-NR_EVENTS=2000000
+NR_EVENTS=4000000
NR_CPUS=2
echo "using $NR_CPUS processor(s)"
echo "using $NR_EVENTS events per cpu"
rm -f /tmp/bench.txt
# without markers
echo ">running without markers"
-t1=$(/usr/bin/time -f%e usttrace ./bench1 $NR_CPUS $NR_EVENTS 2>&1 1> /dev/null)
+#t1=$(/usr/bin/time -f%e usttrace ./bench1 $NR_CPUS $NR_EVENTS 2>&1 1> /dev/null)
+t1=$(/usr/bin/time -f%e ./bench1 $NR_CPUS $NR_EVENTS 2>&1 1> /dev/null)
echo " time=$t1 sec"
echo "time penalty=$penalty sec"
#event = penalty / (nr_events * nr_cpus)
-event=$(echo "scale=8; ($penalty / ($NR_EVENTS * $NR_CPUS));" | bc)
+event=$(echo "scale=10; ($penalty / ($NR_EVENTS * $NR_CPUS));" | bc)
echo "time penalty per event=$event sec"
rm -f /tmp/bench.txt