Merge changes from topic "future_symbol" am: 1de5a578d2 am: 27d194c793
				
					
				
			Original change: https://android-review.googlesource.com/c/platform/build/soong/+/1425589 MUST ONLY BE SUBMITTED BY AUTOMERGER Change-Id: Ibd459c75bcaa171f76ccde10677f30a9379aa96d
This commit is contained in:
		
							
								
								
									
										47
									
								
								cc/cc.go
									
									
									
									
									
								
							
							
						
						
									
										47
									
								
								cc/cc.go
									
									
									
									
									
								
							| @@ -256,11 +256,27 @@ type BaseProperties struct { | ||||
| 	// Deprecated. true is the default, false is invalid. | ||||
| 	Clang *bool `android:"arch_variant"` | ||||
|  | ||||
| 	// Minimum sdk version supported when compiling against the ndk. Setting this property causes | ||||
| 	// two variants to be built, one for the platform and one for apps. | ||||
| 	// The API level that this module is built against. The APIs of this API level will be | ||||
| 	// visible at build time, but use of any APIs newer than min_sdk_version will render the | ||||
| 	// module unloadable on older devices.  In the future it will be possible to weakly-link new | ||||
| 	// APIs, making the behavior match Java: such modules will load on older devices, but | ||||
| 	// calling new APIs on devices that do not support them will result in a crash. | ||||
| 	// | ||||
| 	// This property has the same behavior as sdk_version does for Java modules. For those | ||||
| 	// familiar with Android Gradle, the property behaves similarly to how compileSdkVersion | ||||
| 	// does for Java code. | ||||
| 	// | ||||
| 	// In addition, setting this property causes two variants to be built, one for the platform | ||||
| 	// and one for apps. | ||||
| 	Sdk_version *string | ||||
|  | ||||
| 	// Minimum sdk version that the artifact should support when it runs as part of mainline modules(APEX). | ||||
| 	// Minimum OS API level supported by this C or C++ module. This property becomes the value | ||||
| 	// of the __ANDROID_API__ macro. When the C or C++ module is included in an APEX or an APK, | ||||
| 	// this property is also used to ensure that the min_sdk_version of the containing module is | ||||
| 	// not older (i.e. less) than this module's min_sdk_version. When not set, this property | ||||
| 	// defaults to the value of sdk_version.  When this is set to "apex_inherit", this tracks | ||||
| 	// min_sdk_version of the containing APEX. When the module | ||||
| 	// is not built for an APEX, "apex_inherit" defaults to sdk_version. | ||||
| 	Min_sdk_version *string | ||||
|  | ||||
| 	// If true, always create an sdk variant and don't create a platform variant. | ||||
| @@ -441,6 +457,8 @@ type ModuleContextIntf interface { | ||||
| 	canUseSdk() bool | ||||
| 	useSdk() bool | ||||
| 	sdkVersion() string | ||||
| 	minSdkVersion() string | ||||
| 	isSdkVariant() bool | ||||
| 	useVndk() bool | ||||
| 	isNdk(config android.Config) bool | ||||
| 	IsLlndk() bool | ||||
| @@ -1320,6 +1338,29 @@ func (ctx *moduleContextImpl) sdkVersion() string { | ||||
| 	return "" | ||||
| } | ||||
|  | ||||
| func (ctx *moduleContextImpl) minSdkVersion() string { | ||||
| 	ver := ctx.mod.MinSdkVersion() | ||||
| 	if ver == "apex_inherit" && !ctx.isForPlatform() { | ||||
| 		ver = ctx.apexSdkVersion().String() | ||||
| 	} | ||||
| 	if ver == "apex_inherit" || ver == "" { | ||||
| 		ver = ctx.sdkVersion() | ||||
| 	} | ||||
| 	// Also make sure that minSdkVersion is not greater than sdkVersion, if they are both numbers | ||||
| 	sdkVersionInt, err := strconv.Atoi(ctx.sdkVersion()) | ||||
| 	minSdkVersionInt, err2 := strconv.Atoi(ver) | ||||
| 	if err == nil && err2 == nil { | ||||
| 		if sdkVersionInt < minSdkVersionInt { | ||||
| 			return strconv.Itoa(sdkVersionInt) | ||||
| 		} | ||||
| 	} | ||||
| 	return ver | ||||
| } | ||||
|  | ||||
| func (ctx *moduleContextImpl) isSdkVariant() bool { | ||||
| 	return ctx.mod.IsSdkVariant() | ||||
| } | ||||
|  | ||||
| func (ctx *moduleContextImpl) useVndk() bool { | ||||
| 	return ctx.mod.UseVndk() | ||||
| } | ||||
|   | ||||
| @@ -404,7 +404,12 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps | ||||
|  | ||||
| 	target := "-target " + tc.ClangTriple() | ||||
| 	if ctx.Os().Class == android.Device { | ||||
| 		version := ctx.sdkVersion() | ||||
| 		// When built for the non-updateble part of platform, minSdkVersion doesn't matter. | ||||
| 		// It matters only when building we are building for modules that can be unbundled. | ||||
| 		version := "current" | ||||
| 		if !ctx.isForPlatform() || ctx.isSdkVariant() { | ||||
| 			version = ctx.minSdkVersion() | ||||
| 		} | ||||
| 		if version == "" || version == "current" { | ||||
| 			target += strconv.Itoa(android.FutureApiLevelInt) | ||||
| 		} else { | ||||
|   | ||||
| @@ -141,6 +141,13 @@ func init() { | ||||
| 		// Warnings from clang-10 | ||||
| 		// Nested and array designated initialization is nice to have. | ||||
| 		"-Wno-c99-designator", | ||||
|  | ||||
| 		// Calls to the APIs that are newer than the min sdk version of the caller should be | ||||
| 		// guarded with __builtin_available. | ||||
| 		"-Wunguarded-availability", | ||||
| 		// This macro allows the bionic versioning.h to indirectly determine whether the | ||||
| 		// option -Wunguarded-availability is on or not. | ||||
| 		"-D__ANDROID_UNGUARDED_AVAILABILITY__", | ||||
| 	}, " ")) | ||||
|  | ||||
| 	pctx.StaticVariable("ClangExtraCppflags", strings.Join([]string{ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user