#include #include #include #include static struct traceobj trobj; static int tseq[] = { 8, 1, 9, 4, 10, 5, 11, 2, 6, 7 }; static u_long btid, ftid; static u_long sem_id; static void backgroundTask(u_long a1, u_long a2, u_long a3, u_long a4) { unsigned int safety = 100000000, count = 0; int ret; traceobj_enter(&trobj); traceobj_mark(&trobj, 1); ret = sm_p(sem_id, SM_WAIT, 0); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 2); while (--safety > 0) count++; traceobj_mark(&trobj, 3); traceobj_exit(&trobj); } static void foregroundTask(u_long a1, u_long a2, u_long a3, u_long a4) { int ret; traceobj_enter(&trobj); traceobj_mark(&trobj, 4); ret = sm_p(sem_id, SM_WAIT, 0); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 5); tm_wkafter(2); traceobj_mark(&trobj, 6); ret = t_delete(btid); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 7); traceobj_exit(&trobj); } int main(int argc, char *const argv[]) { u_long args[] = { 1, 2, 3, 4 }; int ret; traceobj_init(&trobj, argv[0], sizeof(tseq) / sizeof(int)); ret = sm_create("SEMA", 0, SM_PRIOR, &sem_id); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 8); ret = t_create("BGND", 20, 0, 0, 0, &btid); traceobj_assert(&trobj, ret == SUCCESS); ret = t_start(btid, 0, backgroundTask, args); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 9); ret = t_create("FGND", 21, 0, 0, 0, &ftid); traceobj_assert(&trobj, ret == SUCCESS); ret = t_start(ftid, 0, foregroundTask, args); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 10); ret = sm_v(sem_id); traceobj_assert(&trobj, ret == SUCCESS); traceobj_mark(&trobj, 11); ret = sm_v(sem_id); traceobj_assert(&trobj, ret == SUCCESS); traceobj_join(&trobj); traceobj_verify(&trobj, tseq, sizeof(tseq) / sizeof(int)); exit(0); }