Commit 0a033a18 authored by Dave Day's avatar Dave Day

cmd/gc: support -installsuffix in the compiler and builder

Add the -installsuffix flag to gc and {5,6,8}l, which overrides -race
for the suffix if both are supplied.
Pass this flag from the go tool for build and install.

R=rsc
CC=golang-dev
https://golang.org/cl/14246044
parent 45b830ed
...@@ -117,6 +117,7 @@ main(int argc, char *argv[]) ...@@ -117,6 +117,7 @@ main(int argc, char *argv[])
flagstr("extldflags", "flags for external linker", &extldflags); flagstr("extldflags", "flags for external linker", &extldflags);
flagcount("f", "ignore version mismatch", &debug['f']); flagcount("f", "ignore version mismatch", &debug['f']);
flagcount("g", "disable go package data checks", &debug['g']); flagcount("g", "disable go package data checks", &debug['g']);
flagstr("installsuffix", "pkg directory suffix", &flag_installsuffix);
flagstr("k", "sym: set field tracking symbol", &tracksym); flagstr("k", "sym: set field tracking symbol", &tracksym);
flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode); flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode);
flagcount("n", "dump symbol table", &debug['n']); flagcount("n", "dump symbol table", &debug['n']);
......
...@@ -112,6 +112,7 @@ main(int argc, char *argv[]) ...@@ -112,6 +112,7 @@ main(int argc, char *argv[])
flagstr("extldflags", "flags for external linker", &extldflags); flagstr("extldflags", "flags for external linker", &extldflags);
flagcount("f", "ignore version mismatch", &debug['f']); flagcount("f", "ignore version mismatch", &debug['f']);
flagcount("g", "disable go package data checks", &debug['g']); flagcount("g", "disable go package data checks", &debug['g']);
flagstr("installsuffix", "pkg directory suffix", &flag_installsuffix);
flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode); flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode);
flagstr("k", "sym: set field tracking symbol", &tracksym); flagstr("k", "sym: set field tracking symbol", &tracksym);
flagcount("n", "dump symbol table", &debug['n']); flagcount("n", "dump symbol table", &debug['n']);
......
...@@ -118,6 +118,7 @@ main(int argc, char *argv[]) ...@@ -118,6 +118,7 @@ main(int argc, char *argv[])
flagstr("extldflags", "flags for external linker", &extldflags); flagstr("extldflags", "flags for external linker", &extldflags);
flagcount("f", "ignore version mismatch", &debug['f']); flagcount("f", "ignore version mismatch", &debug['f']);
flagcount("g", "disable go package data checks", &debug['g']); flagcount("g", "disable go package data checks", &debug['g']);
flagstr("installsuffix", "pkg directory suffix", &flag_installsuffix);
flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode); flagfn1("linkmode", "mode: set link mode (internal, external, auto)", setlinkmode);
flagstr("k", "sym: set field tracking symbol", &tracksym); flagstr("k", "sym: set field tracking symbol", &tracksym);
flagstr("o", "outfile: set output file", &outfile); flagstr("o", "outfile: set output file", &outfile);
......
...@@ -976,6 +976,7 @@ EXTERN int typecheckok; ...@@ -976,6 +976,7 @@ EXTERN int typecheckok;
EXTERN int compiling_runtime; EXTERN int compiling_runtime;
EXTERN int compiling_wrappers; EXTERN int compiling_wrappers;
EXTERN int pure_go; EXTERN int pure_go;
EXTERN char* flag_installsuffix;
EXTERN int flag_race; EXTERN int flag_race;
EXTERN int flag_largemodel; EXTERN int flag_largemodel;
EXTERN int noescape; EXTERN int noescape;
......
...@@ -257,6 +257,7 @@ main(int argc, char *argv[]) ...@@ -257,6 +257,7 @@ main(int argc, char *argv[])
flagcount("g", "debug code generation", &debug['g']); flagcount("g", "debug code generation", &debug['g']);
flagcount("h", "halt on error", &debug['h']); flagcount("h", "halt on error", &debug['h']);
flagcount("i", "debug line number stack", &debug['i']); flagcount("i", "debug line number stack", &debug['i']);
flagstr("installsuffix", "pkg directory suffix", &flag_installsuffix);
flagcount("j", "debug runtime-initialized variables", &debug['j']); flagcount("j", "debug runtime-initialized variables", &debug['j']);
flagcount("l", "disable inlining", &debug['l']); flagcount("l", "disable inlining", &debug['l']);
flagcount("m", "print optimization decisions", &debug['m']); flagcount("m", "print optimization decisions", &debug['m']);
...@@ -577,7 +578,7 @@ static int ...@@ -577,7 +578,7 @@ static int
findpkg(Strlit *name) findpkg(Strlit *name)
{ {
Idir *p; Idir *p;
char *q, *race; char *q, *suffix, *suffixsep;
if(islocalname(name)) { if(islocalname(name)) {
if(safemode) if(safemode)
...@@ -615,13 +616,19 @@ findpkg(Strlit *name) ...@@ -615,13 +616,19 @@ findpkg(Strlit *name)
return 1; return 1;
} }
if(goroot != nil) { if(goroot != nil) {
race = ""; suffix = "";
if(flag_race) suffixsep = "";
race = "_race"; if(flag_installsuffix != nil) {
snprint(namebuf, sizeof(namebuf), "%s/pkg/%s_%s%s/%Z.a", goroot, goos, goarch, race, name); suffixsep = "_";
suffix = flag_installsuffix;
} else if(flag_race) {
suffixsep = "_";
suffix = "race";
}
snprint(namebuf, sizeof(namebuf), "%s/pkg/%s_%s%s%s/%Z.a", goroot, goos, goarch, suffixsep, suffix, name);
if(access(namebuf, 0) >= 0) if(access(namebuf, 0) >= 0)
return 1; return 1;
snprint(namebuf, sizeof(namebuf), "%s/pkg/%s_%s%s/%Z.%c", goroot, goos, goarch, race, name, thechar); snprint(namebuf, sizeof(namebuf), "%s/pkg/%s_%s%s%s/%Z.%c", goroot, goos, goarch, suffixsep, suffix, name, thechar);
if(access(namebuf, 0) >= 0) if(access(namebuf, 0) >= 0)
return 1; return 1;
} }
......
...@@ -1530,6 +1530,9 @@ func (gcToolchain) gc(b *builder, p *Package, obj string, importArgs []string, g ...@@ -1530,6 +1530,9 @@ func (gcToolchain) gc(b *builder, p *Package, obj string, importArgs []string, g
if extFiles == 0 { if extFiles == 0 {
gcargs = append(gcargs, "-complete") gcargs = append(gcargs, "-complete")
} }
if buildContext.InstallSuffix != "" {
gcargs = append(gcargs, "-installsuffix", buildContext.InstallSuffix)
}
args := stringList(tool(archChar+"g"), "-o", ofile, buildGcflags, gcargs, "-D", p.localPrefix, importArgs) args := stringList(tool(archChar+"g"), "-o", ofile, buildGcflags, gcargs, "-D", p.localPrefix, importArgs)
for _, f := range gofiles { for _, f := range gofiles {
...@@ -1579,6 +1582,9 @@ func (gcToolchain) ld(b *builder, p *Package, out string, allactions []*action, ...@@ -1579,6 +1582,9 @@ func (gcToolchain) ld(b *builder, p *Package, out string, allactions []*action,
} }
} }
ldflags := buildLdflags ldflags := buildLdflags
if buildContext.InstallSuffix != "" {
ldflags = append(ldflags, "-installsuffix", buildContext.InstallSuffix)
}
if cxx { if cxx {
// The program includes C++ code. If the user has not // The program includes C++ code. If the user has not
// specified the -extld option, then default to // specified the -extld option, then default to
......
...@@ -82,6 +82,7 @@ var testFlagDefn = []*testFlagSpec{ ...@@ -82,6 +82,7 @@ var testFlagDefn = []*testFlagSpec{
{name: "tags"}, {name: "tags"},
{name: "compiler"}, {name: "compiler"},
{name: "race", boolVar: &buildRace}, {name: "race", boolVar: &buildRace},
{name: "installsuffix"},
// passed to 6.out, adding a "test." prefix to the name if necessary: -v becomes -test.v. // passed to 6.out, adding a "test." prefix to the name if necessary: -v becomes -test.v.
{name: "bench", passToTest: true}, {name: "bench", passToTest: true},
......
...@@ -91,7 +91,7 @@ Lflag(char *arg) ...@@ -91,7 +91,7 @@ Lflag(char *arg)
void void
libinit(void) libinit(void)
{ {
char *race; char *suffix, *suffixsep;
fmtinstall('i', iconv); fmtinstall('i', iconv);
fmtinstall('Y', Yconv); fmtinstall('Y', Yconv);
...@@ -101,10 +101,16 @@ libinit(void) ...@@ -101,10 +101,16 @@ libinit(void)
print("goarch is not known: %s\n", goarch); print("goarch is not known: %s\n", goarch);
// add goroot to the end of the libdir list. // add goroot to the end of the libdir list.
race = ""; suffix = "";
if(flag_race) suffixsep = "";
race = "_race"; if(flag_installsuffix != nil) {
Lflag(smprint("%s/pkg/%s_%s%s", goroot, goos, goarch, race)); suffixsep = "_";
suffix = flag_installsuffix;
} else if(flag_race) {
suffixsep = "_";
suffix = "race";
}
Lflag(smprint("%s/pkg/%s_%s%s%s", goroot, goos, goarch, suffixsep, suffix));
// Unix doesn't like it when we write to a running (or, sometimes, // Unix doesn't like it when we write to a running (or, sometimes,
// recently run) binary, so remove the output file before writing it. // recently run) binary, so remove the output file before writing it.
......
...@@ -160,6 +160,7 @@ EXTERN char** ldflag; ...@@ -160,6 +160,7 @@ EXTERN char** ldflag;
EXTERN int havedynamic; EXTERN int havedynamic;
EXTERN int iscgo; EXTERN int iscgo;
EXTERN int elfglobalsymndx; EXTERN int elfglobalsymndx;
EXTERN char* flag_installsuffix;
EXTERN int flag_race; EXTERN int flag_race;
EXTERN int flag_shared; EXTERN int flag_shared;
EXTERN char* tracksym; EXTERN char* tracksym;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment