source: benchmark/readyQ/churn.cpp @ 12bb5ab1

ADTast-experimentalpthread-emulationqualifiedEnum
Last change on this file since 12bb5ab1 was 12bb5ab1, checked in by Thierry Delisle <tdelisle@…>, 2 years ago

Implemented the churn benchmark for libfibre.
Trivial change to the cfa version.

  • Property mode set to 100644
File size: 2.9 KB
Line 
1#include "rq_bench.hpp"
2#include <libfibre/fibre.h>
3
4unsigned spot_cnt = 2;
5FredSemaphore * spots;
6
7struct Churner {
8        unsigned long long count = 0;
9        unsigned long long blocks = 0;
10        bool skip = false;
11        __lehmer64_state_t seed;
12        bench_sem self;
13};
14
15void churner_main( Churner * self ) {
16        fibre_park();
17        for(;;) {
18                unsigned r = __lehmer64( self->seed );
19                FredSemaphore & sem = spots[r % spot_cnt];
20                if(!self->skip) sem.V();
21                self->blocks += sem.P() == SemaphoreWasOpen ? 1 : 0;
22                self->skip = false;
23
24                self->count ++;
25                if( clock_mode && stop) break;
26                if(!clock_mode && self->count >= stop_count) break;
27        }
28
29        __atomic_fetch_add(&threads_left, -1, __ATOMIC_SEQ_CST);
30}
31
32int main(int argc, char * argv[]) {
33        option_t opt[] = {
34                BENCH_OPT,
35                { 's', "spots", "Number of spots in the system", spot_cnt }
36        };
37        BENCH_OPT_PARSE("libfibre churn benchmark");
38
39        {
40                unsigned long long global_counter = 0;
41                unsigned long long global_blocks  = 0;
42                uint64_t start, end;
43                FibreInit(1, nprocs );
44                {
45                        spots = new FredSemaphore[spot_cnt]();
46
47                        threads_left = nthreads;
48                        Churner * thddata = new Churner[nthreads]();
49                        for(unsigned i = 0; i < nthreads; i++ ) {
50                                Churner & t = thddata[i];
51                                t.skip = i < spot_cnt;
52                                t.seed = rand();
53                        }
54                        Fibre * threads[nthreads];
55                        for(unsigned i = 0; i < nthreads; i++) {
56                                threads[i] = new Fibre( reinterpret_cast<void (*)(void *)>(churner_main), &thddata[i] );
57                        }
58                        printf("Starting\n");
59
60                        bool is_tty = isatty(STDOUT_FILENO);
61                        start = timeHiRes();
62
63                        for(unsigned i = 0; i < nthreads; i++ ) {
64                                fibre_unpark( threads[i] );
65                        }
66                        wait<Fibre>(start, is_tty);
67
68                        stop = true;
69                        end = timeHiRes();
70                        printf("\nDone\n");
71
72                        for(unsigned i = 0; i < spot_cnt; i++) {
73                                for(int j = 0; j < 10000; j++) spots[i].V();
74                        }
75
76                        printf("All Vd\n");
77
78                        for(unsigned i = 0; i < nthreads; i++ ) {
79                                fibre_join( threads[i], nullptr );
80                                global_counter += thddata[i].count;
81                                global_blocks  += thddata[i].blocks;
82                        }
83
84                        printf("Fibers Joined\n");
85
86                        delete[](spots);
87                        delete[](thddata);
88                }
89
90                printf("\nDone2\n");
91
92                printf("Duration (ms)        : %'ld\n", to_miliseconds(end - start));
93                printf("Number of processors : %'d\n", nprocs);
94                printf("Number of threads    : %'d\n", nthreads);
95                printf("Number of spots      : %'d\n", spot_cnt);
96                printf("Total Operations(ops): %'15llu\n", global_counter);
97                printf("Total blocks         : %'15llu\n", global_blocks);
98                printf("Ops per second       : %'18.2lf\n", ((double)global_counter) / to_fseconds(end - start));
99                printf("ns per ops           : %'18.2lf\n", ((double)(end - start)) / global_counter);
100                printf("Ops per threads      : %'15llu\n", global_counter / nthreads);
101                printf("Ops per procs        : %'15llu\n", global_counter / nprocs);
102                printf("Ops/sec/procs        : %'18.2lf\n", (((double)global_counter) / nprocs) / to_fseconds(end - start));
103                printf("ns per ops/procs     : %'18.2lf\n", ((double)(end - start)) / (global_counter / nprocs));
104                fflush(stdout);
105        }
106
107        return 0;
108
109}
Note: See TracBrowser for help on using the repository browser.