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:
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,
};