aboutsummaryrefslogtreecommitdiff
path: root/core/sys/linux
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2024-05-31 10:32:19 +0100
committerGitHub <noreply@github.com>2024-05-31 10:32:19 +0100
commitffded3d557eefd53a65292870ac171c4c02d361e (patch)
treeecd63e149c63a11fabed181a5d0cc3b00a3279ed /core/sys/linux
parentae63fd923039b6d3ab9a8abe0407827bf5fcd86d (diff)
parent0514ee0410826d00f71fd8ce188371cf7afab494 (diff)
Merge pull request #3655 from iErik/master
core:sys/linux - Add support for Unix Domain Socket addresses
Diffstat (limited to 'core/sys/linux')
-rw-r--r--core/sys/linux/sys.odin5
-rw-r--r--core/sys/linux/types.odin9
2 files changed, 14 insertions, 0 deletions
diff --git a/core/sys/linux/sys.odin b/core/sys/linux/sys.odin
index 413c8742b..171829cde 100644
--- a/core/sys/linux/sys.odin
+++ b/core/sys/linux/sys.odin
@@ -487,6 +487,7 @@ connect :: proc "contextless" (sock: Fd, addr: ^$T) -> (Errno)
where
T == Sock_Addr_In ||
T == Sock_Addr_In6 ||
+ T == Sock_Addr_Un ||
T == Sock_Addr_Any
{
ret := syscall(SYS_connect, sock, addr, size_of(T))
@@ -502,6 +503,7 @@ accept :: proc "contextless" (sock: Fd, addr: ^$T, sockflags: Socket_FD_Flags =
where
T == Sock_Addr_In ||
T == Sock_Addr_In6 ||
+ T == Sock_Addr_Un ||
T == Sock_Addr_Any
{
addr_len: i32 = size_of(T)
@@ -514,6 +516,7 @@ recvfrom :: proc "contextless" (sock: Fd, buf: []u8, flags: Socket_Msg, addr: ^$
where
T == Sock_Addr_In ||
T == Sock_Addr_In6 ||
+ T == Sock_Addr_Un ||
T == Sock_Addr_Any
{
addr_len: i32 = size_of(T)
@@ -531,6 +534,7 @@ sendto :: proc "contextless" (sock: Fd, buf: []u8, flags: Socket_Msg, addr: ^$T)
where
T == Sock_Addr_In ||
T == Sock_Addr_In6 ||
+ T == Sock_Addr_Un ||
T == Sock_Addr_Any
{
ret := syscall(SYS_sendto, sock, raw_data(buf), len(buf), transmute(i32) flags, addr, size_of(T))
@@ -590,6 +594,7 @@ bind :: proc "contextless" (sock: Fd, addr: ^$T) -> (Errno)
where
T == Sock_Addr_In ||
T == Sock_Addr_In6 ||
+ T == Sock_Addr_Un ||
T == Sock_Addr_Any
{
ret := syscall(SYS_bind, sock, addr, size_of(T))
diff --git a/core/sys/linux/types.odin b/core/sys/linux/types.odin
index 677bac7e0..5053e1e1c 100644
--- a/core/sys/linux/types.odin
+++ b/core/sys/linux/types.odin
@@ -632,6 +632,14 @@ Sock_Addr_In6 :: struct #packed {
}
/*
+ Struct representing Unix Domain Socket address
+*/
+Sock_Addr_Un :: struct #packed {
+ sun_family: Address_Family,
+ sun_path: [108]u8,
+}
+
+/*
Struct representing an arbitrary socket address.
*/
Sock_Addr_Any :: struct #raw_union {
@@ -641,6 +649,7 @@ Sock_Addr_Any :: struct #raw_union {
},
using ipv4: Sock_Addr_In,
using ipv6: Sock_Addr_In6,
+ using uds: Sock_Addr_Un,
}
/*