Changeset ab8c6a6 for src/Concurrency
- Timestamp:
- Oct 26, 2020, 12:17:28 PM (4 years ago)
- Branches:
- ADT, arm-eh, ast-experimental, enum, forall-pointer-decay, jacob/cs343-translation, master, new-ast-unique-expr, pthread-emulation, qualifiedEnum
- Children:
- 342be43
- Parents:
- 912cc7d7
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Concurrency/Keywords.cc
r912cc7d7 rab8c6a6 46 46 } 47 47 48 // Only detects threads constructed with the keyword thread. 49 inline static bool isThread( DeclarationWithType * decl ) { 50 Type * baseType = decl->get_type()->stripDeclarator(); 51 StructInstType * instType = dynamic_cast<StructInstType *>( baseType ); 52 if ( nullptr == instType ) { return false; } 53 return instType->baseStruct->is_thread(); 54 } 55 48 56 //============================================================================================= 49 57 // Pass declarations … … 119 127 "get_thread", 120 128 "thread keyword requires threads to be in scope, add #include <thread.hfa>\n", 121 " ",129 "ThreadCancelled", 122 130 true, 123 131 AggregateDecl::Thread … … 290 298 std::list<DeclarationWithType*> findMutexArgs( FunctionDecl*, bool & first ); 291 299 void validate( DeclarationWithType * ); 292 void addDtorStatments( FunctionDecl* func, CompoundStmt *, const std::list<DeclarationWithType * > &); 293 void addStatments( FunctionDecl* func, CompoundStmt *, const std::list<DeclarationWithType * > &); 300 void addDtorStatements( FunctionDecl* func, CompoundStmt *, const std::list<DeclarationWithType * > &); 301 void addStatements( FunctionDecl* func, CompoundStmt *, const std::list<DeclarationWithType * > &); 302 void addThreadDtorStatements( FunctionDecl* func, CompoundStmt * body, const std::list<DeclarationWithType * > & args ); 294 303 295 304 static void implement( std::list< Declaration * > & translationUnit ) { … … 302 311 StructDecl* guard_decl = nullptr; 303 312 StructDecl* dtor_guard_decl = nullptr; 313 StructDecl* thread_guard_decl = nullptr; 304 314 305 315 static std::unique_ptr< Type > generic_func; … … 801 811 bool first = false; 802 812 std::list<DeclarationWithType*> mutexArgs = findMutexArgs( decl, first ); 803 bool isDtor = CodeGen::isDestructor( decl->name );813 bool const isDtor = CodeGen::isDestructor( decl->name ); 804 814 805 815 // Is this function relevant to monitors … … 849 859 850 860 // Instrument the body 851 if( isDtor ) { 852 addDtorStatments( decl, body, mutexArgs ); 861 if ( isDtor && isThread( mutexArgs.front() ) ) { 862 if( !thread_guard_decl ) { 863 SemanticError( decl, "thread destructor requires threads to be in scope, add #include <thread.hfa>\n" ); 864 } 865 addThreadDtorStatements( decl, body, mutexArgs ); 866 } 867 else if ( isDtor ) { 868 addDtorStatements( decl, body, mutexArgs ); 853 869 } 854 870 else { 855 addStat ments( decl, body, mutexArgs );871 addStatements( decl, body, mutexArgs ); 856 872 } 857 873 } … … 870 886 assert( !dtor_guard_decl ); 871 887 dtor_guard_decl = decl; 888 } 889 else if( decl->name == "thread_dtor_guard_t" && decl->body ) { 890 assert( !thread_guard_decl ); 891 thread_guard_decl = decl; 872 892 } 873 893 } … … 908 928 } 909 929 910 void MutexKeyword::addDtorStat ments( FunctionDecl* func, CompoundStmt * body, const std::list<DeclarationWithType * > & args ) {930 void MutexKeyword::addDtorStatements( FunctionDecl* func, CompoundStmt * body, const std::list<DeclarationWithType * > & args ) { 911 931 Type * arg_type = args.front()->get_type()->clone(); 912 932 arg_type->set_mutex( false ); … … 957 977 958 978 //$monitor * __monitors[] = { get_monitor(a), get_monitor(b) }; 959 body->push_front( new DeclStmt( monitors) ); 960 } 961 962 void MutexKeyword::addStatments( FunctionDecl* func, CompoundStmt * body, const std::list<DeclarationWithType * > & args ) { 979 body->push_front( new DeclStmt( monitors ) ); 980 } 981 982 void MutexKeyword::addThreadDtorStatements( 983 FunctionDecl*, CompoundStmt * body, 984 const std::list<DeclarationWithType * > & args ) { 985 assert( args.size() == 1 ); 986 DeclarationWithType * arg = args.front(); 987 Type * arg_type = arg->get_type()->clone(); 988 assert( arg_type->get_mutex() ); 989 arg_type->set_mutex( false ); 990 991 // thread_dtor_guard_t __guard = { this, intptr( 0 ) }; 992 body->push_front( 993 new DeclStmt( new ObjectDecl( 994 "__guard", 995 noStorageClasses, 996 LinkageSpec::Cforall, 997 nullptr, 998 new StructInstType( 999 noQualifiers, 1000 thread_guard_decl 1001 ), 1002 new ListInit( 1003 { 1004 new SingleInit( new CastExpr( new VariableExpr( arg ), arg_type ) ), 1005 new SingleInit( new UntypedExpr( 1006 new NameExpr( "intptr" ), { 1007 new ConstantExpr( Constant::from_int( 0 ) ), 1008 } 1009 ) ), 1010 }, 1011 noDesignators, 1012 true 1013 ) 1014 )) 1015 ); 1016 } 1017 1018 void MutexKeyword::addStatements( FunctionDecl* func, CompoundStmt * body, const std::list<DeclarationWithType * > & args ) { 963 1019 ObjectDecl * monitors = new ObjectDecl( 964 1020 "__monitors",
Note: See TracChangeset
for help on using the changeset viewer.