aboutsummaryrefslogtreecommitdiff
path: root/core/sys/linux
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-05-31 16:35:38 +0100
committergingerBill <bill@gingerbill.org>2024-05-31 16:35:38 +0100
commit5628cfabe59feef67cffcd08ee4eb4a74bffda2c (patch)
tree80f7a9074811e258e904edcb58c0fadbeed9ddd6 /core/sys/linux
parent31a9b3f4282334329540b7e75bf6e5ec3dae6030 (diff)
parente12ff63b16dfa871123ad63d1ec1ce69f7063473 (diff)
Merge branch 'master' of https://github.com/odin-lang/Odin
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,
}
/*