Skip to content

Commit

Permalink
Added benchmark support for x86 and aarch32
Browse files Browse the repository at this point in the history
Signed-off-by: Alwin Joshy <[email protected]>
  • Loading branch information
alwin-joshy committed Jun 5, 2023
1 parent b9346b2 commit 28e7ea6
Show file tree
Hide file tree
Showing 4 changed files with 111 additions and 3 deletions.
6 changes: 5 additions & 1 deletion apps/fault/src/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -578,13 +578,15 @@ static void run_fault_benchmark(env_t *env, fault_results_t *results)
run_benchmark(measure_fault_roundtrip_fn_ep, measure_fault_roundtrip_handler_fn, done_ep.cptr,
N_HANDLER_ARGS, handler_argv);

#ifndef CONFIG_ARCH_IA32
/* benchmark vm fault */
run_benchmark(measure_vm_fault_fn, measure_vm_fault_handler_fn, done_ep.cptr,
N_VM_HANDLER_ARGS, vm_handler_argv);

/* benchmark vm fault reply */
run_benchmark(measure_vm_fault_reply_fn, measure_vm_fault_reply_handler_fn,
done_ep.cptr, N_VM_HANDLER_ARGS, vm_handler_argv);
#endif
}

void measure_overhead(fault_results_t *results)
Expand All @@ -603,12 +605,14 @@ void measure_overhead(fault_results_t *results)
results->reply_recv_1_overhead[i] = (end - start);
}

#ifndef CONFIG_ARCH_IA32
for (int i = 0; i < N_RUNS; i++) {
SEL4BENCH_READ_CCNT(start)
SEL4BENCH_READ_CCNT(start);
DO_NOP_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, reply);
SEL4BENCH_READ_CCNT(end);
results->reply_0_recv_4_overhead[i] = (end - start);
}
#endif

/* overhead of cycle count */
for (int i = 0; i < N_RUNS; i++) {
Expand Down
39 changes: 39 additions & 0 deletions libsel4benchsupport/sel4_arch_include/aarch32/sel4_arch/fault.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,25 @@
ip = mr0; \
} while(0)

#define DO_REPLY_0_RECV_4(ep, m0, m1, m2, m3, ro, swi) do { \
register seL4_Word src asm("r0") = (seL4_Word)ep; \
register seL4_MessageInfo_t info asm("r1") = seL4_MessageInfo_new(0, 0, 0, 0); \
register seL4_Word scno asm("r7") = seL4_SysReplyRecv; \
register seL4_Word ro_copy asm("r6") = (seL4_Word) ro; \
register seL4_Word mr0 asm("r2"); \
register seL4_Word mr1 asm("r3"); \
register seL4_Word mr2 asm("r4"); \
register seL4_Word mr3 asm("r5"); \
asm volatile(NOPS swi NOPS \
: "+r"(src), "+r"(info), "+r" (mr0), "+r" (mr1), "+r" (mr2), "+r" (mr3) \
: "r"(scno), "r" (ro_copy) \
); \
m0 = mr0; \
m1 = mr1; \
m2 = mr2; \
m3 = mr3; \
} while(0)


#else
#define DO_REPLY_RECV_1(ep, ip, ro, swi) do { \
Expand All @@ -36,7 +55,27 @@
); \
ip = mr0; \
} while(0)

#define DO_REPLY_0_RECV_4(ep, m0, m1, m2, m3, ro, swi) do { \
register seL4_Word src asm("r0") = (seL4_Word)ep; \
register seL4_MessageInfo_t info asm("r1") = seL4_MessageInfo_new(0, 0, 0, 1); \
register seL4_Word scno asm("r7") = seL4_SysReplyRecv; \
register seL4_Word mr0 asm("r2"); \
register seL4_Word mr1 asm("r3"); \
register seL4_Word mr2 asm("r4"); \
register seL4_Word mr3 asm("r5"); \
asm volatile(NOPS swi NOPS \
: "+r"(src), "+r"(info), "+r" (mr0), "+r" (mr1), "+r" (mr2), "+r" (mr3) \
: "r"(scno) \
); \
m0 = mr0; \
m1 = mr1; \
m2 = mr2; \
m3 = mr3; \
} while(0)
#endif /* CONFIG_KERNEL_MCS */

