mirror of
https://github.com/golang/go
synced 2024-11-17 03:04:44 -07:00
cmd/dist: add AIX operating system.
This commit adds AIX operating system to cmd/dist package for ppc64 architecture. The stack guard is increased because of syscalls made inside the runtime which need a larger stack. Disable cmd/vet/all tests until aix/ppc64 is fully available. Change-Id: I7e3caf86724249ae564a152d90c1cbd4de288814 Reviewed-on: https://go-review.googlesource.com/c/138715 Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
8919fe9e4d
commit
a3a69afff8
2
src/cmd/dist/build.go
vendored
2
src/cmd/dist/build.go
vendored
@ -87,6 +87,7 @@ var okgoos = []string{
|
||||
"openbsd",
|
||||
"plan9",
|
||||
"windows",
|
||||
"aix",
|
||||
}
|
||||
|
||||
// find reports the first index of p in l[0:n], or else -1.
|
||||
@ -1388,6 +1389,7 @@ func checkNotStale(goBinary string, targets ...string) {
|
||||
// single point of truth for supported platforms. This list is used
|
||||
// by 'go tool dist list'.
|
||||
var cgoEnabled = map[string]bool{
|
||||
"aix/ppc64": false,
|
||||
"darwin/386": true,
|
||||
"darwin/amd64": true,
|
||||
"darwin/arm": true,
|
||||
|
4
src/cmd/dist/buildruntime.go
vendored
4
src/cmd/dist/buildruntime.go
vendored
@ -87,6 +87,10 @@ func mkzbootstrap(file string) {
|
||||
// stack guard size. Larger multipliers are used for non-optimized
|
||||
// builds that have larger stack frames.
|
||||
func stackGuardMultiplier() int {
|
||||
// On AIX, a larger stack is needed for syscalls
|
||||
if goos == "aix" {
|
||||
return 2
|
||||
}
|
||||
for _, s := range strings.Split(os.Getenv("GO_GCFLAGS"), " ") {
|
||||
if s == "-N" {
|
||||
return 2
|
||||
|
3
src/cmd/dist/main.go
vendored
3
src/cmd/dist/main.go
vendored
@ -81,6 +81,9 @@ func main() {
|
||||
}
|
||||
case "windows":
|
||||
exe = ".exe"
|
||||
case "aix":
|
||||
// uname -m doesn't work under AIX
|
||||
gohostarch = "ppc64"
|
||||
}
|
||||
|
||||
sysinit()
|
||||
|
@ -48,10 +48,13 @@ const (
|
||||
Hplan9
|
||||
Hsolaris
|
||||
Hwindows
|
||||
Haix
|
||||
)
|
||||
|
||||
func (h *HeadType) Set(s string) error {
|
||||
switch s {
|
||||
case "aix":
|
||||
*h = Haix
|
||||
case "darwin":
|
||||
*h = Hdarwin
|
||||
case "dragonfly":
|
||||
@ -82,6 +85,8 @@ func (h *HeadType) Set(s string) error {
|
||||
|
||||
func (h *HeadType) String() string {
|
||||
switch *h {
|
||||
case Haix:
|
||||
return "aix"
|
||||
case Hdarwin:
|
||||
return "darwin"
|
||||
case Hdragonfly:
|
||||
|
@ -204,6 +204,12 @@ func (p platform) vet() {
|
||||
return
|
||||
}
|
||||
|
||||
if p.os == "aix" && p.arch == "ppc64" {
|
||||
// TODO(aix): enable as soon as the aix/ppc64 port has fully landed
|
||||
fmt.Println("skipping aix/ppc64")
|
||||
return
|
||||
}
|
||||
|
||||
var buf bytes.Buffer
|
||||
fmt.Fprintf(&buf, "go run main.go -p %s\n", p)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user