| [02fa55e] | 1 | #include <select.hfa>
 | 
|---|
 | 2 | #include <thread.hfa>
 | 
|---|
 | 3 | #include <channel.hfa>
 | 
|---|
 | 4 | 
 | 
|---|
 | 5 | channel(long long int) A, B, C;
 | 
|---|
 | 6 | 
 | 
|---|
 | 7 | volatile bool done = false;
 | 
|---|
 | 8 | long long int globalTotal = 0;
 | 
|---|
 | 9 | 
 | 
|---|
 | 10 | thread Server1 {};
 | 
|---|
 | 11 | void main( Server1 & this ) {
 | 
|---|
 | 12 |     long long int a, b, c, i = 0, myTotal = 0;
 | 
|---|
 | 13 |     for( ;;i++ ) {
 | 
|---|
 | 14 |         // printf("loop S\n");
 | 
|---|
 | 15 |         waituntil( a << A ) { myTotal += a; }
 | 
|---|
 | 16 |         or waituntil( b << B ) { myTotal += b; }
 | 
|---|
 | 17 |         or waituntil( c << C ) { if ( c == -1 ) break; myTotal += c; }
 | 
|---|
 | 18 |     }
 | 
|---|
 | 19 |     __atomic_fetch_add( &globalTotal, myTotal, __ATOMIC_SEQ_CST );
 | 
|---|
 | 20 | }
 | 
|---|
 | 21 | 
 | 
|---|
 | 22 | size_t numtimes = 100000;
 | 
|---|
 | 23 | size_t numServers = 1;
 | 
|---|
 | 24 | int main( int argc, char * argv[] ) {
 | 
|---|
 | 25 |     if ( argc == 2 )
 | 
|---|
 | 26 |         numtimes = atoi( argv[1] );
 | 
|---|
 | 27 | 
 | 
|---|
 | 28 |     processor p[numServers];
 | 
|---|
 | 29 |     A{0};
 | 
|---|
 | 30 |     B{0};
 | 
|---|
 | 31 |     C{0};
 | 
|---|
 | 32 | 
 | 
|---|
 | 33 |     long long int total = 0;
 | 
|---|
 | 34 |     printf("start\n");
 | 
|---|
 | 35 |     {
 | 
|---|
 | 36 |         Server1 s[numServers];
 | 
|---|
 | 37 |         for( long long int j = 0; j < numtimes; j++ ) {
 | 
|---|
 | 38 |             // printf("loop\n");
 | 
|---|
 | 39 |             waituntil( j >> A ) { total += j; }
 | 
|---|
 | 40 |             or waituntil( j >> B ) { total += j; }
 | 
|---|
 | 41 |             or waituntil( j >> C ) { total += j; }
 | 
|---|
 | 42 |         }
 | 
|---|
 | 43 |         printf("sending sentinels\n");
 | 
|---|
 | 44 |         for ( i; numServers ) insert( C, -1 );
 | 
|---|
 | 45 |         printf("joining servers\n");
 | 
|---|
 | 46 |     }
 | 
|---|
 | 47 |     if ( total != globalTotal ) 
 | 
|---|
 | 48 |         printf("CHECKSUM MISMATCH!! Main thread got %lld, server sum is %lld\n", total, globalTotal);
 | 
|---|
 | 49 |     printf("done\n");
 | 
|---|
 | 50 | }
 | 
|---|