Merge "Allow ramdisk targets to set cflags/exclude_srcs." into main am: 6ff7d9e532
am: f2aebd5720
Original change: https://android-review.googlesource.com/c/platform/build/soong/+/2679377 Change-Id: I25bf9312679c9aa8742ddbca86f6a4386d67ee1c Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
committed by
Automerger Merge Worker
commit
0fc8e44b72
@@ -189,13 +189,13 @@ type BaseCompilerProperties struct {
|
||||
// build the recovery variant of the C/C++ module.
|
||||
Exclude_generated_sources []string
|
||||
}
|
||||
Vendor_ramdisk struct {
|
||||
Ramdisk, Vendor_ramdisk struct {
|
||||
// list of source files that should not be used to
|
||||
// build the vendor ramdisk variant of the C/C++ module.
|
||||
// build the ramdisk variants of the C/C++ module.
|
||||
Exclude_srcs []string `android:"path"`
|
||||
|
||||
// List of additional cflags that should be used to build the vendor ramdisk
|
||||
// variant of the C/C++ module.
|
||||
// List of additional cflags that should be used to build the ramdisk
|
||||
// variants of the C/C++ module.
|
||||
Cflags []string
|
||||
}
|
||||
Platform struct {
|
||||
@@ -351,6 +351,7 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps
|
||||
CheckBadCompilerFlags(ctx, "vendor.cflags", compiler.Properties.Target.Vendor.Cflags)
|
||||
CheckBadCompilerFlags(ctx, "product.cflags", compiler.Properties.Target.Product.Cflags)
|
||||
CheckBadCompilerFlags(ctx, "recovery.cflags", compiler.Properties.Target.Recovery.Cflags)
|
||||
CheckBadCompilerFlags(ctx, "ramdisk.cflags", compiler.Properties.Target.Ramdisk.Cflags)
|
||||
CheckBadCompilerFlags(ctx, "vendor_ramdisk.cflags", compiler.Properties.Target.Vendor_ramdisk.Cflags)
|
||||
CheckBadCompilerFlags(ctx, "platform.cflags", compiler.Properties.Target.Platform.Cflags)
|
||||
|
||||
@@ -536,6 +537,9 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps
|
||||
if ctx.inVendorRamdisk() {
|
||||
flags.Local.CFlags = append(flags.Local.CFlags, esc(compiler.Properties.Target.Vendor_ramdisk.Cflags)...)
|
||||
}
|
||||
if ctx.inRamdisk() {
|
||||
flags.Local.CFlags = append(flags.Local.CFlags, esc(compiler.Properties.Target.Ramdisk.Cflags)...)
|
||||
}
|
||||
if !ctx.useSdk() {
|
||||
flags.Local.CFlags = append(flags.Local.CFlags, esc(compiler.Properties.Target.Platform.Cflags)...)
|
||||
}
|
||||
|
@@ -678,10 +678,17 @@ func squashVendorRamdiskSrcs(m *Module) {
|
||||
}
|
||||
}
|
||||
|
||||
func squashRamdiskSrcs(m *Module) {
|
||||
if lib, ok := m.compiler.(*libraryDecorator); ok {
|
||||
lib.baseCompiler.Properties.Exclude_srcs = append(lib.baseCompiler.Properties.Exclude_srcs, lib.baseCompiler.Properties.Target.Ramdisk.Exclude_srcs...)
|
||||
}
|
||||
}
|
||||
|
||||
func (c *Module) SetImageVariation(ctx android.BaseModuleContext, variant string, module android.Module) {
|
||||
m := module.(*Module)
|
||||
if variant == android.RamdiskVariation {
|
||||
m.MakeAsPlatform()
|
||||
squashRamdiskSrcs(m)
|
||||
} else if variant == android.VendorRamdiskVariation {
|
||||
m.MakeAsPlatform()
|
||||
squashVendorRamdiskSrcs(m)
|
||||
|
Reference in New Issue
Block a user