mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 10:42:45 +00:00 
			
		
		
		
	 76c20642f0
			
		
	
	
		76c20642f0
		
	
	
	
	
		
			
			This fixes a null RefPtr deref (which asserts) in the scheduler if a file descriptor being select()'ed is closed by a second thread while blocked in select(). Test: Kernel/null-deref-close-during-select.cpp
		
			
				
	
	
		
			36 lines
		
	
	
	
		
			687 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			687 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <pthread.h>
 | |
| #include <stdio.h>
 | |
| #include <sys/select.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| int pipefds[2];
 | |
| 
 | |
| int main(int, char**)
 | |
| {
 | |
|     pipe(pipefds);
 | |
| 
 | |
|     pthread_t tid;
 | |
|     pthread_create(
 | |
|         &tid, nullptr, [](void*) -> void* {
 | |
|             sleep(1);
 | |
|             printf("ST: close()\n");
 | |
|             close(pipefds[1]);
 | |
|             pthread_exit(nullptr);
 | |
|             return nullptr;
 | |
|         },
 | |
|         nullptr);
 | |
| 
 | |
|     fd_set rfds;
 | |
|     FD_ZERO(&rfds);
 | |
|     FD_SET(pipefds[1], &rfds);
 | |
| 
 | |
|     printf("MT: select()\n");
 | |
|     int rc = select(pipefds[1] + 1, &rfds, nullptr, nullptr, nullptr);
 | |
|     if (rc < 0) {
 | |
|         perror("select");
 | |
|         return 1;
 | |
|     }
 | |
| 
 | |
|     printf("ok\n");
 | |
|     return 0;
 | |
| }
 |