Merge "Revert "Use --dependency-file when linking elf files."" am: b914e7f8c6 am: c43e5ff7cc
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/2115768 Change-Id: Ieed01217bf395e4951ff571a69b346327d584168 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
		| @@ -853,24 +853,13 @@ func transformObjToDynamicBinary(ctx android.ModuleContext, | |||||||
| 	deps = append(deps, crtBegin...) | 	deps = append(deps, crtBegin...) | ||||||
| 	deps = append(deps, crtEnd...) | 	deps = append(deps, crtEnd...) | ||||||
|  |  | ||||||
| 	var depFile android.WritablePath |  | ||||||
| 	var depFileLdFlags string |  | ||||||
| 	depsType := blueprint.DepsNone |  | ||||||
| 	if !ctx.Windows() && !ctx.Darwin() { |  | ||||||
| 		// lld only supports --dependency-file for elf files |  | ||||||
| 		depFile = outputFile.ReplaceExtension(ctx, "d") |  | ||||||
| 		depFileLdFlags = " -Wl,--dependency-file=" + depFile.String() |  | ||||||
| 		depsType = blueprint.DepsGCC |  | ||||||
| 		implicitOutputs = append(implicitOutputs, depFile) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	rule := ld | 	rule := ld | ||||||
| 	args := map[string]string{ | 	args := map[string]string{ | ||||||
| 		"ldCmd":         ldCmd, | 		"ldCmd":         ldCmd, | ||||||
| 		"crtBegin":      strings.Join(crtBegin.Strings(), " "), | 		"crtBegin":      strings.Join(crtBegin.Strings(), " "), | ||||||
| 		"libFlags":      strings.Join(libFlagsList, " "), | 		"libFlags":      strings.Join(libFlagsList, " "), | ||||||
| 		"extraLibFlags": flags.extraLibFlags, | 		"extraLibFlags": flags.extraLibFlags, | ||||||
| 		"ldFlags":       flags.globalLdFlags + " " + flags.localLdFlags + depFileLdFlags, | 		"ldFlags":       flags.globalLdFlags + " " + flags.localLdFlags, | ||||||
| 		"crtEnd":        strings.Join(crtEnd.Strings(), " "), | 		"crtEnd":        strings.Join(crtEnd.Strings(), " "), | ||||||
| 	} | 	} | ||||||
| 	if ctx.Config().UseRBE() && ctx.Config().IsEnvTrue("RBE_CXX_LINKS") { | 	if ctx.Config().UseRBE() && ctx.Config().IsEnvTrue("RBE_CXX_LINKS") { | ||||||
| @@ -881,8 +870,6 @@ func transformObjToDynamicBinary(ctx android.ModuleContext, | |||||||
|  |  | ||||||
| 	ctx.Build(pctx, android.BuildParams{ | 	ctx.Build(pctx, android.BuildParams{ | ||||||
| 		Rule:            rule, | 		Rule:            rule, | ||||||
| 		Deps:            depsType, |  | ||||||
| 		Depfile:         depFile, |  | ||||||
| 		Description:     "link " + outputFile.Base(), | 		Description:     "link " + outputFile.Base(), | ||||||
| 		Output:          outputFile, | 		Output:          outputFile, | ||||||
| 		ImplicitOutputs: implicitOutputs, | 		ImplicitOutputs: implicitOutputs, | ||||||
| @@ -1039,33 +1026,18 @@ func transformObjsToObj(ctx android.ModuleContext, objFiles android.Paths, | |||||||
|  |  | ||||||
| 	ldCmd := "${config.ClangBin}/clang++" | 	ldCmd := "${config.ClangBin}/clang++" | ||||||
|  |  | ||||||
| 	var implicitOutputs android.WritablePaths |  | ||||||
| 	var depFile android.WritablePath |  | ||||||
| 	var depFileLdFlags string |  | ||||||
| 	depsType := blueprint.DepsNone |  | ||||||
| 	if !ctx.Windows() && !ctx.Darwin() { |  | ||||||
| 		// lld only supports --dependency-file for elf files |  | ||||||
| 		depFile = outputFile.ReplaceExtension(ctx, "d") |  | ||||||
| 		depFileLdFlags = " -Wl,--dependency-file=" + depFile.String() |  | ||||||
| 		depsType = blueprint.DepsGCC |  | ||||||
| 		implicitOutputs = append(implicitOutputs, depFile) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	rule := partialLd | 	rule := partialLd | ||||||
| 	args := map[string]string{ | 	args := map[string]string{ | ||||||
| 		"ldCmd":   ldCmd, | 		"ldCmd":   ldCmd, | ||||||
| 		"ldFlags": flags.globalLdFlags + " " + flags.localLdFlags + depFileLdFlags, | 		"ldFlags": flags.globalLdFlags + " " + flags.localLdFlags, | ||||||
| 	} | 	} | ||||||
| 	if ctx.Config().UseRBE() && ctx.Config().IsEnvTrue("RBE_CXX_LINKS") { | 	if ctx.Config().UseRBE() && ctx.Config().IsEnvTrue("RBE_CXX_LINKS") { | ||||||
| 		rule = partialLdRE | 		rule = partialLdRE | ||||||
| 		args["inCommaList"] = strings.Join(objFiles.Strings(), ",") | 		args["inCommaList"] = strings.Join(objFiles.Strings(), ",") | ||||||
| 		args["implicitInputs"] = strings.Join(deps.Strings(), ",") | 		args["implicitInputs"] = strings.Join(deps.Strings(), ",") | ||||||
| 		args["implicitOutputs"] = strings.Join(implicitOutputs.Strings(), ",") |  | ||||||
| 	} | 	} | ||||||
| 	ctx.Build(pctx, android.BuildParams{ | 	ctx.Build(pctx, android.BuildParams{ | ||||||
| 		Rule:        rule, | 		Rule:        rule, | ||||||
| 		Deps:        depsType, |  | ||||||
| 		Depfile:     depFile, |  | ||||||
| 		Description: "link " + outputFile.Base(), | 		Description: "link " + outputFile.Base(), | ||||||
| 		Output:      outputFile, | 		Output:      outputFile, | ||||||
| 		Inputs:      objFiles, | 		Inputs:      objFiles, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user