1 // socket_solaris.go -- Socket handling specific to Solaris.
3 // Copyright 2010 The Go Authors. All rights reserved.
4 // Use of this source code is governed by a BSD-style
5 // license that can be found in the LICENSE file.
9 const SizeofSockaddrInet4 = 16
10 const SizeofSockaddrInet6 = 32
11 const SizeofSockaddrUnix = 110
13 type RawSockaddrInet4 struct {
16 Addr [4]byte /* in_addr */
20 func (sa *RawSockaddrInet4) setLen() Socklen_t {
21 return SizeofSockaddrInet4
24 type RawSockaddrInet6 struct {
28 Addr [16]byte /* in6_addr */
33 func (sa *RawSockaddrInet6) setLen() Socklen_t {
34 return SizeofSockaddrInet6
37 type RawSockaddrUnix struct {
42 func (sa *RawSockaddrUnix) setLen(int) {
45 func (sa *RawSockaddrUnix) getLen() (int, error) {
47 // "Abstract" Unix domain socket.
48 // Rewrite leading NUL as @ for textual display.
49 // (This is the standard convention.)
50 // Not friendly to overwrite in place,
51 // but the callers below don't care.
55 // Assume path ends at NUL.
56 // This is not technically the GNU/Linux semantics for
57 // abstract Unix domain sockets--they are supposed
58 // to be uninterpreted fixed-size binary blobs--but
59 // everyone uses this convention.
61 for n < len(sa.Path) - 3 && sa.Path[n] != 0 {
68 type RawSockaddr struct {
73 // BindToDevice binds the socket associated with fd to device.
74 func BindToDevice(fd int, device string) (err error) {
78 func anyToSockaddrOS(rsa *RawSockaddrAny) (Sockaddr, error) {
79 return nil, EAFNOSUPPORT