Skip to content

Commit

Permalink
gccgo: suppress "ar rcD" and "-zdefs" on AIX
Browse files Browse the repository at this point in the history
    
    Reviewed-on: https://go-review.googlesource.com/100955


git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@259445 138bc75d-0d04-0410-961f-82ee72b054a4
  • Loading branch information
ian committed Apr 17, 2018
1 parent acf8e64 commit 94059ab
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 6 deletions.
2 changes: 1 addition & 1 deletion gcc/go/gofrontend/MERGE
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
3aa5fc91094c5f24b26747ec176ad44cde784fc7
2c7093358e5f5ebeb102d44d1036ca0a807d46a5

The first line of this file holds the git revision number of the last
merge done from the gofrontend repository.
13 changes: 8 additions & 5 deletions libgo/go/cmd/go/internal/work/gccgo.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,15 +190,15 @@ func (gccgoToolchain) pack(b *Builder, a *Action, afile string, ofiles []string)
}
absAfile := mkAbs(objdir, afile)
// Try with D modifier first, then without if that fails.
if b.run(a, p.Dir, p.ImportPath, nil, "ar", "rcD", absAfile, absOfiles) != nil {
if cfg.Goos == "aix" || b.run(a, p.Dir, p.ImportPath, nil, "ar", "rcD", absAfile, absOfiles) != nil {
var arArgs []string
if cfg.Goos == "aix" && cfg.Goarch == "ppc64" {
// AIX puts both 32-bit and 64-bit objects in the same archive.
// Tell the AIX "ar" command to only care about 64-bit objects.
// AIX "ar" command does not know D option.
return b.run(a, p.Dir, p.ImportPath, nil, "ar", "-X64", "rc", absAfile, absOfiles)
} else {
return b.run(a, p.Dir, p.ImportPath, nil, "ar", "rc", absAfile, absOfiles)
arArgs = append(arArgs, "-X64")
}
return b.run(a, p.Dir, p.ImportPath, nil, "ar", "rc", arArgs, absAfile, absOfiles)
}
return nil
}
Expand Down Expand Up @@ -466,7 +466,10 @@ func (tools gccgoToolchain) link(b *Builder, root *Action, out, importcfg string
ldflags = append(ldflags, goLibBegin...)
ldflags = append(ldflags, "-lgo", "-lgcc_s", "-lgcc", "-lc", "-lgcc")
case "shared":
ldflags = append(ldflags, "-zdefs", "-shared", "-nostdlib", "-lgo", "-lgcc_s", "-lgcc", "-lc")
if cfg.Goos != "aix" {
ldflags = append(ldflags, "-zdefs")
}
ldflags = append(ldflags, "-shared", "-nostdlib", "-lgo", "-lgcc_s", "-lgcc", "-lc")

case "pie":
ldflags = append(ldflags, "-pie")
Expand Down

0 comments on commit 94059ab

Please sign in to comment.