mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-11 01:06:01 +03:00
5387a19268
This encourages callers to strongly reference file descriptions while working with them. This fixes a use-after-free issue where one thread would close() an open fd while another thread was blocked on it becoming readable. Test: Kernel/uaf-close-while-blocked-in-read.cpp
31 lines
669 B
C++
31 lines
669 B
C++
#include <pthread.h>
|
|
#include <stdio.h>
|
|
#include <string.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("Second thread closing pipes!\n");
|
|
close(pipefds[0]);
|
|
close(pipefds[1]);
|
|
pthread_exit(nullptr);
|
|
return nullptr;
|
|
},
|
|
nullptr);
|
|
|
|
printf("First thread doing a blocking read from pipe...\n");
|
|
char buffer[16];
|
|
int nread = read(pipefds[0], buffer, sizeof(buffer));
|
|
printf("Ok, read %d bytes from pipe\n", nread);
|
|
|
|
return 0;
|
|
}
|