Enable HWASan for multiple modules in one place(Soong)
Environment variables HWASAN_INCLUDE_PATHS and PRODUCT_HWASAN_INCLUDE_PATHS can be used to enable HWASan for multiple modules, by just adding the module directory to the env variable. Bug: b/271948407 Test: Set specific module directory to above env variable and check the assembly codes of output elf files after building, finding hwasan related symbols inside. Change-Id: Ic49b515830c4469ca5fa94f547b26c0fb602fc54
This commit is contained in:
@@ -1557,6 +1557,13 @@ func (c *config) MemtagHeapSyncEnabledForPath(path string) bool {
|
||||
return HasAnyPrefix(path, c.productVariables.MemtagHeapSyncIncludePaths) && !c.MemtagHeapDisabledForPath(path)
|
||||
}
|
||||
|
||||
func (c *config) HWASanEnabledForPath(path string) bool {
|
||||
if len(c.productVariables.HWASanIncludePaths) == 0 {
|
||||
return false
|
||||
}
|
||||
return HasAnyPrefix(path, c.productVariables.HWASanIncludePaths)
|
||||
}
|
||||
|
||||
func (c *config) VendorConfig(name string) VendorConfig {
|
||||
return soongconfig.Config(c.productVariables.VendorVars[name])
|
||||
}
|
||||
|
@@ -306,6 +306,8 @@ type productVariables struct {
|
||||
MemtagHeapAsyncIncludePaths []string `json:",omitempty"`
|
||||
MemtagHeapSyncIncludePaths []string `json:",omitempty"`
|
||||
|
||||
HWASanIncludePaths []string `json:",omitempty"`
|
||||
|
||||
VendorPath *string `json:",omitempty"`
|
||||
OdmPath *string `json:",omitempty"`
|
||||
ProductPath *string `json:",omitempty"`
|
||||
|
@@ -593,6 +593,12 @@ func (sanitize *sanitize) begin(ctx BaseModuleContext) {
|
||||
}
|
||||
}
|
||||
|
||||
// Enable HWASan for all components in the include paths (for Aarch64 only)
|
||||
if s.Hwaddress == nil && ctx.Config().HWASanEnabledForPath(ctx.ModuleDir()) &&
|
||||
ctx.Arch().ArchType == android.Arm64 && ctx.toolchain().Bionic() {
|
||||
s.Hwaddress = proptools.BoolPtr(true)
|
||||
}
|
||||
|
||||
// Enable CFI for non-host components in the include paths
|
||||
if s.Cfi == nil && ctx.Config().CFIEnabledForPath(ctx.ModuleDir()) && !ctx.Host() {
|
||||
s.Cfi = proptools.BoolPtr(true)
|
||||
|
Reference in New Issue
Block a user