- File:
-
- 1 edited
-
libcfa/src/concurrency/kernel/startup.cfa (modified) (6 diffs)
Legend:
- Unmodified
- Added
- Removed
-
libcfa/src/concurrency/kernel/startup.cfa
r5614a191 r09ae8a6 18 18 19 19 // C Includes 20 #include <errno.h> // errno20 #include <errno.h> // errno 21 21 #include <signal.h> 22 #include <string.h> // strerror23 #include <unistd.h> // sysconf22 #include <string.h> // strerror 23 #include <unistd.h> // sysconf 24 24 25 25 extern "C" { 26 #include <limits.h> // PTHREAD_STACK_MIN27 #include <unistd.h> // syscall28 #include <sys/eventfd.h> // eventfd29 #include <sys/mman.h> // mprotect30 #include <sys/resource.h> // getrlimit26 #include <limits.h> // PTHREAD_STACK_MIN 27 #include <unistd.h> // syscall 28 #include <sys/eventfd.h> // eventfd 29 #include <sys/mman.h> // mprotect 30 #include <sys/resource.h> // getrlimit 31 31 } 32 32 33 33 // CFA Includes 34 34 #include "kernel_private.hfa" 35 #include "startup.hfa" // STARTUP_PRIORITY_XXX35 #include "startup.hfa" // STARTUP_PRIORITY_XXX 36 36 #include "limits.hfa" 37 37 #include "math.hfa" … … 122 122 extern "C" { 123 123 struct { __dllist_t(cluster) list; __spinlock_t lock; } __cfa_dbg_global_clusters; 124 extern size_t __cfa_page_size; 125 extern int __map_prot; 126 } 124 } 125 126 extern size_t __page_size; 127 extern int __map_prot; 127 128 128 129 //----------------------------------------------------------------------------- … … 573 574 } 574 575 576 extern size_t __page_size; 575 577 void ^?{}(processor & this) with( this ){ 576 578 /* paranoid */ verify( !__atomic_load_n(&do_terminate, __ATOMIC_ACQUIRE) ); … … 734 736 check( pthread_attr_init( &attr ), "pthread_attr_init" ); // initialize attribute 735 737 736 size_t stacksize = DEFAULT_STACK_SIZE;738 size_t stacksize = max( PTHREAD_STACK_MIN, DEFAULT_STACK_SIZE ); 737 739 738 740 void * stack; 739 741 #if CFA_PROCESSOR_USE_MMAP 740 stacksize = ceiling( stacksize, __ cfa_page_size ) + __cfa_page_size;742 stacksize = ceiling( stacksize, __page_size ) + __page_size; 741 743 stack = mmap(0p, stacksize, __map_prot, MAP_PRIVATE | MAP_ANONYMOUS, 0, 0); 742 744 if(stack == ((void*)-1)) { 743 745 abort( "pthread stack creation : internal error, mmap failure, error(%d) %s.", errno, strerror( errno ) ); 744 746 } 745 if ( mprotect( stack, __ cfa_page_size, PROT_NONE ) == -1 ) {747 if ( mprotect( stack, __page_size, PROT_NONE ) == -1 ) { 746 748 abort( "pthread stack creation : internal error, mprotect failure, error(%d) %s.", errno, strerror( errno ) ); 747 749 } // if 748 750 #else 749 751 __cfaabi_dbg_debug_do( 750 stack = memalign( __ cfa_page_size, stacksize + __cfa_page_size );752 stack = memalign( __page_size, stacksize + __page_size ); 751 753 // pthread has no mechanism to create the guard page in user supplied stack. 752 if ( mprotect( stack, __ cfa_page_size, PROT_NONE ) == -1 ) {754 if ( mprotect( stack, __page_size, PROT_NONE ) == -1 ) { 753 755 abort( "mprotect : internal error, mprotect failure, error(%d) %s.", errno, strerror( errno ) ); 754 756 } // if … … 777 779 check( pthread_attr_getstacksize( &attr, &stacksize ), "pthread_attr_getstacksize" ); 778 780 assert( stacksize >= PTHREAD_STACK_MIN ); 779 stacksize += __ cfa_page_size;781 stacksize += __page_size; 780 782 781 783 if(munmap(stack, stacksize) == -1) { … … 785 787 __cfaabi_dbg_debug_do( 786 788 // pthread has no mechanism to create the guard page in user supplied stack. 787 if ( mprotect( stack, __ cfa_page_size, __map_prot ) == -1 ) {789 if ( mprotect( stack, __page_size, __map_prot ) == -1 ) { 788 790 abort( "mprotect : internal error, mprotect failure, error(%d) %s.", errno, strerror( errno ) ); 789 791 } // if
Note:
See TracChangeset
for help on using the changeset viewer.