source: tests/concurrency/waituntil/channel_zero_size.cfa @ 1db6d70

ast-experimental
Last change on this file since 1db6d70 was c26bea2a, checked in by Peter A. Buhr <pabuhr@…>, 13 months ago

first attempt at renaming directory tests/concurrent to tests/concurrency to harmonize with other concurrency directory names

  • Property mode set to 100644
File size: 1.3 KB
Line 
1#include <select.hfa>
2#include <thread.hfa>
3#include <channel.hfa>
4
5channel(long long int) A, B, C;
6
7volatile bool done = false;
8long long int globalTotal = 0;
9
10thread Server1 {};
11void 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
22size_t numtimes = 100000;
23size_t numServers = 1;
24int 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}
Note: See TracBrowser for help on using the repository browser.