#define DO_REAL_REPLY_RECV_1(ep, mr0, ro) DO_REPLY_RECV_1(ep, mr0, ro, "swi $0")
#define DO_NOP_REPLY_RECV_1(ep, mr0, ro) DO_REPLY_RECV_1(ep, mr0, ro, "nop")
#define DO_REAL_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro) DO_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro, "swi $0")
#define DO_NOP_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro) DO_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro, "nop")
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,7 @@
register seL4_Word mr3 asm("x5"); \
asm volatile(NOPS swi NOPS \
: "+r"(src), "+r"(info), "+r" (mr0), "+r" (mr1), "+r" (mr2), "+r" (mr3) \
: "r"(scno), "r" (ro_copy)\
: \
: "r"(scno), "r" (ro_copy) \
); \
m0 = mr0; \
m1 = mr1; \
Expand Down
66 changes: 66 additions & 0 deletions libsel4benchsupport/sel4_arch_include/x86_64/sel4_arch/fault.h
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,39 @@
msg0 = mr0; \
} while(0)

#define DO_REPLY_0_RECV_4(ep, m0, m1, m2, m3, ro, sys) do { \
uint64_t ep_copy = ep; \
seL4_MessageInfo_t tag = seL4_MessageInfo_new(0, 0, 0, 0); \
register seL4_Word mr0 asm("r10"); \
register seL4_Word mr1 asm("r8"); \
register seL4_Word mr2 asm("r9"); \
register seL4_Word mr3 asm("r15"); \
register seL4_Word ro_copy asm("r12") = ro;\
asm volatile( \
"movq %%rsp, %%rbx \n" \
sys" \n" \
"mov %%rbx, %%rsp \n"\
: \
"+S" (tag), \
"+D" (ep_copy), \
"=r" (mr0), \
"=r" (mr1), \
"=r" (mr2), \
"=r" (mr3) \
: \
"d" ((seL4_Word)seL4_SysReplyRecv), \
"r" (ro_copy)\
: \
"%rcx", \
"%rbx", \
"%r11" \
); \
m0 = mr0; \
m1 = mr1; \
m2 = mr2; \
m3 = mr3; \
} while(0)

static inline seL4_MessageInfo_t seL4_RecvWith1MR(seL4_CPtr src, seL4_Word *mr0, seL4_CPtr reply)
{
return seL4_RecvWithMRs(src, NULL, mr0, NULL, NULL, NULL, reply);
Expand Down Expand Up @@ -78,6 +111,37 @@ static inline void seL4_ReplyWith1MR(seL4_Word mr0, seL4_CPtr dest)
msg0 = mr0; \
} while(0)

#define DO_REPLY_0_RECV_4(ep, m0, m1, m2, m3, ro, sys) do { \
uint64_t ep_copy = ep; \
seL4_MessageInfo_t tag = seL4_MessageInfo_new(0, 0, 0, 0); \
register seL4_Word mr0 asm("r10"); \
register seL4_Word mr1 asm("r8"); \
register seL4_Word mr2 asm("r9"); \
register seL4_Word mr3 asm("r15"); \
asm volatile( \
"movq %%rsp, %%rbx \n" \
sys" \n" \
"mov %%rbx, %%rsp \n"\
: \
"+S" (tag), \
"+D" (ep_copy), \
"=r" (mr0), \
"=r" (mr1), \
"=r" (mr2), \
"=r" (mr3) \
: \
"d" ((seL4_Word)seL4_SysReplyRecv) \
: \
"%rcx", \
"%rbx", \
"%r11" \
); \
m0 = mr0; \
m1 = mr1; \
m2 = mr2; \
m3 = mr3; \
} while(0)

static inline seL4_MessageInfo_t seL4_RecvWith1MR(seL4_CPtr src, seL4_Word *mr0, UNUSED seL4_CPtr reply)
{
return seL4_RecvWithMRs(src, NULL, mr0, NULL, NULL, NULL);
Expand All @@ -92,6 +156,8 @@ static inline void seL4_ReplyWith1MR(seL4_Word mr0, UNUSED seL4_CPtr dest)

#define DO_REAL_REPLY_RECV_1(ep, mr0, ro) DO_REPLY_RECV_1(ep, mr0, ro, "syscall")
#define DO_NOP_REPLY_RECV_1(ep, mr0, ro) DO_REPLY_RECV_1(ep, mr0, ro, ".byte 0x66\n.byte 0x90")
#define DO_REAL_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro) DO_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro, "syscall")
#define DO_NOP_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro) DO_REPLY_0_RECV_4(ep, mr0, mr1, mr2, mr3, ro, ".byte 0x66\n.byte 0x90")

#else
#error Only support benchmarking with syscall as sysenter is known to be slower
Expand Down

0 comments on commit 28e7ea6

Please sign in to comment.