sockopt_windows.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. // Copyright 2011 The Go Authors. All rights reserved.
  2. // Use of this source code is governed by a BSD-style
  3. // license that can be found in the LICENSE file.
  4. package net
  5. import (
  6. "os"
  7. "syscall"
  8. )
  9. func setDefaultSockopts(s syscall.Handle, family, sotype int, ipv6only bool) error {
  10. if family == syscall.AF_INET6 && sotype != syscall.SOCK_RAW {
  11. // Allow both IP versions even if the OS default
  12. // is otherwise. Note that some operating systems
  13. // never admit this option.
  14. syscall.SetsockoptInt(s, syscall.IPPROTO_IPV6, syscall.IPV6_V6ONLY, boolint(ipv6only))
  15. }
  16. // Allow broadcast.
  17. syscall.SetsockoptInt(s, syscall.SOL_SOCKET, syscall.SO_BROADCAST, 1)
  18. return nil
  19. }
  20. func setDefaultListenerSockopts(s syscall.Handle) error {
  21. // Windows will reuse recently-used addresses by default.
  22. // SO_REUSEADDR should not be used here, as it allows
  23. // a socket to forcibly bind to a port in use by another socket.
  24. // This could lead to a non-deterministic behavior, where
  25. // connection requests over the port cannot be guaranteed
  26. // to be handled by the correct socket.
  27. return nil
  28. }
  29. func setDefaultMulticastSockopts(s syscall.Handle) error {
  30. // Allow multicast UDP and raw IP datagram sockets to listen
  31. // concurrently across multiple listeners.
  32. return os.NewSyscallError("setsockopt", syscall.SetsockoptInt(s, syscall.SOL_SOCKET, syscall.SO_REUSEADDR, 1))
  33. }