mirror of
https://github.com/golang/go
synced 2024-11-25 00:57:59 -07:00
net: fix EAI_BADFLAGS error on freebsd
R=rsc CC=golang-dev https://golang.org/cl/4442072
This commit is contained in:
parent
1f59004511
commit
338b7abdfc
@ -31,6 +31,7 @@ GOFILES_freebsd=\
|
|||||||
port.go\
|
port.go\
|
||||||
|
|
||||||
CGOFILES_freebsd=\
|
CGOFILES_freebsd=\
|
||||||
|
cgo_bsd.go\
|
||||||
cgo_unix.go\
|
cgo_unix.go\
|
||||||
|
|
||||||
GOFILES_darwin=\
|
GOFILES_darwin=\
|
||||||
@ -42,6 +43,7 @@ GOFILES_darwin=\
|
|||||||
port.go\
|
port.go\
|
||||||
|
|
||||||
CGOFILES_darwin=\
|
CGOFILES_darwin=\
|
||||||
|
cgo_bsd.go\
|
||||||
cgo_unix.go\
|
cgo_unix.go\
|
||||||
|
|
||||||
GOFILES_linux=\
|
GOFILES_linux=\
|
||||||
@ -57,6 +59,7 @@ ifeq ($(GOARCH),arm)
|
|||||||
GOFILES_linux+=cgo_stub.go
|
GOFILES_linux+=cgo_stub.go
|
||||||
else
|
else
|
||||||
CGOFILES_linux=\
|
CGOFILES_linux=\
|
||||||
|
cgo_linux.go\
|
||||||
cgo_unix.go
|
cgo_unix.go
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
14
src/pkg/net/cgo_bsd.go
Normal file
14
src/pkg/net/cgo_bsd.go
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
// Copyright 2011 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.
|
||||||
|
|
||||||
|
package net
|
||||||
|
|
||||||
|
/*
|
||||||
|
#include <netdb.h>
|
||||||
|
*/
|
||||||
|
import "C"
|
||||||
|
|
||||||
|
func cgoAddrInfoMask() C.int {
|
||||||
|
return C.AI_MASK
|
||||||
|
}
|
14
src/pkg/net/cgo_linux.go
Normal file
14
src/pkg/net/cgo_linux.go
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
// Copyright 2011 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.
|
||||||
|
|
||||||
|
package net
|
||||||
|
|
||||||
|
/*
|
||||||
|
#include <netdb.h>
|
||||||
|
*/
|
||||||
|
import "C"
|
||||||
|
|
||||||
|
func cgoAddrInfoMask() C.int {
|
||||||
|
return C.AI_CANONNAME | C.AI_V4MAPPED | C.AI_ALL
|
||||||
|
}
|
@ -86,7 +86,7 @@ func cgoLookupIPCNAME(name string) (addrs []IP, cname string, err os.Error, comp
|
|||||||
// and similarly for IPv6), but in practice setting it causes
|
// and similarly for IPv6), but in practice setting it causes
|
||||||
// getaddrinfo to return the wrong canonical name on Linux.
|
// getaddrinfo to return the wrong canonical name on Linux.
|
||||||
// So definitely leave it out.
|
// So definitely leave it out.
|
||||||
hints.ai_flags = C.AI_ALL | C.AI_V4MAPPED | C.AI_CANONNAME
|
hints.ai_flags = (C.AI_ALL | C.AI_V4MAPPED | C.AI_CANONNAME) & cgoAddrInfoMask()
|
||||||
|
|
||||||
h := C.CString(name)
|
h := C.CString(name)
|
||||||
defer C.free(unsafe.Pointer(h))
|
defer C.free(unsafe.Pointer(h))
|
||||||
|
Loading…
Reference in New Issue
Block a user