// Copyright 2013 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

// This file implements sysSocket for platforms that provide a fast path for
// setting SetNonblock and CloseOnExec.

//go:build dragonfly || freebsd || linux || netbsd || openbsd || solaris

package net

import (
	
	
	
)

// Wrapper around the socket system call that marks the returned file
// descriptor as nonblocking and close-on-exec.
func sysSocket(, ,  int) (int, error) {
	,  := socketFunc(, |syscall.SOCK_NONBLOCK|syscall.SOCK_CLOEXEC, )
	// TODO: We can remove the fallback on Linux and *BSD,
	// as currently supported versions all support accept4
	// with SOCK_CLOEXEC, but Solaris does not. See issue #59359.
	switch  {
	case nil:
		return , nil
	default:
		return -1, os.NewSyscallError("socket", )
	case syscall.EPROTONOSUPPORT, syscall.EINVAL:
	}

	// See ../syscall/exec_unix.go for description of ForkLock.
	syscall.ForkLock.RLock()
	,  = socketFunc(, , )
	if  == nil {
		syscall.CloseOnExec()
	}
	syscall.ForkLock.RUnlock()
	if  != nil {
		return -1, os.NewSyscallError("socket", )
	}
	if  = syscall.SetNonblock(, true);  != nil {
		poll.CloseFunc()
		return -1, os.NewSyscallError("setnonblock", )
	}
	return , nil
}