Add Relocation Packer support
am: 394e9dc876
Change-Id: Ib07800a5773223de38bcd8fbac88bc0bf3bbe9f2
This commit is contained in:
@@ -126,6 +126,7 @@ bootstrap_go_package {
|
|||||||
"cc/check.go",
|
"cc/check.go",
|
||||||
"cc/gen.go",
|
"cc/gen.go",
|
||||||
"cc/makevars.go",
|
"cc/makevars.go",
|
||||||
|
"cc/relocation_packer.go",
|
||||||
"cc/sanitize.go",
|
"cc/sanitize.go",
|
||||||
"cc/stl.go",
|
"cc/stl.go",
|
||||||
"cc/strip.go",
|
"cc/strip.go",
|
||||||
|
@@ -70,8 +70,8 @@ var standardProperties = map[string]struct {
|
|||||||
"LOCAL_NO_CRT": {"nocrt", bpparser.BoolType},
|
"LOCAL_NO_CRT": {"nocrt", bpparser.BoolType},
|
||||||
"LOCAL_ALLOW_UNDEFINED_SYMBOLS": {"allow_undefined_symbols", bpparser.BoolType},
|
"LOCAL_ALLOW_UNDEFINED_SYMBOLS": {"allow_undefined_symbols", bpparser.BoolType},
|
||||||
"LOCAL_RTTI_FLAG": {"rtti", bpparser.BoolType},
|
"LOCAL_RTTI_FLAG": {"rtti", bpparser.BoolType},
|
||||||
|
"LOCAL_NO_STANDARD_LIBRARIES": {"no_standard_libraries", bpparser.BoolType},
|
||||||
"LOCAL_NO_STANDARD_LIBRARIES": {"no_standard_libraries", bpparser.BoolType},
|
"LOCAL_PACK_MODULE_RELOCATIONS": {"pack_relocations", bpparser.BoolType},
|
||||||
|
|
||||||
"LOCAL_EXPORT_PACKAGE_RESOURCES": {"export_package_resources", bpparser.BoolType},
|
"LOCAL_EXPORT_PACKAGE_RESOURCES": {"export_package_resources", bpparser.BoolType},
|
||||||
}
|
}
|
||||||
|
@@ -81,6 +81,7 @@ func (c *Module) AndroidMk() (ret android.AndroidMkData, err error) {
|
|||||||
func (library *libraryDecorator) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkData) {
|
func (library *libraryDecorator) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkData) {
|
||||||
if !library.static() {
|
if !library.static() {
|
||||||
ctx.subAndroidMk(ret, &library.stripper)
|
ctx.subAndroidMk(ret, &library.stripper)
|
||||||
|
ctx.subAndroidMk(ret, &library.relocationPacker)
|
||||||
}
|
}
|
||||||
|
|
||||||
if library.static() {
|
if library.static() {
|
||||||
@@ -181,6 +182,15 @@ func (stripper *stripper) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMk
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (packer *relocationPacker) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkData) {
|
||||||
|
ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) error {
|
||||||
|
if packer.Properties.PackingRelocations {
|
||||||
|
fmt.Fprintln(w, "LOCAL_PACK_MODULE_RELOCATIONS := true")
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func (installer *baseInstaller) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkData) {
|
func (installer *baseInstaller) AndroidMk(ctx AndroidMkContext, ret *android.AndroidMkData) {
|
||||||
ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) error {
|
ret.Extra = append(ret.Extra, func(w io.Writer, outputFile android.Path) error {
|
||||||
path := installer.path.RelPathString()
|
path := installer.path.RelPathString()
|
||||||
|
@@ -151,6 +151,7 @@ type libraryDecorator struct {
|
|||||||
|
|
||||||
flagExporter
|
flagExporter
|
||||||
stripper
|
stripper
|
||||||
|
relocationPacker
|
||||||
|
|
||||||
// If we're used as a whole_static_lib, our missing dependencies need
|
// If we're used as a whole_static_lib, our missing dependencies need
|
||||||
// to be given
|
// to be given
|
||||||
@@ -177,7 +178,8 @@ func (library *libraryDecorator) linkerProps() []interface{} {
|
|||||||
return append(props,
|
return append(props,
|
||||||
&library.Properties,
|
&library.Properties,
|
||||||
&library.flagExporter.Properties,
|
&library.flagExporter.Properties,
|
||||||
&library.stripper.StripProperties)
|
&library.stripper.StripProperties,
|
||||||
|
&library.relocationPacker.Properties)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
|
func (library *libraryDecorator) linkerFlags(ctx ModuleContext, flags Flags) Flags {
|
||||||
@@ -289,6 +291,8 @@ func (library *libraryDecorator) linkerInit(ctx BaseModuleContext) {
|
|||||||
library.baseInstaller.location = location
|
library.baseInstaller.location = location
|
||||||
|
|
||||||
library.baseLinker.linkerInit(ctx)
|
library.baseLinker.linkerInit(ctx)
|
||||||
|
|
||||||
|
library.relocationPacker.packingInit(ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (library *libraryDecorator) linkerDeps(ctx BaseModuleContext, deps Deps) Deps {
|
func (library *libraryDecorator) linkerDeps(ctx BaseModuleContext, deps Deps) Deps {
|
||||||
@@ -386,6 +390,12 @@ func (library *libraryDecorator) linkShared(ctx ModuleContext,
|
|||||||
|
|
||||||
builderFlags := flagsToBuilderFlags(flags)
|
builderFlags := flagsToBuilderFlags(flags)
|
||||||
|
|
||||||
|
if library.relocationPacker.needsPacking(ctx) {
|
||||||
|
packedOutputFile := outputFile
|
||||||
|
outputFile = android.PathForModuleOut(ctx, "unpacked", fileName)
|
||||||
|
library.relocationPacker.pack(ctx, outputFile, packedOutputFile, builderFlags)
|
||||||
|
}
|
||||||
|
|
||||||
if library.stripper.needsStrip(ctx) {
|
if library.stripper.needsStrip(ctx) {
|
||||||
strippedOutputFile := outputFile
|
strippedOutputFile := outputFile
|
||||||
outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
|
outputFile = android.PathForModuleOut(ctx, "unstripped", fileName)
|
||||||
|
84
cc/relocation_packer.go
Normal file
84
cc/relocation_packer.go
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
// Copyright 2016 Google Inc. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package cc
|
||||||
|
|
||||||
|
import (
|
||||||
|
"runtime"
|
||||||
|
|
||||||
|
"github.com/google/blueprint"
|
||||||
|
|
||||||
|
"android/soong/android"
|
||||||
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
pctx.SourcePathVariable("relocationPackerCmd", "prebuilts/misc/${config.HostPrebuiltTag}/relocation_packer/relocation_packer")
|
||||||
|
}
|
||||||
|
|
||||||
|
var relocationPackerRule = pctx.AndroidStaticRule("packRelocations",
|
||||||
|
blueprint.RuleParams{
|
||||||
|
Command: "rm -f $out && cp $in $out && $relocationPackerCmd $out",
|
||||||
|
CommandDeps: []string{"$relocationPackerCmd"},
|
||||||
|
Description: "pack relocations $out",
|
||||||
|
})
|
||||||
|
|
||||||
|
type RelocationPackerProperties struct {
|
||||||
|
Pack_relocations *bool `android:"arch_variant"`
|
||||||
|
|
||||||
|
// This will be true even if we're embedded in Make, in which case
|
||||||
|
// we'll defer to make to actually do the packing.
|
||||||
|
PackingRelocations bool `blueprint:"mutated"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type relocationPacker struct {
|
||||||
|
Properties RelocationPackerProperties
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *relocationPacker) packingInit(ctx BaseModuleContext) {
|
||||||
|
enabled := true
|
||||||
|
// Relocation packer isn't available on Darwin yet
|
||||||
|
if runtime.GOOS == "darwin" {
|
||||||
|
enabled = false
|
||||||
|
}
|
||||||
|
if ctx.Target().Os != android.Android {
|
||||||
|
enabled = false
|
||||||
|
}
|
||||||
|
if ctx.AConfig().Getenv("DISABLE_RELOCATION_PACKER") == "true" {
|
||||||
|
enabled = false
|
||||||
|
}
|
||||||
|
if ctx.sdk() {
|
||||||
|
enabled = false
|
||||||
|
}
|
||||||
|
if p.Properties.Pack_relocations != nil &&
|
||||||
|
*p.Properties.Pack_relocations == false {
|
||||||
|
enabled = false
|
||||||
|
}
|
||||||
|
|
||||||
|
p.Properties.PackingRelocations = enabled
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *relocationPacker) needsPacking(ctx ModuleContext) bool {
|
||||||
|
if ctx.AConfig().EmbeddedInMake() {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return p.Properties.PackingRelocations
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *relocationPacker) pack(ctx ModuleContext, in, out android.ModuleOutPath, flags builderFlags) {
|
||||||
|
ctx.ModuleBuild(pctx, android.ModuleBuildParams{
|
||||||
|
Rule: relocationPackerRule,
|
||||||
|
Output: out,
|
||||||
|
Input: in,
|
||||||
|
})
|
||||||
|
}
|
Reference in New Issue
Block a user