mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 10:40:57 +00:00 
			
		
		
		
	Always initialize thread local storage
We had previously not enabled TLS in MODE=tiny in order to keep the smallest example programs (e.g. life.com) just 16kb in size. But it was error prone doing that, so now we just always enable it because this change uses hacks to ensure it won't increase life.com's size. This change also fixes a bug on NetBSD, where signal handlers would break thread local storage if SA_SIGINFO was being used. This looks like it might be a bug in NetBSD, but it's got a simple workaround.
This commit is contained in:
		
							parent
							
								
									057e8f5b54
								
							
						
					
					
						commit
						69f4152f38
					
				
					 33 changed files with 174 additions and 123 deletions
				
			
		|  | @ -114,6 +114,12 @@ TEST(malloc, test) { | |||
|   for (i = 0; i < ARRAYLEN(fds); ++i) close(fds[i]); | ||||
| } | ||||
| 
 | ||||
| TEST(memalign, roundsUpAlignmentToTwoPower) { | ||||
|   char *volatile p = memalign(129, 1); | ||||
|   ASSERT_EQ(0, (intptr_t)p & 255); | ||||
|   free(p); | ||||
| } | ||||
| 
 | ||||
| void *bulk[1024]; | ||||
| 
 | ||||
| void BulkFreeBenchSetup(void) { | ||||
|  |  | |||
|  | @ -19,9 +19,11 @@ | |||
| #include "libc/bits/segmentation.h" | ||||
| #include "libc/calls/calls.h" | ||||
| #include "libc/dce.h" | ||||
| #include "libc/nexgen32e/threaded.h" | ||||
| #include "libc/testlib/testlib.h" | ||||
| 
 | ||||
| __attribute__((__constructor__)) static void init(void) { | ||||
|   __tls_enabled = false; | ||||
|   pledge("stdio rpath", 0); | ||||
|   errno = 0; | ||||
| } | ||||
|  |  | |||
|  | @ -24,6 +24,7 @@ | |||
| #include "libc/intrin/kprintf.h" | ||||
| #include "libc/runtime/memtrack.internal.h" | ||||
| #include "libc/runtime/runtime.h" | ||||
| #include "libc/str/str.h" | ||||
| #include "libc/sysv/consts/map.h" | ||||
| #include "libc/sysv/consts/o.h" | ||||
| #include "libc/sysv/consts/prot.h" | ||||
|  | @ -66,6 +67,12 @@ TEST(munmap, doesntExist_doesntCare) { | |||
|   } | ||||
| } | ||||
| 
 | ||||
| TEST(munmap, invalidParams) { | ||||
|   EXPECT_SYS(EINVAL, -1, munmap(0, 0)); | ||||
|   EXPECT_SYS(EINVAL, -1, munmap((void *)0x100080000000, 0)); | ||||
|   EXPECT_SYS(EINVAL, -1, munmap((void *)0x100080000001, FRAMESIZE)); | ||||
| } | ||||
| 
 | ||||
| TEST(munmap, test) { | ||||
|   char *p; | ||||
|   ASSERT_NE(MAP_FAILED, (p = mmap(0, FRAMESIZE, PROT_READ | PROT_WRITE, | ||||
|  | @ -75,12 +82,6 @@ TEST(munmap, test) { | |||
|   EXPECT_FALSE(MemoryExists(p)); | ||||
| } | ||||
| 
 | ||||
| TEST(munmap, invalidParams) { | ||||
|   EXPECT_SYS(EINVAL, -1, munmap(0, 0)); | ||||
|   EXPECT_SYS(EINVAL, -1, munmap((void *)0x100080000000, 0)); | ||||
|   EXPECT_SYS(EINVAL, -1, munmap((void *)0x100080000001, FRAMESIZE)); | ||||
| } | ||||
| 
 | ||||
| TEST(munmap, punchHoleInMemory) { | ||||
|   char *p; | ||||
|   ASSERT_NE(MAP_FAILED, (p = mmap(0, FRAMESIZE * 3, PROT_READ | PROT_WRITE, | ||||
|  |  | |||
|  | @ -64,7 +64,6 @@ TEST(fgetc, testUnbuffered) { | |||
| } | ||||
| 
 | ||||
| BENCH(fputc, bench) { | ||||
|   __enable_tls(); | ||||
|   __enable_threads(); | ||||
|   FILE *f; | ||||
|   ASSERT_NE(NULL, (f = fopen("/dev/null", "w"))); | ||||
|  |  | |||
|  | @ -38,9 +38,3 @@ TEST(pthread_key_create, testRunsDtors_becauseNoLeakReport) { | |||
|   EXPECT_EQ(0, pthread_setspecific(key, x)); | ||||
|   EXPECT_EQ(x, pthread_getspecific(key)); | ||||
| } | ||||
| 
 | ||||
| __attribute__((__constructor__)) static void init(void) { | ||||
|   if (IsTiny()) { | ||||
|     __enable_tls(); | ||||
|   } | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue