Commit d1b90995 authored by Thomas Munro's avatar Thomas Munro

Remove latch.c workaround for Linux < 2.6.27.

Commit 82ebbeb0 added a workaround for systems with no epoll_create1()
and EPOLL_CLOEXEC.  Linux < 2.6.27 and glibc < 2.9 are long gone.  Now
seems like a good time to drop the extra code, because otherwise we'd
have to add similar already-dead workaround code to new patches using
XXX_CLOEXEC flags that arrived in the same kernel release.
Reviewed-by: default avatarTom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/CA%2BhUKGKL_%3DaO%3Dr30N%3Ds9VoDgTqHpRSzePRbA9dkYO7snc7HsxA%40mail.gmail.com
parent 943eb478
...@@ -666,31 +666,12 @@ CreateWaitEventSet(MemoryContext context, int nevents) ...@@ -666,31 +666,12 @@ CreateWaitEventSet(MemoryContext context, int nevents)
/* treat this as though epoll_create1 itself returned EMFILE */ /* treat this as though epoll_create1 itself returned EMFILE */
elog(ERROR, "epoll_create1 failed: %m"); elog(ERROR, "epoll_create1 failed: %m");
} }
#ifdef EPOLL_CLOEXEC
set->epoll_fd = epoll_create1(EPOLL_CLOEXEC); set->epoll_fd = epoll_create1(EPOLL_CLOEXEC);
if (set->epoll_fd < 0) if (set->epoll_fd < 0)
{ {
ReleaseExternalFD(); ReleaseExternalFD();
elog(ERROR, "epoll_create1 failed: %m"); elog(ERROR, "epoll_create1 failed: %m");
} }
#else
/* cope with ancient glibc lacking epoll_create1 (e.g., RHEL5) */
set->epoll_fd = epoll_create(nevents);
if (set->epoll_fd < 0)
{
ReleaseExternalFD();
elog(ERROR, "epoll_create failed: %m");
}
if (fcntl(set->epoll_fd, F_SETFD, FD_CLOEXEC) == -1)
{
int save_errno = errno;
close(set->epoll_fd);
ReleaseExternalFD();
errno = save_errno;
elog(ERROR, "fcntl(F_SETFD) failed on epoll descriptor: %m");
}
#endif /* EPOLL_CLOEXEC */
#elif defined(WAIT_USE_KQUEUE) #elif defined(WAIT_USE_KQUEUE)
if (!AcquireExternalFD()) if (!AcquireExternalFD())
{ {
...@@ -736,7 +717,7 @@ CreateWaitEventSet(MemoryContext context, int nevents) ...@@ -736,7 +717,7 @@ CreateWaitEventSet(MemoryContext context, int nevents)
* *
* Note: preferably, this shouldn't have to free any resources that could be * Note: preferably, this shouldn't have to free any resources that could be
* inherited across an exec(). If it did, we'd likely leak those resources in * inherited across an exec(). If it did, we'd likely leak those resources in
* many scenarios. For the epoll case, we ensure that by setting FD_CLOEXEC * many scenarios. For the epoll case, we ensure that by setting EPOLL_CLOEXEC
* when the FD is created. For the Windows case, we assume that the handles * when the FD is created. For the Windows case, we assume that the handles
* involved are non-inheritable. * involved are non-inheritable.
*/ */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment