zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 1f79a9e4e300affd111b51ec172bbeff42ca755a (tree)
parent 0d25302d43557d89b868b8925b2e98395d1ebe60
Author: GasInfinity <me@gasinfinity.dev>
Date:   Tue, 24 Mar 2026 09:27:06 +0100

feat(Io.net): add `allow_broadcast` to `BindOptions`

* and implement it in `Threaded`, `Uring` and `Kqueue`

Diffstat:
Mlib/std/Io/Kqueue.zig | 1+
Mlib/std/Io/Threaded.zig | 2++
Mlib/std/Io/Uring.zig | 1+
Mlib/std/Io/net.zig | 4++++
4 files changed, 8 insertions(+), 0 deletions(-)

diff --git a/lib/std/Io/Kqueue.zig b/lib/std/Io/Kqueue.zig @@ -1029,6 +1029,7 @@ fn netBindIp( var storage: Io.Threaded.PosixAddress = undefined; var addr_len = Io.Threaded.addressToPosix(address, &storage); try posixBind(k, socket_fd, &storage.any, addr_len); + if (options.allow_broadcast) try setSocketOption(k, socket_fd, posix.SOL.SOCKET, posix.SO.BROADCAST, 1); try posixGetSockName(k, socket_fd, &storage.any, &addr_len); return .{ .handle = socket_fd, .address = Io.Threaded.addressFromPosix(&storage) }; } diff --git a/lib/std/Io/Threaded.zig b/lib/std/Io/Threaded.zig @@ -12196,6 +12196,7 @@ fn netBindIpPosix( var storage: PosixAddress = undefined; var addr_len = addressToPosix(address, &storage); try posixBind(socket_fd, &storage.any, addr_len); + if (options.allow_broadcast) try setSocketOptionPosix(socket_fd, std.posix.SOL.SOCKET, std.posix.SO.BROADCAST, 1); try posixGetSockName(socket_fd, &storage.any, &addr_len); return .{ .handle = socket_fd, .address = addressFromPosix(&storage) }; } @@ -12212,6 +12213,7 @@ fn netBindIpWindows( const socket_handle = try openSocketAfd(family, options); errdefer windows.CloseHandle(socket_handle); const bound_address = try bindSocketIpAfd(socket_handle, address, .Active); + if (options.allow_broadcast) try setSocketOptionAfd(socket_handle, ws2_32.SOL.SOCKET, ws2_32.SO.BROADCAST, true); return .{ .handle = socket_handle, .address = bound_address }; } diff --git a/lib/std/Io/Uring.zig b/lib/std/Io/Uring.zig @@ -4991,6 +4991,7 @@ fn netBindIp( var storage: PosixAddress = undefined; var addr_len = addressToPosix(address, &storage); try ev.bind(&maybe_sync.cancel_region, socket_fd, &storage.any, addr_len); + if (options.allow_broadcast) try ev.setsockopt(&maybe_sync.cancel_region, socket_fd, linux.SOL.SOCKET, linux.SO.BROADCAST, 1); try ev.getsockname(try maybe_sync.enterSync(ev), socket_fd, &storage.any, &addr_len); return .{ .handle = socket_fd, .address = addressFromPosix(&storage) }; } diff --git a/lib/std/Io/net.zig b/lib/std/Io/net.zig @@ -282,6 +282,10 @@ pub const IpAddress = union(enum) { /// In this case, an IPv4 and an IPv6 application can bind to a single port /// at the same time. ip6_only: bool = false, + /// Allow the socket to send datagrams to broadcast addresses. + /// When not enabled any attempt to send datagrams to a broadcast address + /// will fail with `error.AccessDenied` + allow_broadcast: bool = false, mode: Socket.Mode, protocol: ?Protocol = null, };