- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/tests/concurrent/examples/boundedBuffer.c
r1edf37f ra1ecdd1 8 8 // Created On : Mon Oct 30 12:45:13 2017 9 9 // Last Modified By : Peter A. Buhr 10 // Last Modified On : Thu Dec 14 21:28:52201711 // Update Count : 3210 // Last Modified On : Wed Dec 13 21:01:49 2017 11 // Update Count : 27 12 12 // 13 13 … … 18 18 #include <unistd.h> // getpid 19 19 20 forall( otype T ) 20 21 monitor Buffer { 21 22 condition full, empty; 22 23 int front, back, count; 23 intelements[20];24 T elements[20]; 24 25 }; 25 26 26 void ?{}( Buffer & buffer ) { 27 forall( otype T ) 28 void ?{}( Buffer(T) & buffer ) { 27 29 buffer.front = buffer.back = buffer.count = 0; 28 30 } 29 31 30 int query( Buffer & buffer ) { return buffer.count; } 32 forall( otype T ) 33 int query( Buffer(T) & buffer ) { return buffer.count; } 31 34 32 void insert( Buffer & mutex buffer, int elem ) with( buffer ) { 35 forall( otype T ) 36 void insert( Buffer(T) & mutex buffer, T elem ) with( buffer ) { 33 37 if ( count == 20 ) wait( empty ); 34 38 elements[back] = elem; … … 38 42 } 39 43 40 int remove( Buffer & mutex buffer ) with( buffer ) { 44 forall( otype T ) 45 T remove( Buffer(T) & mutex buffer ) with( buffer ) { 41 46 if ( count == 0 ) wait( full ); 42 intelem = elements[front];47 T elem = elements[front]; 43 48 front = ( front + 1 ) % 20; 44 49 count -= 1; … … 48 53 49 54 thread Producer { 50 Buffer & buffer;55 Buffer(int) & buffer; 51 56 unsigned int N; 52 57 }; … … 58 63 insert( prod.buffer, -1 ); 59 64 } 60 void ?{}( Producer & prod, Buffer * buffer, unsigned int N ) {65 void ?{}( Producer & prod, Buffer(int) * buffer, unsigned int N ) { 61 66 &prod.buffer = buffer; 62 67 prod.N = N; … … 64 69 65 70 thread Consumer { 66 Buffer & buffer;71 Buffer(int) & buffer; 67 72 int & sum; // summation of producer values 68 73 }; … … 76 81 } // for 77 82 } 78 void ?{}( Consumer & cons, Buffer * buffer, int * sum ) {83 void ?{}( Consumer & cons, Buffer(int) * buffer, int * sum ) { 79 84 &cons.buffer = buffer; 80 85 &cons.sum = sum; … … 82 87 83 88 int main() { 84 Buffer buffer;89 Buffer(int) buffer; 85 90 enum { Prods = 5, Cons = 5 }; 86 91 Producer * prods[Prods];
Note: See TracChangeset
for help on using the changeset viewer.