automatically exploiting cross-invocation parallelism using runtime ...
automatically exploiting cross-invocation parallelism using runtime ...
automatically exploiting cross-invocation parallelism using runtime ...
You also want an ePaper? Increase the reach of your titles
YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.
Scheduler Function SchedulerSync Function1 void scheduler () {2 iternum = 0;3 threadID = getTid();4 for (i = 0; i < N; i++) {5 start = A[i];6 end = B[i];7 for (j = start; j < end; j++) {8 addr_set = computeAddr(iternum);9 tid = schedule(iternum, addr_set);10 tid_queue = getQueue(tid);11 schedulerSync(iternum, tid, tid_queue, addr_set);12 if (threadID == tid)13 worker(iternum, &C[j]);14 iternum++;}}}1 void schedulerSync(iternum, tid, queue, addr_set) {2 threadID = getTid();3 while (addr = get_next(addr_set)) {4 depTid = getTid(shadow[threadID][addr]);5 depIterNum = getIterNum(shadow[threadID][addr]);6 if (depTid != tid && depIterNum != -1 && threadID == tid) {7 produce(depTid, queue);8 produce(depIterNum, queue);}9 shadow[threadID][addr] = (tid, iternum);}10 if (threadID == tid) {11 produce(NO_SYNC, queue);}}Worker Function doWork FunctionworkerSync Function1 void worker(iternum, addr) {2 while (1) {3 depTid = consume();4 if (depTID == NO_SYNC) {5 doWork(iternum, addr);6 return;}7 else8 workerSync(depTid);}}1 void doWork(iternum, addr) {2 tid = getTid();3 update(addr);4 latestFinished[tid] = iternum;}1 void workerSync(depTid) {2 iternum = consume();3 while (latestFinished[depTid] < iternum)4 sleep();}Figure 3.10: Optimization for DOMORE technique: duplicating scheduler code on all worker threads to enable DOMORE in SPEC-CROSS framework.45