mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-08-03 16:30:29 +00:00
Eliminate some flakes
- Get ASAN working on Windows. - Deleting directories and then recreating them with the same name in a short period of time appears to be a no-no on Windows. - There's no reason to call FlushFileBuffers on close() for pipes, and it's harmful since it might block indefinitely for no good reason.
This commit is contained in:
parent
27c899af56
commit
4e56d89dcd
60 changed files with 588 additions and 751 deletions
|
@ -1323,15 +1323,20 @@ static textwindows noinline int epoll_create1$nt(uint32_t flags) {
|
|||
int64_t ephnd;
|
||||
struct PortState *port_state;
|
||||
struct TsTreeNode *tree_node;
|
||||
if ((fd = __getemptyfd()) == -1) return -1;
|
||||
if (wepoll_init() < 0) return -1;
|
||||
if ((fd = __reservefd()) == -1) return -1;
|
||||
port_state = port_new(&ephnd);
|
||||
if (!port_state) return -1;
|
||||
if (!port_state) {
|
||||
__releasefd(fd);
|
||||
return -1;
|
||||
}
|
||||
tree_node = port_state_to_handle_tree_node(port_state);
|
||||
if (ts_tree_add(&epoll__handle_tree, tree_node, (uintptr_t)ephnd) < 0) {
|
||||
/* This should never happen. */
|
||||
port_delete(port_state);
|
||||
RETURN_SET_ERROR(-1, kNtErrorAlreadyExists);
|
||||
err_set_win_error(kNtErrorAlreadyExists);
|
||||
__releasefd(fd);
|
||||
return -1;
|
||||
}
|
||||
g_fds.p[fd].kind = kFdEpoll;
|
||||
g_fds.p[fd].handle = ephnd;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue