mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-06-27 14:58:30 +00:00
Perform fine-tuning of socketpair and pipe
- removed unneeded share parameter from pipe on nt - socktpair(type | SOCK_CLOEXEC) is now polyfilled - use textwindows for linker micro-optimization - apologies for auto clang-format diff noise :( - improve socketpair docstring See #122
This commit is contained in:
parent
4e93750afd
commit
4177489762
11 changed files with 172 additions and 133 deletions
|
@ -16,96 +16,77 @@
|
|||
│ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │
|
||||
│ PERFORMANCE OF THIS SOFTWARE. │
|
||||
╚─────────────────────────────────────────────────────────────────────────────*/
|
||||
#include "libc/calls/internal.h"
|
||||
#include "libc/errno.h"
|
||||
#include "libc/mem/mem.h"
|
||||
#include "libc/sock/internal.h"
|
||||
#include "libc/sock/yoink.inc"
|
||||
#include "libc/sysv/consts/fio.h"
|
||||
#include "libc/sysv/consts/o.h"
|
||||
#include "libc/sysv/consts/sock.h"
|
||||
#include "libc/sysv/consts/af.h"
|
||||
|
||||
#include "libc/alg/reverse.internal.h"
|
||||
#include "libc/nt/createfile.h"
|
||||
#include "libc/nt/enum/accessmask.h"
|
||||
#include "libc/nt/enum/creationdisposition.h"
|
||||
#include "libc/nt/enum/filesharemode.h"
|
||||
#include "libc/nt/ipc.h"
|
||||
#include "libc/nt/process.h"
|
||||
#include "libc/nt/runtime.h"
|
||||
|
||||
#include "libc/sock/internal.h"
|
||||
#include "libc/sysv/consts/af.h"
|
||||
#include "libc/sysv/consts/o.h"
|
||||
#include "libc/sysv/consts/sock.h"
|
||||
#include "libc/sysv/errfuns.h"
|
||||
|
||||
// {{{ sys_socketpair_nt
|
||||
int sys_socketpair_nt(int family, int type, int proto, int sv[2]) {
|
||||
int64_t hpipe, h1, h2;
|
||||
int reader, writer;
|
||||
char16_t pipename[64];
|
||||
uint32_t mode;
|
||||
textwindows int sys_socketpair_nt(int family, int type, int proto, int sv[2]) {
|
||||
int64_t hpipe, h1, h2;
|
||||
int reader, writer, oflags;
|
||||
char16_t pipename[64];
|
||||
uint32_t mode;
|
||||
|
||||
// Supports only AF_UNIX
|
||||
if (family != AF_UNIX) {
|
||||
errno = EAFNOSUPPORT;
|
||||
return -1;
|
||||
}
|
||||
// Supports only AF_UNIX
|
||||
if (family != AF_UNIX) {
|
||||
return eafnosupport();
|
||||
}
|
||||
|
||||
mode = kNtPipeWait;
|
||||
if (type == SOCK_STREAM) {
|
||||
mode |= kNtPipeReadmodeByte | kNtPipeTypeByte;
|
||||
} else if ((type == SOCK_DGRAM) || (type == SOCK_SEQPACKET)) {
|
||||
mode |= kNtPipeReadmodeMessage | kNtPipeTypeMessage;
|
||||
} else {
|
||||
errno = EOPNOTSUPP;
|
||||
return -1;
|
||||
}
|
||||
oflags = 0;
|
||||
if (type & SOCK_CLOEXEC) oflags |= O_CLOEXEC;
|
||||
type &= ~SOCK_CLOEXEC;
|
||||
|
||||
CreatePipeName(pipename);
|
||||
if ((reader = __reservefd()) == -1) return -1;
|
||||
if ((writer = __reservefd()) == -1) {
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
if ((hpipe = CreateNamedPipe(pipename,
|
||||
kNtPipeAccessDuplex,
|
||||
mode,
|
||||
1,
|
||||
65536,
|
||||
65536,
|
||||
0,
|
||||
&kNtIsInheritable)) == -1) {
|
||||
__winerr();
|
||||
__releasefd(writer);
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
mode = kNtPipeWait;
|
||||
if (type == SOCK_STREAM) {
|
||||
mode |= kNtPipeReadmodeByte | kNtPipeTypeByte;
|
||||
} else if ((type == SOCK_DGRAM) || (type == SOCK_SEQPACKET)) {
|
||||
mode |= kNtPipeReadmodeMessage | kNtPipeTypeMessage;
|
||||
} else {
|
||||
return eopnotsupp();
|
||||
}
|
||||
|
||||
h1 = CreateFile(pipename,
|
||||
kNtGenericWrite | kNtGenericRead,
|
||||
0, // Not shared
|
||||
&kNtIsInheritable,
|
||||
kNtOpenExisting, 0, 0);
|
||||
if (h1 == -1) {
|
||||
CloseHandle(hpipe);
|
||||
__winerr();
|
||||
__releasefd(writer);
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
CreatePipeName(pipename);
|
||||
if ((reader = __reservefd()) == -1) return -1;
|
||||
if ((writer = __reservefd()) == -1) {
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
if ((hpipe = CreateNamedPipe(pipename, kNtPipeAccessDuplex, mode, 1, 65536,
|
||||
65536, 0, &kNtIsInheritable)) == -1) {
|
||||
__winerr();
|
||||
__releasefd(writer);
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
|
||||
g_fds.p[reader].kind = kFdFile;
|
||||
g_fds.p[reader].flags = 0; // TODO
|
||||
g_fds.p[reader].handle = hpipe;
|
||||
h1 = CreateFile(pipename, kNtGenericWrite | kNtGenericRead,
|
||||
0, // Not shared
|
||||
&kNtIsInheritable, kNtOpenExisting, 0, 0);
|
||||
if (h1 == -1) {
|
||||
CloseHandle(hpipe);
|
||||
__winerr();
|
||||
__releasefd(writer);
|
||||
__releasefd(reader);
|
||||
return -1;
|
||||
}
|
||||
|
||||
g_fds.p[writer].kind = kFdFile;
|
||||
g_fds.p[writer].flags = 0; // TODO
|
||||
g_fds.p[writer].handle = h1;
|
||||
g_fds.p[reader].kind = kFdFile;
|
||||
g_fds.p[reader].flags = oflags;
|
||||
g_fds.p[reader].handle = hpipe;
|
||||
|
||||
sv[0] = reader;
|
||||
sv[1] = writer;
|
||||
return 0;
|
||||
g_fds.p[writer].kind = kFdFile;
|
||||
g_fds.p[writer].flags = oflags;
|
||||
g_fds.p[writer].handle = h1;
|
||||
|
||||
sv[0] = reader;
|
||||
sv[1] = writer;
|
||||
return 0;
|
||||
}
|
||||
// }}}
|
||||
|
||||
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue