Changes in / [54eb1bb3:dd92fe9]


Ignore:
Files:
1 deleted
6 edited

Legend:

Unmodified
Added
Removed
  • doc/theses/thierry_delisle_PhD/code/readQ_example/Makefile

    r54eb1bb3 rdd92fe9  
    1 all: gui-proto-pthread gui-proto-fibre gui-proto-cforall
    2 
    3 PRECIOUS: thrdlib/libthrd-pthread.so thrdlib/libthrd-fibre.so thrdlib/libthrd-cforall.so
     1all: gui-proto
    42
    53CXXFLAGS = -fpic -g -O0 -I.
    64
    7 thrdlib/libthrd-%.so:
    8         +${MAKE} -C thrdlib libthrd-$*.so
    9 
    10 gui-proto-%: proto-gui/main.o thrdlib/libthrd-%.so Makefile
    11         $(CXX) -Lthrdlib -Wl,--rpath,thrdlib -pthread -o $@ $< -lthrd-$*
    12 
    13 CFAINC=${HOME}/local/include/cfa-dev
    14 CFALIB=${HOME}/local/lib/cfa-dev/x64-debug
    15 CFAFLAGS=-z execstack -ftls-model=initial-exec -L${CFALIB} -Wl,-rpath,${CFALIB}
    16 
    17 gui-proto-cforall: proto-gui/main.o thrdlib/libthrd-cforall.so Makefile
    18         $(CXX) -Lthrdlib -Wl,--rpath,thrdlib ${CFAFLAGS} -pthread -o $@ $< -lthrd-cforall -Wl,--push-state,--no-as-needed -lcfathread -lcfa -ldl -lm -Wl,--pop-state
     5gui-proto: proto-gui/main.o thrdlib/thread.o
     6        $(CXX) -pthread -ldl -o ${@} ${^} -ftls-model=initial-exec
  • doc/theses/thierry_delisle_PhD/code/readQ_example/proto-gui/main.cpp

    r54eb1bb3 rdd92fe9  
    1111#include <getopt.h>
    1212using thrdlib::thread_t;
     13
     14
     15extern __attribute__((aligned(128))) thread_local struct {
     16        void * volatile this_thread;
     17        void * volatile this_processor;
     18        void * volatile this_stats;
     19
     20        struct {
     21                volatile unsigned short disable_count;
     22                volatile bool enabled;
     23                volatile bool in_progress;
     24        } preemption_state;
     25
     26        #if defined(__SIZEOF_INT128__)
     27                __uint128_t rand_seed;
     28        #else
     29                uint64_t rand_seed;
     30        #endif
     31        struct {
     32                uint64_t fwd_seed;
     33                uint64_t bck_seed;
     34        } ready_rng;
     35} kernelTLS __attribute__ ((tls_model ( "initial-exec" )));
    1336
    1437//--------------------
     
    125148}
    126149
    127 typedef uint64_t __wyhash64_state_t;
    128 static inline uint64_t __wyhash64( __wyhash64_state_t & state ) {
    129         state += 0x60bee2bee120fc15;
    130         __uint128_t tmp;
    131         tmp = (__uint128_t) state * 0xa3b195354a39b70d;
    132         uint64_t m1 = (tmp >> 64) ^ tmp;
    133         tmp = (__uint128_t)m1 * 0x1b03738712fad5c9;
    134         uint64_t m2 = (tmp >> 64) ^ tmp;
    135         return m2;
    136 }
    137 
    138150void Simulator( thread_t self ) {
    139151        for(unsigned i = 0; i < nproduce; i++) {
     
    144156                }
    145157
    146                 __wyhash64_state_t state = 0;
    147 
    148158                // Write the frame information
    149159                frame.number = i;
    150160                for( unsigned x = 0; x < fsize; x++ ) {
    151                         frame.data[x] = __wyhash64(state);
     161                        frame.data[x] = i;
    152162                }
    153163                std::cout << "Simulated " << i << std::endl;
     
    177187
    178188                std::cout << "Rendered " << i << std::endl;
    179                 // assert(total == i * fsize);
     189                assert(total == i * fsize);
    180190
    181191                // Release
     
    191201int main(int argc, char * argv[]) {
    192202        nframes  = 3;
    193         fsize    = 3840 * 2160 * 4 * 4;
     203        fsize    = 1000;
    194204        nproduce = 60;
     205
     206        const char * framework;
    195207
    196208        for(;;) {
     
    210222                        // Exit Case
    211223                        case -1:
     224                                /* paranoid */ assert(optind <= argc);
     225                                if( optind == argc ) {
     226                                        std::cerr << "Must specify a framework" << std::endl;
     227                                        goto usage;
     228
     229                                }
     230                                framework = argv[optind];
    212231                                goto run;
    213232                        case 'b':
     
    242261                                std::cerr << opt << std::endl;
    243262                        usage:
    244                                 std::cerr << "Usage: " << argv[0] << " [options]" << std::endl;
     263                                std::cerr << "Usage: " << argv[0] << " [options] framework" << std::endl;
    245264                                std::cerr << std::endl;
    246265                                std::cerr << "  -b, --buff=COUNT    Number of frames to buffer" << std::endl;
     
    251270        }
    252271        run:
     272        assert( framework );
     273
    253274        frames.reset(new Frame[nframes]);
    254275        for(unsigned i = 0; i < nframes; i++) {
     
    259280        std::cout << "(Buffering " << nframes << ")" << std::endl;
    260281
    261         thrdlib::init( 2 );
     282        thrdlib::init( framework, 2 );
    262283
    263284        thread_t stats     = thrdlib::create( Stats );
  • doc/theses/thierry_delisle_PhD/code/readQ_example/thrdlib/Makefile

    r54eb1bb3 rdd92fe9  
    1 all: fibre.so libthrd-pthread.so.so cforall.so
     1all: fibre.so pthread.so cforall.so
    22
    33clean:
    4         rm -rf fibre.so libthrd-pthread.so.so cforall.so
     4        rm -rf fibre.so pthread.so
    55
    66CXXFLAGS=-Wall -Wextra -O3 -g -fpic -std=c++17 -pthread -ftls-model=initial-exec
    77
    8 libthrd-pthread.so: thread.cpp thread.hpp Makefile
    9         $(CXX) $(CXXFLAGS) -shared -o $@ $< -DWITH_PTHREADS
     8pthread.so: pthread.cpp Makefile
     9        $(CXX) $(CXXFLAGS) -shared -o ${@} ${<}
    1010
    11 libthrd-fibre.so: thread.cpp thread.hpp Makefile
    12         $(CXX) $(CXXFLAGS) -shared -o $@ $< -DWITH_LIBFIBRE -lfibre
     11fibre.so: fibre.cpp Makefile
     12        $(CXX) $(CXXFLAGS) -shared -o ${@} ${<} -lfibre
    1313
    1414CFAINC=${HOME}/local/include/cfa-dev
     
    1616CFAFLAGS=-z execstack -I${CFAINC} -I${CFAINC}/concurrency -L${CFALIB} -Wl,-rpath,${CFALIB}
    1717
    18 libthrd-cforall.so: thread.cpp thread.hpp Makefile
    19         $(CXX) $(CXXFLAGS) $(CFAFLAGS) -shared -o $@ $< -DWITH_CFORALL -Wl,--push-state,--no-as-needed -lcfathread -lcfa -ldl -lm -Wl,--pop-state
     18cforall.so: cforall.cpp Makefile
     19        $(CXX) $(CXXFLAGS) $(CFAFLAGS) -shared -o ${@} ${<} -lcfathread -lcfa -ldl -lm
  • doc/theses/thierry_delisle_PhD/code/readQ_example/thrdlib/pthread.hpp

    r54eb1bb3 rdd92fe9  
    1 #pragma once
    2 
    31#include <pthread.h>
    42#include <errno.h>
     
    9997        // Basic kernel features
    10098        void thrdlib_init( int ) {}
    101         void thrdlib_clean( void ) {}
    10299}
  • doc/theses/thierry_delisle_PhD/code/readQ_example/thrdlib/thread.cpp

    r54eb1bb3 rdd92fe9  
    1 #if !defined(WITH_PTHREADS) && !defined(WITH_LIBFIBRE) && !defined(WITH_CFORALL)
    2 #error must define WITH_PTHREADS, WITH_LIBFIBRE or WITH_CFORALL
    3 #endif
     1#include "thread.hpp"
    42
    5 #ifdef WITH_PTHREADS
    6 #include "pthread.hpp"
    7 #endif
    8 #ifdef WITH_LIBFIBRE
    9 #include "fibre.hpp"
    10 #endif
    11 #ifdef WITH_CFORALL
    12 #include "cforall.hpp"
    13 #endif
     3#include <cstdarg>                                                                              // va_start, va_end
     4#include <cstdio>
     5#include <cstring>                                                                              // strlen
     6extern "C" {
     7        #include <unistd.h>                                                                             // _exit, getpid
     8        #include <signal.h>
     9        #include <dlfcn.h>                                                                              // dlopen, dlsym
     10        #include <execinfo.h>                                                                   // backtrace, messages
     11}
    1412
    15 namespace thrdlib {
    16         //--------------------
    17         // Basic thread support
    18         void * create( void (*main)( void * ) ) { return (thread_t)thrdlib_create(  (void (*)( thread_t )) main ); }
    19         void join  ( void * handle ) { thrdlib_join  ((thread_t)handle); }
    20         void park  ( void * handle ) { thrdlib_park  ((thread_t)handle); }
    21         void unpark( void * handle ) { thrdlib_unpark((thread_t)handle); }
    22         void yield( void )  { thrdlib_yield(); }
     13#include <iostream>
     14#include <string>
    2315
    24         //--------------------
    25         // Basic kernel features
    26         void init( int procs ) { thrdlib_init(procs); }
    27         void clean( void ) { thrdlib_clean(); }
    28 };
     16using thrdlib::thread_t;
     17
     18thread_t (*thrdlib::create)( void (*main)( thread_t ) ) = nullptr;
     19void (*thrdlib::join)( thread_t handle ) = nullptr;
     20void (*thrdlib::park)( thread_t handle ) = nullptr;
     21void (*thrdlib::unpark)( thread_t handle ) = nullptr;
     22void (*thrdlib::yield)( void ) = nullptr;
     23void (*lib_clean)(void) = nullptr;
     24
     25typedef void (*fptr_t)();
     26static fptr_t open_symbol( void * library, const char * symbol, bool required ) {
     27        void * ptr = dlsym( library, symbol );
     28
     29        const char * error = dlerror();
     30        if ( required && error ) {
     31                std::cerr << "Fetching symbol '" << symbol << "' failed with error '" << error << "'\n";
     32                std::abort();
     33        }
     34
     35        return (fptr_t)ptr;
     36}
     37
     38//--------------------
     39// Basic kernel features
     40void thrdlib::init( const char * name, int procs ) {
     41        std::string file = __FILE__;
     42        std::size_t found = file.find_last_of("/");
     43        std::string libname = file.substr(0,found+1) + name + ".so";
     44
     45        std::cout << "Use framework " << name << "(" << libname << ")\n";
     46
     47        void * library = dlopen( libname.c_str(), RTLD_NOW );
     48        if ( const char * error = dlerror() ) {
     49                std::cerr << "Could not open library '" << libname << "' from name '" << name <<"'\n";
     50                std::cerr << "Error was : '" << error << "'\n";
     51                std::abort();
     52        }
     53
     54        void (*lib_init)( int ) = (void (*)( int ))open_symbol( library, "thrdlib_init", false );
     55        lib_clean = open_symbol( library, "thrdlib_clean" , false );
     56
     57        thrdlib::create = (typeof(thrdlib::create))open_symbol( library, "thrdlib_create", true  );
     58        thrdlib::join   = (typeof(thrdlib::join  ))open_symbol( library, "thrdlib_join"  , true  );
     59        thrdlib::park   = (typeof(thrdlib::park  ))open_symbol( library, "thrdlib_park"  , true  );
     60        thrdlib::unpark = (typeof(thrdlib::unpark))open_symbol( library, "thrdlib_unpark", true  );
     61        thrdlib::yield  = (typeof(thrdlib::yield ))open_symbol( library, "thrdlib_yield" , true  );
     62
     63        lib_init( procs );
     64}
     65
     66void thrdlib::clean( void ) {
     67        if(lib_clean) lib_clean();
     68}
  • doc/theses/thierry_delisle_PhD/code/readQ_example/thrdlib/thread.hpp

    r54eb1bb3 rdd92fe9  
    66        //--------------------
    77        // Basic thread support
    8         extern thread_t create( void (*main)( thread_t ) );
    9         extern void join( thread_t handle );
    10         extern void park( thread_t handle );
    11         extern void unpark( thread_t handle );
    12         extern void yield( void ) ;
     8        extern thread_t (*create)( void (*main)( thread_t ) );
     9        extern void (*join)( thread_t handle );
     10        extern void (*park)( thread_t handle );
     11        extern void (*unpark)( thread_t handle );
     12        extern void (*yield)( void ) ;
    1313
    1414        //--------------------
    1515        // Basic kernel features
    16         extern void init( int procs );
     16        extern void init( const char * name, int procs );
    1717        extern void clean( void );
    1818};
Note: See TracChangeset for help on using the changeset viewer.