Joe Onorato | 964f401 | 2023-05-06 12:29:01 -0700 | [diff] [blame] | 1 | # Copyright (C) 2023 The Android Open Source Project |
| 2 | # |
| 3 | # Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | # you may not use this file except in compliance with the License. |
| 5 | # You may obtain a copy of the License at |
| 6 | # |
| 7 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | # |
| 9 | # Unless required by applicable law or agreed to in writing, software |
| 10 | # distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | # See the License for the specific language governing permissions and |
| 13 | # limitations under the License. |
| 14 | |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 15 | |
| 16 | # ----------------------------------------------------------------- |
| 17 | # Choose the flag files |
| 18 | # ----------------------------------------------------------------- |
Joe Onorato | 1f65551 | 2023-06-12 23:29:25 -0700 | [diff] [blame] | 19 | # Release configs are defined in reflease_config_map files, which map |
| 20 | # the short name (e.g. -next) used in lunch to the starlark files |
| 21 | # defining the build flag values. |
| 22 | # |
| 23 | # (If you're thinking about aconfig flags, there is one build flag, |
Joe Onorato | 6aa48f8 | 2023-06-21 15:17:42 -0700 | [diff] [blame] | 24 | # RELEASE_ACONFIG_VALUE_SETS, that sets which aconfig_value_set |
Joe Onorato | 1f65551 | 2023-06-12 23:29:25 -0700 | [diff] [blame] | 25 | # module to use to set the aconfig flag values.) |
| 26 | # |
| 27 | # The short release config names *can* appear multiple times, to allow |
| 28 | # for AOSP and vendor specific flags under the same name, but the |
| 29 | # individual flag values must appear in exactly one config. Vendor |
| 30 | # does not override AOSP, or anything like that. This is because |
| 31 | # vendor code usually includes prebuilts, and having vendor compile |
| 32 | # with different flags from AOSP increases the likelihood of flag |
| 33 | # mismatch. |
| 34 | |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 35 | # Do this first, because we're going to unset TARGET_RELEASE before |
| 36 | # including anyone, so they don't start making conditionals based on it. |
| 37 | # This logic is in make because starlark doesn't understand optional |
| 38 | # vendor files. |
| 39 | |
| 40 | # If this is a google source tree, restrict it to only the one file |
| 41 | # which has OWNERS control. If it isn't let others define their own. |
| 42 | # TODO: Remove wildcard for build/release one when all branch manifests |
| 43 | # have updated. |
| 44 | config_map_files := $(wildcard build/release/release_config_map.mk) \ |
| 45 | $(if $(wildcard vendor/google/release/release_config_map.mk), \ |
| 46 | vendor/google/release/release_config_map.mk, \ |
| 47 | $(sort \ |
| 48 | $(wildcard device/*/release/release_config_map.mk) \ |
| 49 | $(wildcard device/*/*/release/release_config_map.mk) \ |
| 50 | $(wildcard vendor/*/release/release_config_map.mk) \ |
| 51 | $(wildcard vendor/*/*/release/release_config_map.mk) \ |
| 52 | ) \ |
| 53 | ) |
| 54 | |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 55 | # PRODUCT_RELEASE_CONFIG_MAPS is set by Soong using an initial run of product |
| 56 | # config to capture only the list of config maps needed by the build. |
| 57 | # Keep them in the order provided, but remove duplicates. |
| 58 | $(foreach map,$(PRODUCT_RELEASE_CONFIG_MAPS), \ |
| 59 | $(if $(filter $(map),$(config_map_files)),,$(eval config_map_files += $(map))) \ |
| 60 | ) |
| 61 | |
| 62 | # Declare or extend a release-config. |
| 63 | # |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 64 | # $1 config name |
| 65 | # $2 release config files |
| 66 | define declare-release-config |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 67 | $(if $(strip $(2)),, \ |
| 68 | $(error declare-release-config: config $(strip $(1)) must have release config files) \ |
| 69 | ) |
| 70 | $(eval _all_release_configs := $(sort $(_all_release_configs) $(strip $(1)))) |
Joe Onorato | 1f65551 | 2023-06-12 23:29:25 -0700 | [diff] [blame] | 71 | $(eval _all_release_configs.$(strip $(1)).DECLARED_IN := $(_included) $(_all_release_configs.$(strip $(1)).DECLARED_IN)) |
| 72 | $(eval _all_release_configs.$(strip $(1)).FILES := $(_all_release_configs.$(strip $(1)).FILES) $(strip $(2))) |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 73 | endef |
| 74 | |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 75 | # Include the config map files and populate _flag_declaration_files. |
| 76 | _flag_declaration_files := |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 77 | $(foreach f, $(config_map_files), \ |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 78 | $(eval FLAG_DECLARATION_FILES:= ) \ |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 79 | $(eval _included := $(f)) \ |
| 80 | $(eval include $(f)) \ |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 81 | $(eval _flag_declaration_files += $(FLAG_DECLARATION_FILES)) \ |
| 82 | ) |
| 83 | FLAG_DECLARATION_FILES := |
| 84 | |
| 85 | # Make sure that the flag definitions are included for vendor/google builds. |
| 86 | # This decouples the change in vendor/google/release/release_config_map.mk |
| 87 | # from this logic change. |
| 88 | # TODO: Remove this once the vendor/google FLAG_DECLARATION_FILES change is there. |
| 89 | $(if $(wildcard vendor/google/release/release_config_map.mk),\ |
| 90 | $(if $(filter vendor/google/release/build_flags.bzl,$(_flag_declaration_files)),,\ |
| 91 | $(eval _flag_declaration_files := vendor/google/release/build_flags.bzl $(_flag_declaration_files)) \ |
| 92 | ) \ |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 93 | ) |
| 94 | |
| 95 | # If TARGET_RELEASE is set, fail if there is no matching release config |
| 96 | # If it isn't set, no release config files will be included and all flags |
| 97 | # will get their default values. |
| 98 | ifneq ($(TARGET_RELEASE),) |
| 99 | ifeq ($(filter $(_all_release_configs), $(TARGET_RELEASE)),) |
| 100 | $(error No release config found for TARGET_RELEASE: $(TARGET_RELEASE). Available releases are: $(_all_release_configs)) |
| 101 | else |
| 102 | # Choose flag files |
| 103 | # Don't sort this, use it in the order they gave us. |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 104 | # Do allow duplicate entries, retaining only the first usage. |
| 105 | flag_value_files := |
| 106 | $(foreach f,$(_all_release_configs.$(TARGET_RELEASE).FILES), \ |
| 107 | $(if $(filter $(f),$(flag_value_files)),,$(eval flag_value_files += $(f)))\ |
| 108 | ) |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 109 | endif |
| 110 | else |
| 111 | # Useful for finding scripts etc that aren't passing or setting TARGET_RELEASE |
| 112 | ifneq ($(FAIL_IF_NO_RELEASE_CONFIG),) |
| 113 | $(error FAIL_IF_NO_RELEASE_CONFIG was set and TARGET_RELEASE was not) |
| 114 | endif |
| 115 | flag_value_files := |
| 116 | endif |
| 117 | |
| 118 | # Unset variables so they can't use them |
| 119 | define declare-release-config |
| 120 | $(error declare-release-config can only be called from inside release_config_map.mk files) |
| 121 | endef |
| 122 | |
| 123 | # TODO: Remove this check after enough people have sourced lunch that we don't |
| 124 | # need to worry about it trying to do get_build_vars TARGET_RELEASE. Maybe after ~9/2023 |
| 125 | ifneq ($(CALLED_FROM_SETUP),true) |
| 126 | define TARGET_RELEASE |
| 127 | $(error TARGET_RELEASE may not be accessed directly. Use individual flags.) |
| 128 | endef |
| 129 | else |
| 130 | TARGET_RELEASE:= |
| 131 | endif |
| 132 | .KATI_READONLY := TARGET_RELEASE |
| 133 | |
| 134 | |
| 135 | $(foreach config, $(_all_release_configs), \ |
| 136 | $(eval _all_release_configs.$(config).DECLARED_IN:= ) \ |
| 137 | $(eval _all_release_configs.$(config).FILES:= ) \ |
| 138 | ) |
| 139 | _all_release_configs:= |
| 140 | config_map_files:= |
| 141 | |
| 142 | |
| 143 | # ----------------------------------------------------------------- |
| 144 | # Flag declarations and values |
| 145 | # ----------------------------------------------------------------- |
| 146 | # This part is in starlark. We generate a root starlark file that loads |
| 147 | # all of the flags declaration files that we found, and the flag_value_files |
| 148 | # that we chose from the config map above. Then we run that, and load the |
| 149 | # results of that into the make environment. |
| 150 | |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 151 | # _flag_declaration_files is the combined list of FLAG_DECLARATION_FILES set by |
| 152 | # release_config_map.mk files above. |
Joe Onorato | 964f401 | 2023-05-06 12:29:01 -0700 | [diff] [blame] | 153 | |
Cole Faust | 386b374 | 2023-06-06 16:55:58 -0700 | [diff] [blame] | 154 | # Because starlark can't find files with $(wildcard), write an entrypoint starlark script that |
| 155 | # contains the result of the above wildcards for the starlark code to use. |
| 156 | filename_to_starlark=$(subst /,_,$(subst .,_,$(1))) |
| 157 | _c:=load("//build/make/core/release_config.bzl", "release_config") |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 158 | _c+=$(newline)def add(d, k, v): |
| 159 | _c+=$(newline)$(space)d = dict(d) |
| 160 | _c+=$(newline)$(space)d[k] = v |
| 161 | _c+=$(newline)$(space)return d |
LaMont Jones | 38b195e | 2023-11-06 22:14:51 +0000 | [diff] [blame^] | 162 | _c+=$(foreach f,$(_flag_declaration_files),$(newline)load("$(f)", flags_$(call filename_to_starlark,$(f)) = "flags")) |
| 163 | _c+=$(newline)all_flags = [] $(foreach f,$(_flag_declaration_files),+ [add(x, "declared_in", "$(f)") for x in flags_$(call filename_to_starlark,$(f))]) |
Joe Onorato | d6df20a | 2023-06-09 18:51:00 -0700 | [diff] [blame] | 164 | _c+=$(foreach f,$(flag_value_files),$(newline)load("//$(f)", values_$(call filename_to_starlark,$(f)) = "values")) |
| 165 | _c+=$(newline)all_values = [] $(foreach f,$(flag_value_files),+ [add(x, "set_in", "$(f)") for x in values_$(call filename_to_starlark,$(f))]) |
| 166 | _c+=$(newline)variables_to_export_to_make = release_config(all_flags, all_values) |
Cole Faust | 386b374 | 2023-06-06 16:55:58 -0700 | [diff] [blame] | 167 | $(file >$(OUT_DIR)/release_config_entrypoint.bzl,$(_c)) |
| 168 | _c:= |
| 169 | filename_to_starlark:= |
Joe Onorato | 964f401 | 2023-05-06 12:29:01 -0700 | [diff] [blame] | 170 | |
Cole Faust | 386b374 | 2023-06-06 16:55:58 -0700 | [diff] [blame] | 171 | # Exclude the entrypoint file as a dependency (by passing it as the 2nd argument) so that we don't |
| 172 | # rerun kati every build. Kati will replay the $(file) command that generates it every build, |
| 173 | # updating its timestamp. |
| 174 | # |
| 175 | # We also need to pass --allow_external_entrypoint to rbcrun in case the OUT_DIR is set to something |
| 176 | # outside of the source tree. |
| 177 | $(call run-starlark,$(OUT_DIR)/release_config_entrypoint.bzl,$(OUT_DIR)/release_config_entrypoint.bzl,--allow_external_entrypoint) |
Joe Onorato | 7b578d3 | 2023-05-19 09:13:36 -0700 | [diff] [blame] | 178 | |