Home | History | Annotate | Download | only in core
      1 # Put some miscellaneous rules here
      2 
      3 # Pick a reasonable string to use to identify files.
      4 ifneq "" "$(filter eng.%,$(BUILD_NUMBER))"
      5   # BUILD_NUMBER has a timestamp in it, which means that
      6   # it will change every time.  Pick a stable value.
      7   FILE_NAME_TAG := eng.$(USER)
      8 else
      9   FILE_NAME_TAG := $(BUILD_NUMBER)
     10 endif
     11 
     12 # -----------------------------------------------------------------
     13 # Define rules to copy PRODUCT_COPY_FILES defined by the product.
     14 # PRODUCT_COPY_FILES contains words like <source file>:<dest file>.
     15 # <dest file> is relative to $(PRODUCT_OUT), so it should look like,
     16 # e.g., "system/etc/file.xml".
     17 # The filter part means "only eval the copy-one-file rule if this
     18 # src:dest pair is the first one to match %:dest"
     19 $(foreach cf,$(PRODUCT_COPY_FILES), \
     20   $(eval _src := $(call word-colon,1,$(cf))) \
     21   $(eval _dest := $(call word-colon,2,$(cf))) \
     22   $(eval _fulldest := $(call append-path,$(PRODUCT_OUT),$(_dest))) \
     23   $(if $(filter $(_src):$(_dest),$(firstword $(filter %:$(_dest),$(PRODUCT_COPY_FILES)))), \
     24     $(eval $(call copy-one-file,$(_src),$(_fulldest))),) \
     25   $(eval ALL_DEFAULT_INSTALLED_MODULES += $(_fulldest)) \
     26  )
     27 
     28 # -----------------------------------------------------------------
     29 # docs/index.html
     30 gen := $(OUT_DOCS)/index.html
     31 ALL_DOCS += $(gen)
     32 $(gen): frameworks/base/docs/docs-redirect-index.html
     33 	@mkdir -p $(dir $@)
     34 	@cp -f $< $@
     35 
     36 # -----------------------------------------------------------------
     37 # default.prop
     38 INSTALLED_DEFAULT_PROP_TARGET := $(TARGET_ROOT_OUT)/default.prop
     39 ALL_DEFAULT_INSTALLED_MODULES += $(INSTALLED_DEFAULT_PROP_TARGET)
     40 ADDITIONAL_DEFAULT_PROPERTIES := \
     41 	$(call collapse-pairs, $(ADDITIONAL_DEFAULT_PROPERTIES))
     42 
     43 $(INSTALLED_DEFAULT_PROP_TARGET):
     44 	@echo Target buildinfo: $@
     45 	@mkdir -p $(dir $@)
     46 	$(hide) echo "#" > $@; \
     47 	        echo "# ADDITIONAL_DEFAULT_PROPERTIES" >> $@; \
     48 	        echo "#" >> $@;
     49 	$(hide) $(foreach line,$(ADDITIONAL_DEFAULT_PROPERTIES), \
     50 		echo "$(line)" >> $@;)
     51 
     52 # -----------------------------------------------------------------
     53 # build.prop
     54 INSTALLED_BUILD_PROP_TARGET := $(TARGET_OUT)/build.prop
     55 ALL_DEFAULT_INSTALLED_MODULES += $(INSTALLED_BUILD_PROP_TARGET)
     56 ADDITIONAL_BUILD_PROPERTIES := \
     57 	$(call collapse-pairs, $(ADDITIONAL_BUILD_PROPERTIES))
     58 
     59 # A list of arbitrary tags describing the build configuration.
     60 # Force ":=" so we can use +=
     61 BUILD_VERSION_TAGS := $(BUILD_VERSION_TAGS)
     62 ifeq ($(TARGET_BUILD_TYPE),debug)
     63   BUILD_VERSION_TAGS += debug
     64 endif
     65 # Apps are always signed with test keys, and may be re-signed in a post-build
     66 # step.  If that happens, the "test-keys" tag will be removed by that step.
     67 BUILD_VERSION_TAGS += test-keys
     68 BUILD_VERSION_TAGS := $(subst $(space),$(comma),$(sort $(BUILD_VERSION_TAGS)))
     69 
     70 # A human-readable string that descibes this build in detail.
     71 build_desc := $(TARGET_PRODUCT)-$(TARGET_BUILD_VARIANT) $(PLATFORM_VERSION) $(BUILD_ID) $(BUILD_NUMBER) $(BUILD_VERSION_TAGS)
     72 $(INSTALLED_BUILD_PROP_TARGET): PRIVATE_BUILD_DESC := $(build_desc)
     73 
     74 # The string used to uniquely identify this build;  used by the OTA server.
     75 ifeq (,$(strip $(BUILD_FINGERPRINT)))
     76   BUILD_FINGERPRINT := $(PRODUCT_BRAND)/$(TARGET_PRODUCT)/$(TARGET_DEVICE):$(PLATFORM_VERSION)/$(BUILD_ID)/$(BUILD_NUMBER):$(TARGET_BUILD_VARIANT)/$(BUILD_VERSION_TAGS)
     77 endif
     78 ifneq ($(words $(BUILD_FINGERPRINT)),1)
     79   $(error BUILD_FINGERPRINT cannot contain spaces: "$(BUILD_FINGERPRINT)")
     80 endif
     81 
     82 # Display parameters shown under Settings -> About Phone
     83 ifeq ($(TARGET_BUILD_VARIANT),user)
     84   # User builds should show:
     85   # release build number or branch.buld_number non-release builds
     86 
     87   # Dev. branches should have DISPLAY_BUILD_NUMBER set
     88   ifeq "true" "$(DISPLAY_BUILD_NUMBER)"
     89     BUILD_DISPLAY_ID := $(BUILD_ID).$(BUILD_NUMBER)
     90   else
     91     BUILD_DISPLAY_ID := $(BUILD_ID)
     92   endif
     93 else
     94   # Non-user builds should show detailed build information
     95   BUILD_DISPLAY_ID := $(build_desc)
     96 endif
     97 
     98 # Selects the first locale in the list given as the argument,
     99 # and splits it into language and region, which each may be
    100 # empty.
    101 define default-locale
    102 $(subst _, , $(firstword $(1)))
    103 endef
    104 
    105 # Selects the first locale in the list given as the argument
    106 # and returns the language (or the region)
    107 define default-locale-language
    108 $(word 2, 2, $(call default-locale, $(1)))
    109 endef
    110 define default-locale-region
    111 $(word 3, 3, $(call default-locale, $(1)))
    112 endef
    113 
    114 BUILDINFO_SH := build/tools/buildinfo.sh
    115 $(INSTALLED_BUILD_PROP_TARGET): $(BUILDINFO_SH) $(INTERNAL_BUILD_ID_MAKEFILE)
    116 	@echo Target buildinfo: $@
    117 	@mkdir -p $(dir $@)
    118 	$(hide) TARGET_BUILD_TYPE="$(TARGET_BUILD_VARIANT)" \
    119 			TARGET_DEVICE="$(TARGET_DEVICE)" \
    120 			PRODUCT_NAME="$(TARGET_PRODUCT)" \
    121 			PRODUCT_BRAND="$(PRODUCT_BRAND)" \
    122 			PRODUCT_DEFAULT_LANGUAGE="$(call default-locale-language,$(PRODUCT_LOCALES))" \
    123 			PRODUCT_DEFAULT_REGION="$(call default-locale-region,$(PRODUCT_LOCALES))" \
    124 			PRODUCT_DEFAULT_WIFI_CHANNELS="$(PRODUCT_DEFAULT_WIFI_CHANNELS)" \
    125 			PRODUCT_MODEL="$(PRODUCT_MODEL)" \
    126 			PRODUCT_MANUFACTURER="$(PRODUCT_MANUFACTURER)" \
    127 			PRIVATE_BUILD_DESC="$(PRIVATE_BUILD_DESC)" \
    128 			BUILD_ID="$(BUILD_ID)" \
    129 			BUILD_DISPLAY_ID="$(BUILD_DISPLAY_ID)" \
    130 			BUILD_NUMBER="$(BUILD_NUMBER)" \
    131 			PLATFORM_VERSION="$(PLATFORM_VERSION)" \
    132 			PLATFORM_SDK_VERSION="$(PLATFORM_SDK_VERSION)" \
    133 			PLATFORM_VERSION_CODENAME="$(PLATFORM_VERSION_CODENAME)" \
    134 			BUILD_VERSION_TAGS="$(BUILD_VERSION_TAGS)" \
    135 			TARGET_BOOTLOADER_BOARD_NAME="$(TARGET_BOOTLOADER_BOARD_NAME)" \
    136 			BUILD_FINGERPRINT="$(BUILD_FINGERPRINT)" \
    137 			TARGET_BOARD_PLATFORM="$(TARGET_BOARD_PLATFORM)" \
    138 			TARGET_CPU_ABI="$(TARGET_CPU_ABI)" \
    139 			TARGET_CPU_ABI2="$(TARGET_CPU_ABI2)" \
    140 	        bash $(BUILDINFO_SH) > $@
    141 	$(hide) if [ -f $(TARGET_DEVICE_DIR)/system.prop ]; then \
    142 	          cat $(TARGET_DEVICE_DIR)/system.prop >> $@; \
    143 	        fi
    144 	$(if $(ADDITIONAL_BUILD_PROPERTIES), \
    145 		$(hide) echo >> $@; \
    146 		        echo "#" >> $@; \
    147 		        echo "# ADDITIONAL_BUILD_PROPERTIES" >> $@; \
    148 		        echo "#" >> $@; )
    149 	$(hide) $(foreach line,$(ADDITIONAL_BUILD_PROPERTIES), \
    150 		echo "$(line)" >> $@;)
    151 
    152 build_desc :=
    153 
    154 # -----------------------------------------------------------------
    155 # sdk-build.prop
    156 #
    157 # There are certain things in build.prop that we don't want to
    158 # ship with the sdk; remove them.
    159 
    160 # This must be a list of entire property keys followed by
    161 # "=" characters, without any internal spaces.
    162 sdk_build_prop_remove := \
    163 	ro.build.user= \
    164 	ro.build.host= \
    165 	ro.product.brand= \
    166 	ro.product.manufacturer= \
    167 	ro.product.device=
    168 # TODO: Remove this soon-to-be obsolete property
    169 sdk_build_prop_remove += ro.build.product=
    170 INSTALLED_SDK_BUILD_PROP_TARGET := $(PRODUCT_OUT)/sdk/sdk-build.prop
    171 $(INSTALLED_SDK_BUILD_PROP_TARGET): $(INSTALLED_BUILD_PROP_TARGET)
    172 	@echo SDK buildinfo: $@
    173 	@mkdir -p $(dir $@)
    174 	$(hide) grep -v "$(subst $(space),\|,$(strip \
    175 				$(sdk_build_prop_remove)))" $< > $@.tmp
    176 	$(hide) for x in $(sdk_build_prop_remove); do \
    177 				echo "$$x"generic >> $@.tmp; done
    178 	$(hide) mv $@.tmp $@
    179 
    180 # -----------------------------------------------------------------
    181 # package stats
    182 PACKAGE_STATS_FILE := $(PRODUCT_OUT)/package-stats.txt
    183 PACKAGES_TO_STAT := \
    184     $(sort $(filter $(TARGET_OUT)/% $(TARGET_OUT_DATA)/%, \
    185 	$(filter %.jar %.apk, $(ALL_DEFAULT_INSTALLED_MODULES))))
    186 $(PACKAGE_STATS_FILE): $(PACKAGES_TO_STAT)
    187 	@echo Package stats: $@
    188 	@mkdir -p $(dir $@)
    189 	$(hide) rm -f $@
    190 	$(hide) build/tools/dump-package-stats $^ > $@
    191 
    192 .PHONY: package-stats
    193 package-stats: $(PACKAGE_STATS_FILE)
    194 
    195 # -----------------------------------------------------------------
    196 # Cert-to-package mapping.  Used by the post-build signing tools.
    197 name := $(TARGET_PRODUCT)
    198 ifeq ($(TARGET_BUILD_TYPE),debug)
    199   name := $(name)_debug
    200 endif
    201 name := $(name)-apkcerts-$(FILE_NAME_TAG)
    202 intermediates := \
    203 	$(call intermediates-dir-for,PACKAGING,apkcerts)
    204 APKCERTS_FILE := $(intermediates)/$(name).txt
    205 # Depending on the built packages isn't exactly right,
    206 # but it should guarantee that the apkcerts file is rebuilt
    207 # if any packages change which certs they're signed with.
    208 all_built_packages := $(foreach p,$(PACKAGES),$(ALL_MODULES.$(p).BUILT))
    209 ifneq ($(TARGET_BUILD_APPS),)
    210 # We don't need to really build all the modules for apps_only build.
    211 $(APKCERTS_FILE):
    212 else
    213 $(APKCERTS_FILE): $(all_built_packages)
    214 endif
    215 	@echo APK certs list: $@
    216 	@mkdir -p $(dir $@)
    217 	@rm -f $@
    218 	$(hide) $(foreach p,$(PACKAGES),\
    219           $(if $(PACKAGES.$(p).EXTERNAL_KEY),\
    220 	    echo 'name="$(p).apk" certificate="EXTERNAL" \
    221 	         private_key=""' >> $@;,\
    222 	    echo 'name="$(p).apk" certificate="$(PACKAGES.$(p).CERTIFICATE)" \
    223 	         private_key="$(PACKAGES.$(p).PRIVATE_KEY)"' >> $@;))
    224 
    225 .PHONY: apkcerts-list
    226 apkcerts-list: $(APKCERTS_FILE)
    227 
    228 $(call dist-for-goals, apps_only, $(APKCERTS_FILE):apkcerts.txt)
    229 
    230 # -----------------------------------------------------------------
    231 # module info file
    232 ifdef CREATE_MODULE_INFO_FILE
    233   MODULE_INFO_FILE := $(PRODUCT_OUT)/module-info.txt
    234   $(info Generating $(MODULE_INFO_FILE)...)
    235   $(shell rm -f $(MODULE_INFO_FILE))
    236   $(foreach m,$(ALL_MODULES), \
    237     $(shell echo "NAME=\"$(m)\"" \
    238 	"PATH=\"$(strip $(ALL_MODULES.$(m).PATH))\"" \
    239 	"TAGS=\"$(strip $(filter-out _%,$(ALL_MODULES.$(m).TAGS)))\"" \
    240 	"BUILT=\"$(strip $(ALL_MODULES.$(m).BUILT))\"" \
    241 	"INSTALLED=\"$(strip $(ALL_MODULES.$(m).INSTALLED))\"" >> $(MODULE_INFO_FILE)))
    242 endif
    243 
    244 # -----------------------------------------------------------------
    245 
    246 # The test key is used to sign this package, and as the key required
    247 # for future OTA packages installed by this system.  Actual product
    248 # deliverables will be re-signed by hand.  We expect this file to
    249 # exist with the suffixes ".x509.pem" and ".pk8".
    250 DEFAULT_KEY_CERT_PAIR := $(SRC_TARGET_DIR)/product/security/testkey
    251 
    252 
    253 # Rules that need to be present for the simulator, even
    254 # if they don't do anything.
    255 .PHONY: systemimage
    256 systemimage:
    257 
    258 # -----------------------------------------------------------------
    259 
    260 .PHONY: event-log-tags
    261 
    262 # Produce an event logs tag file for everything we know about, in order
    263 # to properly allocate numbers.  Then produce a file that's filtered
    264 # for what's going to be installed.
    265 
    266 all_event_log_tags_file := $(TARGET_OUT_COMMON_INTERMEDIATES)/all-event-log-tags.txt
    267 
    268 # Include tags from all packages that we know about
    269 all_event_log_tags_src := \
    270     $(sort $(foreach m, $(ALL_MODULES), $(ALL_MODULES.$(m).EVENT_LOG_TAGS)))
    271 
    272 $(all_event_log_tags_file): PRIVATE_SRC_FILES := $(all_event_log_tags_src)
    273 $(all_event_log_tags_file): $(all_event_log_tags_src)
    274 	$(hide) mkdir -p $(dir $@)
    275 	$(hide) build/tools/merge-event-log-tags.py -o $@ $(PRIVATE_SRC_FILES)
    276 
    277 
    278 event_log_tags_file := $(TARGET_OUT)/etc/event-log-tags
    279 
    280 # Include tags from all packages included in this product.
    281 event_log_tags_src := \
    282     $(sort $(foreach m,\
    283       $(PRODUCTS.$(INTERNAL_PRODUCT).PRODUCT_PACKAGES) \
    284       $(call module-names-for-tag-list,user), \
    285       $(ALL_MODULES.$(m).EVENT_LOG_TAGS)))
    286 
    287 $(event_log_tags_file): PRIVATE_SRC_FILES := $(event_log_tags_src)
    288 $(event_log_tags_file): PRIVATE_MERGED_FILE := $(all_event_log_tags_file)
    289 $(event_log_tags_file): $(event_log_tags_src) $(all_event_log_tags_file)
    290 	$(hide) mkdir -p $(dir $@)
    291 	$(hide) build/tools/merge-event-log-tags.py -o $@ -m $(PRIVATE_MERGED_FILE) $(PRIVATE_SRC_FILES)
    292 
    293 event-log-tags: $(event_log_tags_file)
    294 
    295 ALL_DEFAULT_INSTALLED_MODULES += $(event_log_tags_file)
    296 
    297 
    298 ifneq ($(TARGET_SIMULATOR),true)
    299 
    300 # #################################################################
    301 # Targets for boot/OS images
    302 # #################################################################
    303 
    304 # -----------------------------------------------------------------
    305 # the ramdisk
    306 INTERNAL_RAMDISK_FILES := $(filter $(TARGET_ROOT_OUT)/%, \
    307 	$(ALL_PREBUILT) \
    308 	$(ALL_COPIED_HEADERS) \
    309 	$(ALL_GENERATED_SOURCES) \
    310 	$(ALL_DEFAULT_INSTALLED_MODULES))
    311 
    312 BUILT_RAMDISK_TARGET := $(PRODUCT_OUT)/ramdisk.img
    313 
    314 # We just build this directly to the install location.
    315 INSTALLED_RAMDISK_TARGET := $(BUILT_RAMDISK_TARGET)
    316 $(INSTALLED_RAMDISK_TARGET): $(MKBOOTFS) $(INTERNAL_RAMDISK_FILES) | $(MINIGZIP)
    317 	$(call pretty,"Target ram disk: $@")
    318 	$(hide) $(MKBOOTFS) $(TARGET_ROOT_OUT) | $(MINIGZIP) > $@
    319 
    320 
    321 ifneq ($(strip $(TARGET_NO_KERNEL)),true)
    322 
    323 # -----------------------------------------------------------------
    324 # the boot image, which is a collection of other images.
    325 INTERNAL_BOOTIMAGE_ARGS := \
    326 	$(addprefix --second ,$(INSTALLED_2NDBOOTLOADER_TARGET)) \
    327 	--kernel $(INSTALLED_KERNEL_TARGET) \
    328 	--ramdisk $(INSTALLED_RAMDISK_TARGET)
    329 
    330 INTERNAL_BOOTIMAGE_FILES := $(filter-out --%,$(INTERNAL_BOOTIMAGE_ARGS))
    331 
    332 BOARD_KERNEL_CMDLINE := $(strip $(BOARD_KERNEL_CMDLINE))
    333 ifdef BOARD_KERNEL_CMDLINE
    334   INTERNAL_BOOTIMAGE_ARGS += --cmdline "$(BOARD_KERNEL_CMDLINE)"
    335 endif
    336 
    337 BOARD_KERNEL_BASE := $(strip $(BOARD_KERNEL_BASE))
    338 ifdef BOARD_KERNEL_BASE
    339   INTERNAL_BOOTIMAGE_ARGS += --base $(BOARD_KERNEL_BASE)
    340 endif
    341 
    342 BOARD_KERNEL_PAGESIZE := $(strip $(BOARD_KERNEL_PAGESIZE))
    343 ifdef BOARD_KERNEL_PAGESIZE
    344   INTERNAL_BOOTIMAGE_ARGS += --pagesize $(BOARD_KERNEL_PAGESIZE)
    345 endif
    346 
    347 INSTALLED_BOOTIMAGE_TARGET := $(PRODUCT_OUT)/boot.img
    348 
    349 ifeq ($(TARGET_BOOTIMAGE_USE_EXT2),true)
    350 tmp_dir_for_image := $(call intermediates-dir-for,EXECUTABLES,boot_img)/bootimg
    351 INTERNAL_BOOTIMAGE_ARGS += --tmpdir $(tmp_dir_for_image)
    352 INTERNAL_BOOTIMAGE_ARGS += --genext2fs $(MKEXT2IMG)
    353 $(INSTALLED_BOOTIMAGE_TARGET): $(MKEXT2IMG) $(INTERNAL_BOOTIMAGE_FILES)
    354 	$(call pretty,"Target boot image: $@")
    355 	$(hide) $(MKEXT2BOOTIMG) $(INTERNAL_BOOTIMAGE_ARGS) --output $@
    356 
    357 else # TARGET_BOOTIMAGE_USE_EXT2 != true
    358 
    359 $(INSTALLED_BOOTIMAGE_TARGET): $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_FILES)
    360 	$(call pretty,"Target boot image: $@")
    361 	$(hide) $(MKBOOTIMG) $(INTERNAL_BOOTIMAGE_ARGS) --output $@
    362 	$(hide) $(call assert-max-image-size,$@,$(BOARD_BOOTIMAGE_PARTITION_SIZE),raw)
    363 endif # TARGET_BOOTIMAGE_USE_EXT2
    364 
    365 else	# TARGET_NO_KERNEL
    366 # HACK: The top-level targets depend on the bootimage.  Not all targets
    367 # can produce a bootimage, though, and emulator targets need the ramdisk
    368 # instead.  Fake it out by calling the ramdisk the bootimage.
    369 # TODO: make the emulator use bootimages, and make mkbootimg accept
    370 #       kernel-less inputs.
    371 INSTALLED_BOOTIMAGE_TARGET := $(INSTALLED_RAMDISK_TARGET)
    372 endif
    373 
    374 # -----------------------------------------------------------------
    375 # NOTICE files
    376 #
    377 # This needs to be before the systemimage rules, because it adds to
    378 # ALL_DEFAULT_INSTALLED_MODULES, which those use to pick which files
    379 # go into the systemimage.
    380 
    381 .PHONY: notice_files
    382 
    383 # Create the rule to combine the files into text and html forms
    384 # $(1) - Plain text output file
    385 # $(2) - HTML output file
    386 # $(3) - File title
    387 # $(4) - Directory to use.  Notice files are all $(4)/src.  Other
    388 #		 directories in there will be used for scratch
    389 # $(5) - Dependencies for the output files
    390 #
    391 # The algorithm here is that we go collect a hash for each of the notice
    392 # files and write the names of the files that match that hash.  Then
    393 # to generate the real files, we go print out all of the files and their
    394 # hashes.
    395 #
    396 # These rules are fairly complex, so they depend on this makefile so if
    397 # it changes, they'll run again.
    398 #
    399 # TODO: We could clean this up so that we just record the locations of the
    400 # original notice files instead of making rules to copy them somwehere.
    401 # Then we could traverse that without quite as much bash drama.
    402 define combine-notice-files
    403 $(1) $(2): PRIVATE_MESSAGE := $(3)
    404 $(1) $(2) $(4)/hash-timestamp: PRIVATE_DIR := $(4)
    405 $(4)/hash-timestamp: $(5) $(BUILD_SYSTEM)/Makefile
    406 	@echo Finding NOTICE files: $$@
    407 	$$(hide) rm -rf $$@ $$(PRIVATE_DIR)/hash
    408 	$$(hide) mkdir -p $$(PRIVATE_DIR)/hash
    409 	$$(hide) for file in $$$$(find $$(PRIVATE_DIR)/src -type f); do \
    410 			hash=$$$$($(MD5SUM) $$$$file | sed -e "s/ .*//"); \
    411 			hashfile=$$(PRIVATE_DIR)/hash/$$$$hash; \
    412 			echo $$$$file >> $$$$hashfile; \
    413 		done
    414 	$$(hide) touch $$@
    415 $(1): $(4)/hash-timestamp
    416 	@echo Combining NOTICE files: $$@
    417 	$$(hide) mkdir -p $$(dir $$@)
    418 	$$(hide) echo $$(PRIVATE_MESSAGE) > $$@
    419 	$$(hide) find $$(PRIVATE_DIR)/hash -type f | xargs cat | sort | \
    420 		sed -e "s:$$(PRIVATE_DIR)/src\(.*\)\.txt:  \1:" >> $$@
    421 	$$(hide) echo >> $$@
    422 	$$(hide) echo >> $$@
    423 	$$(hide) echo >> $$@
    424 	$$(hide) for hashfile in $$$$(find $$(PRIVATE_DIR)/hash -type f); do \
    425 			echo "============================================================"\
    426 				>> $$@; \
    427 			echo "Notices for file(s):" >> $$@; \
    428 			cat $$$$hashfile | sort | \
    429 				sed -e "s:$$(PRIVATE_DIR)/src\(.*\)\.txt:  \1:" >> \
    430 				$$@; \
    431 			echo "------------------------------------------------------------"\
    432 				>> $$@; \
    433 			echo >> $$@; \
    434 			orig=$$$$(head -n 1 $$$$hashfile); \
    435 			cat $$$$orig >> $$@; \
    436 			echo >> $$@; \
    437 			echo >> $$@; \
    438 			echo >> $$@; \
    439 		done
    440 $(2): $(4)/hash-timestamp
    441 	@echo Combining NOTICE files: $$@
    442 	$$(hide) mkdir -p $$(dir $$@)
    443 	$$(hide) echo "<html><head>" > $$@
    444 	$$(hide) echo "<style type=\"text/css\">" >> $$@
    445 	$$(hide) echo "body { padding: 0; font-family: sans-serif; }" >> $$@
    446 	$$(hide) echo ".same-license { background-color: #eeeeee; border-top: 20px solid white; padding: 10px; }" >> $$@
    447 	$$(hide) echo ".label { font-weight: bold; }" >> $$@
    448 	$$(hide) echo ".file-list { margin-left: 1em; font-color: blue; }" >> $$@
    449 	$$(hide) echo "</style>" >> $$@
    450 	$$(hide) echo "</head><body topmargin=\"0\" leftmargin=\"0\" rightmargin=\"0\" bottommargin=\"0\">" >> $$@
    451 	$$(hide) echo "<table cellpading=\"0\" cellspacing=\"0\" border=\"0\">" \
    452 		>> $$@
    453 	$$(hide) for hashfile in $$$$(find $$(PRIVATE_DIR)/hash -type f); do \
    454 			cat $$$$hashfile | sort | \
    455 				sed -e "s:$$(PRIVATE_DIR)/src\(.*\)\.txt:  <a name=\"\1\"></a>:" >> \
    456 				$$@; \
    457 			echo "<tr><td class=\"same-license\">" >> $$@; \
    458 			echo "<div class=\"label\">Notices for file(s):</div>" >> $$@; \
    459 			echo "<div class=\"file-list\">" >> $$@; \
    460 			cat $$$$hashfile | sort | \
    461 				sed -e "s:$$(PRIVATE_DIR)/src\(.*\)\.txt:  \1<br/>:" >> $$@; \
    462 			echo "</div><!-- file-list -->" >> $$@; \
    463 			echo >> $$@; \
    464 			orig=$$$$(head -n 1 $$$$hashfile); \
    465 			echo "<pre class=\"license-text\">" >> $$@; \
    466 			cat $$$$orig | sed -e "s/\&/\&amp;/g" | sed -e "s/</\&lt;/g" \
    467 					| sed -e "s/>/\&gt;/g" >> $$@; \
    468 			echo "</pre><!-- license-text -->" >> $$@; \
    469 			echo "</td></tr><!-- same-license -->" >> $$@; \
    470 			echo >> $$@; \
    471 			echo >> $$@; \
    472 			echo >> $$@; \
    473 		done
    474 	$$(hide) echo "</table>" >> $$@
    475 	$$(hide) echo "</body></html>" >> $$@
    476 notice_files: $(1) $(2)
    477 endef
    478 
    479 # TODO These intermediate NOTICE.txt/NOTICE.html files should go into
    480 # TARGET_OUT_NOTICE_FILES now that the notice files are gathered from
    481 # the src subdirectory.
    482 
    483 target_notice_file_txt := $(TARGET_OUT_INTERMEDIATES)/NOTICE.txt
    484 target_notice_file_html := $(TARGET_OUT_INTERMEDIATES)/NOTICE.html
    485 target_notice_file_html_gz := $(TARGET_OUT_INTERMEDIATES)/NOTICE.html.gz
    486 tools_notice_file_txt := $(HOST_OUT_INTERMEDIATES)/NOTICE.txt
    487 tools_notice_file_html := $(HOST_OUT_INTERMEDIATES)/NOTICE.html
    488 
    489 kernel_notice_file := $(TARGET_OUT_NOTICE_FILES)/src/kernel.txt
    490 
    491 $(eval $(call combine-notice-files, \
    492 			$(target_notice_file_txt), \
    493 			$(target_notice_file_html), \
    494 			"Notices for files contained in the filesystem images in this directory:", \
    495 			$(TARGET_OUT_NOTICE_FILES), \
    496 			$(ALL_DEFAULT_INSTALLED_MODULES) $(kernel_notice_file)))
    497 
    498 $(eval $(call combine-notice-files, \
    499 			$(tools_notice_file_txt), \
    500 			$(tools_notice_file_html), \
    501 			"Notices for files contained in the tools directory:", \
    502 			$(HOST_OUT_NOTICE_FILES), \
    503 			$(ALL_DEFAULT_INSTALLED_MODULES)))
    504 
    505 # Install the html file at /system/etc/NOTICE.html.gz.
    506 # This is not ideal, but this is very late in the game, after a lot of
    507 # the module processing has already been done -- in fact, we used the
    508 # fact that all that has been done to get the list of modules that we
    509 # need notice files for.
    510 $(target_notice_file_html_gz): $(target_notice_file_html) | $(MINIGZIP)
    511 	$(hide) $(MINIGZIP) -9 < $< > $@
    512 installed_notice_html_gz := $(TARGET_OUT)/etc/NOTICE.html.gz
    513 $(installed_notice_html_gz): $(target_notice_file_html_gz) | $(ACP)
    514 	$(copy-file-to-target)
    515 
    516 # if we've been run my mm, mmm, etc, don't reinstall this every time
    517 ifeq ($(ONE_SHOT_MAKEFILE),)
    518 ALL_DEFAULT_INSTALLED_MODULES += $(installed_notice_html_gz)
    519 endif
    520 
    521 # The kernel isn't really a module, so to get its module file in there, we
    522 # make the target NOTICE files depend on this particular file too, which will
    523 # then be in the right directory for the find in combine-notice-files to work.
    524 $(kernel_notice_file): \
    525 	    prebuilt/$(TARGET_PREBUILT_TAG)/kernel/LINUX_KERNEL_COPYING \
    526 	    | $(ACP)
    527 	@echo Copying: $@
    528 	$(hide) mkdir -p $(dir $@)
    529 	$(hide) $(ACP) $< $@
    530 
    531 
    532 # -----------------------------------------------------------------
    533 # Build a keystore with the authorized keys in it, used to verify the
    534 # authenticity of downloaded OTA packages.
    535 #
    536 # This rule adds to ALL_DEFAULT_INSTALLED_MODULES, so it needs to come
    537 # before the rules that use that variable to build the image.
    538 ALL_DEFAULT_INSTALLED_MODULES += $(TARGET_OUT_ETC)/security/otacerts.zip
    539 $(TARGET_OUT_ETC)/security/otacerts.zip: KEY_CERT_PAIR := $(DEFAULT_KEY_CERT_PAIR)
    540 $(TARGET_OUT_ETC)/security/otacerts.zip: $(addsuffix .x509.pem,$(DEFAULT_KEY_CERT_PAIR))
    541 	$(hide) rm -f $@
    542 	$(hide) mkdir -p $(dir $@)
    543 	$(hide) zip -qj $@ $<
    544 
    545 .PHONY: otacerts
    546 otacerts: $(TARGET_OUT_ETC)/security/otacerts.zip
    547 
    548 
    549 # #################################################################
    550 # Targets for user images
    551 # #################################################################
    552 
    553 INTERNAL_USERIMAGES_EXT_VARIANT :=
    554 ifeq ($(TARGET_USERIMAGES_USE_EXT2),true)
    555 INTERNAL_USERIMAGES_USE_EXT := true
    556 INTERNAL_USERIMAGES_EXT_VARIANT := ext2
    557 else
    558 ifeq ($(TARGET_USERIMAGES_USE_EXT3),true)
    559 INTERNAL_USERIMAGES_USE_EXT := true
    560 INTERNAL_USERIMAGES_EXT_VARIANT := ext3
    561 else
    562 ifeq ($(TARGET_USERIMAGES_USE_EXT4),true)
    563 INTERNAL_USERIMAGES_USE_EXT := true
    564 INTERNAL_USERIMAGES_EXT_VARIANT := ext4
    565 endif
    566 endif
    567 endif
    568 
    569 ifeq ($(INTERNAL_USERIMAGES_USE_EXT),true)
    570 INTERNAL_USERIMAGES_DEPS := $(MKEXT2USERIMG) $(MAKE_EXT4FS)
    571 INTERNAL_USERIMAGES_BINARY_PATHS := $(sort $(dir $(INTERNAL_USERIMAGES_DEPS)))
    572 
    573 # $(1): src directory
    574 # $(2): output file
    575 # $(3): mount point
    576 # $(4): ext variant (ext2, ext3, ext4)
    577 # $(5): size of the partition
    578 define build-userimage-ext-target
    579   @mkdir -p $(dir $(2))
    580     $(hide) PATH=$(foreach p,$(INTERNAL_USERIMAGES_BINARY_PATHS),$(p):)$(PATH) \
    581 	  $(MKEXT2USERIMG) $(1) $(2) $(4) $(3) $(5)
    582 endef
    583 else
    584 INTERNAL_USERIMAGES_DEPS := $(MKYAFFS2)
    585 endif
    586 
    587 # -----------------------------------------------------------------
    588 # Recovery image
    589 
    590 # If neither TARGET_NO_KERNEL nor TARGET_NO_RECOVERY are true
    591 ifeq (,$(filter true, $(TARGET_NO_KERNEL) $(TARGET_NO_RECOVERY) $(BUILD_TINY_ANDROID)))
    592 
    593 INSTALLED_RECOVERYIMAGE_TARGET := $(PRODUCT_OUT)/recovery.img
    594 
    595 recovery_initrc := $(call include-path-for, recovery)/etc/init.rc
    596 recovery_kernel := $(INSTALLED_KERNEL_TARGET) # same as a non-recovery system
    597 recovery_ramdisk := $(PRODUCT_OUT)/ramdisk-recovery.img
    598 recovery_build_prop := $(INSTALLED_BUILD_PROP_TARGET)
    599 recovery_binary := $(call intermediates-dir-for,EXECUTABLES,recovery)/recovery
    600 recovery_resources_common := $(call include-path-for, recovery)/res
    601 recovery_resources_private := $(strip $(wildcard $(TARGET_DEVICE_DIR)/recovery/res))
    602 recovery_resource_deps := $(shell find $(recovery_resources_common) \
    603   $(recovery_resources_private) -type f)
    604 recovery_fstab := $(strip $(wildcard $(TARGET_DEVICE_DIR)/recovery.fstab))
    605 
    606 ifeq ($(recovery_resources_private),)
    607   $(info No private recovery resources for TARGET_DEVICE $(TARGET_DEVICE))
    608 endif
    609 
    610 ifeq ($(recovery_fstab),)
    611   $(info No recovery.fstab for TARGET_DEVICE $(TARGET_DEVICE))
    612 endif
    613 
    614 INTERNAL_RECOVERYIMAGE_ARGS := \
    615 	$(addprefix --second ,$(INSTALLED_2NDBOOTLOADER_TARGET)) \
    616 	--kernel $(recovery_kernel) \
    617 	--ramdisk $(recovery_ramdisk)
    618 
    619 # Assumes this has already been stripped
    620 ifdef BOARD_KERNEL_CMDLINE
    621   INTERNAL_RECOVERYIMAGE_ARGS += --cmdline "$(BOARD_KERNEL_CMDLINE)"
    622 endif
    623 ifdef BOARD_KERNEL_BASE
    624   INTERNAL_RECOVERYIMAGE_ARGS += --base $(BOARD_KERNEL_BASE)
    625 endif
    626 BOARD_KERNEL_PAGESIZE := $(strip $(BOARD_KERNEL_PAGESIZE))
    627 ifdef BOARD_KERNEL_PAGESIZE
    628   INTERNAL_RECOVERYIMAGE_ARGS += --pagesize $(BOARD_KERNEL_PAGESIZE)
    629 endif
    630 
    631 # Keys authorized to sign OTA packages this build will accept.  The
    632 # build always uses test-keys for this; release packaging tools will
    633 # substitute other keys for this one.
    634 OTA_PUBLIC_KEYS := $(SRC_TARGET_DIR)/product/security/testkey.x509.pem
    635 
    636 # Generate a file containing the keys that will be read by the
    637 # recovery binary.
    638 RECOVERY_INSTALL_OTA_KEYS := \
    639 	$(call intermediates-dir-for,PACKAGING,ota_keys)/keys
    640 DUMPKEY_JAR := $(HOST_OUT_JAVA_LIBRARIES)/dumpkey.jar
    641 $(RECOVERY_INSTALL_OTA_KEYS): PRIVATE_OTA_PUBLIC_KEYS := $(OTA_PUBLIC_KEYS)
    642 $(RECOVERY_INSTALL_OTA_KEYS): $(OTA_PUBLIC_KEYS) $(DUMPKEY_JAR)
    643 	@echo "DumpPublicKey: $@ <= $(PRIVATE_OTA_PUBLIC_KEYS)"
    644 	@rm -rf $@
    645 	@mkdir -p $(dir $@)
    646 	java -jar $(DUMPKEY_JAR) $(PRIVATE_OTA_PUBLIC_KEYS) > $@
    647 
    648 $(INSTALLED_RECOVERYIMAGE_TARGET): $(MKBOOTFS) $(MKBOOTIMG) $(MINIGZIP) \
    649 		$(INSTALLED_RAMDISK_TARGET) \
    650 		$(INSTALLED_BOOTIMAGE_TARGET) \
    651 		$(recovery_binary) \
    652 		$(recovery_initrc) $(recovery_kernel) \
    653 		$(INSTALLED_2NDBOOTLOADER_TARGET) \
    654 		$(recovery_build_prop) $(recovery_resource_deps) \
    655 		$(recovery_fstab) \
    656 		$(RECOVERY_INSTALL_OTA_KEYS)
    657 	@echo ----- Making recovery image ------
    658 	rm -rf $(TARGET_RECOVERY_OUT)
    659 	mkdir -p $(TARGET_RECOVERY_OUT)
    660 	mkdir -p $(TARGET_RECOVERY_ROOT_OUT)
    661 	mkdir -p $(TARGET_RECOVERY_ROOT_OUT)/etc
    662 	mkdir -p $(TARGET_RECOVERY_ROOT_OUT)/tmp
    663 	echo Copying baseline ramdisk...
    664 	cp -R $(TARGET_ROOT_OUT) $(TARGET_RECOVERY_OUT)
    665 	rm $(TARGET_RECOVERY_ROOT_OUT)/init*.rc
    666 	echo Modifying ramdisk contents...
    667 	cp -f $(recovery_initrc) $(TARGET_RECOVERY_ROOT_OUT)/
    668 	cp -f $(recovery_binary) $(TARGET_RECOVERY_ROOT_OUT)/sbin/
    669 	cp -rf $(recovery_resources_common) $(TARGET_RECOVERY_ROOT_OUT)/
    670 	$(foreach item,$(recovery_resources_private), \
    671 	  cp -rf $(item) $(TARGET_RECOVERY_ROOT_OUT)/)
    672 	$(foreach item,$(recovery_fstab), \
    673 	  cp -f $(item) $(TARGET_RECOVERY_ROOT_OUT)/etc/recovery.fstab)
    674 	cp $(RECOVERY_INSTALL_OTA_KEYS) $(TARGET_RECOVERY_ROOT_OUT)/res/keys
    675 	cat $(INSTALLED_DEFAULT_PROP_TARGET) $(recovery_build_prop) \
    676 	        > $(TARGET_RECOVERY_ROOT_OUT)/default.prop
    677 	$(MKBOOTFS) $(TARGET_RECOVERY_ROOT_OUT) | $(MINIGZIP) > $(recovery_ramdisk)
    678 	$(MKBOOTIMG) $(INTERNAL_RECOVERYIMAGE_ARGS) --output $@
    679 	@echo ----- Made recovery image -------- $@
    680 	$(hide) $(call assert-max-image-size,$@,$(BOARD_RECOVERYIMAGE_PARTITION_SIZE),raw)
    681 
    682 else
    683 INSTALLED_RECOVERYIMAGE_TARGET :=
    684 endif
    685 
    686 .PHONY: recoveryimage
    687 recoveryimage: $(INSTALLED_RECOVERYIMAGE_TARGET)
    688 
    689 ifneq ($(BOARD_NAND_PAGE_SIZE),)
    690 mkyaffs2_extra_flags := -c $(BOARD_NAND_PAGE_SIZE)
    691 else
    692 mkyaffs2_extra_flags :=
    693 endif
    694 
    695 
    696 # -----------------------------------------------------------------
    697 # system image
    698 #
    699 systemimage_intermediates := \
    700 	$(call intermediates-dir-for,PACKAGING,systemimage)
    701 BUILT_SYSTEMIMAGE := $(systemimage_intermediates)/system.img
    702 
    703 INTERNAL_SYSTEMIMAGE_FILES := $(filter $(TARGET_OUT)/%, \
    704 	$(ALL_PREBUILT) \
    705 	$(ALL_COPIED_HEADERS) \
    706 	$(ALL_GENERATED_SOURCES) \
    707 	$(ALL_DEFAULT_INSTALLED_MODULES))
    708 
    709 ifeq ($(INTERNAL_USERIMAGES_USE_EXT),true)
    710 ## generate an ext2 image
    711 # $(1): output file
    712 define build-systemimage-target
    713     @echo "Target system fs image: $(1)"
    714     $(call build-userimage-ext-target,$(TARGET_OUT),$(1),system,$(INTERNAL_USERIMAGES_EXT_VARIANT),$(BOARD_SYSTEMIMAGE_PARTITION_SIZE))
    715 endef
    716 
    717 else # INTERNAL_USERIMAGES_USE_EXT != true
    718 
    719 ## generate a yaffs2 image
    720 # $(1): output file
    721 define build-systemimage-target
    722     @echo "Target system fs image: $(1)"
    723     @mkdir -p $(dir $(1))
    724     $(hide) $(MKYAFFS2) -f $(mkyaffs2_extra_flags) $(TARGET_OUT) $(1)
    725 endef
    726 endif # INTERNAL_USERIMAGES_USE_EXT
    727 
    728 $(BUILT_SYSTEMIMAGE): $(INTERNAL_SYSTEMIMAGE_FILES) $(INTERNAL_USERIMAGES_DEPS)
    729 	$(call build-systemimage-target,$@)
    730 
    731 INSTALLED_SYSTEMIMAGE := $(PRODUCT_OUT)/system.img
    732 SYSTEMIMAGE_SOURCE_DIR := $(TARGET_OUT)
    733 
    734 # The system partition needs room for the recovery image as well.  We
    735 # now store the recovery image as a binary patch using the boot image
    736 # as the source (since they are very similar).  Generate the patch so
    737 # we can see how big it's going to be, and include that in the system
    738 # image size check calculation.
    739 ifneq ($(INSTALLED_RECOVERYIMAGE_TARGET),)
    740 intermediates := $(call intermediates-dir-for,PACKAGING,recovery_patch)
    741 RECOVERY_FROM_BOOT_PATCH := $(intermediates)/recovery_from_boot.p
    742 $(RECOVERY_FROM_BOOT_PATCH): $(INSTALLED_RECOVERYIMAGE_TARGET) \
    743                              $(INSTALLED_BOOTIMAGE_TARGET) \
    744 			     $(HOST_OUT_EXECUTABLES)/imgdiff \
    745 	                     $(HOST_OUT_EXECUTABLES)/bsdiff
    746 	@echo "Construct recovery from boot"
    747 	mkdir -p $(dir $@)
    748 	PATH=$(HOST_OUT_EXECUTABLES):$$PATH $(HOST_OUT_EXECUTABLES)/imgdiff $(INSTALLED_BOOTIMAGE_TARGET) $(INSTALLED_RECOVERYIMAGE_TARGET) $@
    749 endif
    750 
    751 
    752 $(INSTALLED_SYSTEMIMAGE): $(BUILT_SYSTEMIMAGE) $(RECOVERY_FROM_BOOT_PATCH) | $(ACP)
    753 	@echo "Install system fs image: $@"
    754 	$(copy-file-to-target)
    755 	$(hide) $(call assert-max-image-size,$@ $(RECOVERY_FROM_BOOT_PATCH),$(BOARD_SYSTEMIMAGE_PARTITION_SIZE),yaffs)
    756 
    757 systemimage: $(INSTALLED_SYSTEMIMAGE)
    758 
    759 .PHONY: systemimage-nodeps snod
    760 systemimage-nodeps snod: $(filter-out systemimage-nodeps snod,$(MAKECMDGOALS)) \
    761 	            | $(INTERNAL_USERIMAGES_DEPS)
    762 	@echo "make $@: ignoring dependencies"
    763 	$(call build-systemimage-target,$(INSTALLED_SYSTEMIMAGE))
    764 	$(hide) $(call assert-max-image-size,$(INSTALLED_SYSTEMIMAGE),$(BOARD_SYSTEMIMAGE_PARTITION_SIZE),yaffs)
    765 
    766 #######
    767 ## system tarball
    768 define build-systemtarball-target
    769     $(call pretty,"Target system fs tarball: $(INSTALLED_SYSTEMTARBALL_TARGET)")
    770     $(MKTARBALL) $(FS_GET_STATS) \
    771 		$(PRODUCT_OUT) system $(PRIVATE_SYSTEM_TAR) \
    772 		$(INSTALLED_SYSTEMTARBALL_TARGET)
    773 endef
    774 
    775 system_tar := $(PRODUCT_OUT)/system.tar
    776 INSTALLED_SYSTEMTARBALL_TARGET := $(system_tar).bz2
    777 $(INSTALLED_SYSTEMTARBALL_TARGET): PRIVATE_SYSTEM_TAR := $(system_tar)
    778 $(INSTALLED_SYSTEMTARBALL_TARGET): $(FS_GET_STATS) $(INTERNAL_SYSTEMIMAGE_FILES)
    779 	$(build-systemtarball-target)
    780 
    781 .PHONY: systemtarball-nodeps
    782 systemtarball-nodeps: $(FS_GET_STATS) \
    783                       $(filter-out systemtarball-nodeps stnod,$(MAKECMDGOALS))
    784 	$(build-systemtarball-target)
    785 
    786 .PHONY: stnod
    787 stnod: systemtarball-nodeps
    788 
    789 
    790 # -----------------------------------------------------------------
    791 # data partition image
    792 INTERNAL_USERDATAIMAGE_FILES := \
    793 	$(filter $(TARGET_OUT_DATA)/%,$(ALL_DEFAULT_INSTALLED_MODULES))
    794 
    795 ifeq ($(INTERNAL_USERIMAGES_USE_EXT),true)
    796 ## Generate an ext image
    797 define build-userdataimage-target
    798     $(call pretty,"Target userdata fs image: $(INSTALLED_USERDATAIMAGE_TARGET)")
    799     @mkdir -p $(TARGET_OUT_DATA)
    800     $(call build-userimage-ext-target,$(TARGET_OUT_DATA),$(INSTALLED_USERDATAIMAGE_TARGET),data,$(INTERNAL_USERIMAGES_EXT_VARIANT),$(BOARD_USERDATAIMAGE_PARTITION_SIZE))
    801     $(hide) $(call assert-max-image-size,$(INSTALLED_USERDATAIMAGE_TARGET),$(BOARD_USERDATAIMAGE_PARTITION_SIZE),yaffs)
    802 endef
    803 
    804 else # INTERNAL_USERIMAGES_USE_EXT != true
    805 
    806 ## Generate a yaffs2 image
    807 define build-userdataimage-target
    808     $(call pretty,"Target userdata fs image: $(INSTALLED_USERDATAIMAGE_TARGET)")
    809     @mkdir -p $(TARGET_OUT_DATA)
    810     $(hide) $(MKYAFFS2) -f $(mkyaffs2_extra_flags) $(TARGET_OUT_DATA) $(INSTALLED_USERDATAIMAGE_TARGET)
    811     $(hide) $(call assert-max-image-size,$(INSTALLED_USERDATAIMAGE_TARGET),$(BOARD_USERDATAIMAGE_PARTITION_SIZE),yaffs)
    812 endef
    813 endif # INTERNAL_USERIMAGES_USE_EXT
    814 
    815 BUILT_USERDATAIMAGE_TARGET := $(PRODUCT_OUT)/userdata.img
    816 
    817 # We just build this directly to the install location.
    818 INSTALLED_USERDATAIMAGE_TARGET := $(BUILT_USERDATAIMAGE_TARGET)
    819 $(INSTALLED_USERDATAIMAGE_TARGET): $(INTERNAL_USERIMAGES_DEPS) \
    820                                    $(INTERNAL_USERDATAIMAGE_FILES)
    821 	$(build-userdataimage-target)
    822 
    823 .PHONY: userdataimage-nodeps
    824 userdataimage-nodeps: $(INTERNAL_USERIMAGES_DEPS)
    825 	$(build-userdataimage-target)
    826 
    827 #######
    828 ## data partition tarball
    829 define build-userdatatarball-target
    830     $(call pretty,"Target userdata fs tarball: " \
    831                   "$(INSTALLED_USERDATATARBALL_TARGET)")
    832     $(MKTARBALL) $(FS_GET_STATS) \
    833 		$(PRODUCT_OUT) data $(PRIVATE_USERDATA_TAR) \
    834 		$(INSTALLED_USERDATATARBALL_TARGET)
    835 endef
    836 
    837 userdata_tar := $(PRODUCT_OUT)/userdata.tar
    838 INSTALLED_USERDATATARBALL_TARGET := $(userdata_tar).bz2
    839 $(INSTALLED_USERDATATARBALL_TARGET): PRIVATE_USERDATA_TAR := $(userdata_tar)
    840 $(INSTALLED_USERDATATARBALL_TARGET): $(FS_GET_STATS) $(INTERNAL_USERDATAIMAGE_FILES)
    841 	$(build-userdatatarball-target)
    842 
    843 .PHONY: userdatatarball-nodeps
    844 userdatatarball-nodeps: $(FS_GET_STATS)
    845 	$(build-userdatatarball-target)
    846 
    847 
    848 # -----------------------------------------------------------------
    849 # bring in the installer image generation defines if necessary
    850 ifeq ($(TARGET_USE_DISKINSTALLER),true)
    851 include bootable/diskinstaller/config.mk
    852 endif
    853 
    854 # -----------------------------------------------------------------
    855 # host tools needed to build OTA packages
    856 
    857 OTATOOLS :=  $(HOST_OUT_EXECUTABLES)/minigzip \
    858 	  $(HOST_OUT_EXECUTABLES)/mkbootfs \
    859 	  $(HOST_OUT_EXECUTABLES)/mkbootimg \
    860 	  $(HOST_OUT_EXECUTABLES)/fs_config \
    861 	  $(HOST_OUT_EXECUTABLES)/mkyaffs2image \
    862 	  $(HOST_OUT_EXECUTABLES)/zipalign \
    863 	  $(HOST_OUT_EXECUTABLES)/aapt \
    864 	  $(HOST_OUT_EXECUTABLES)/bsdiff \
    865 	  $(HOST_OUT_EXECUTABLES)/imgdiff \
    866 	  $(HOST_OUT_JAVA_LIBRARIES)/dumpkey.jar \
    867 	  $(HOST_OUT_JAVA_LIBRARIES)/signapk.jar
    868 
    869 .PHONY: otatools
    870 otatools: $(OTATOOLS)
    871 
    872 # -----------------------------------------------------------------
    873 # A zip of the directories that map to the target filesystem.
    874 # This zip can be used to create an OTA package or filesystem image
    875 # as a post-build step.
    876 #
    877 name := $(TARGET_PRODUCT)
    878 ifeq ($(TARGET_BUILD_TYPE),debug)
    879   name := $(name)_debug
    880 endif
    881 name := $(name)-target_files-$(FILE_NAME_TAG)
    882 
    883 intermediates := $(call intermediates-dir-for,PACKAGING,target_files)
    884 BUILT_TARGET_FILES_PACKAGE := $(intermediates)/$(name).zip
    885 $(BUILT_TARGET_FILES_PACKAGE): intermediates := $(intermediates)
    886 $(BUILT_TARGET_FILES_PACKAGE): \
    887 		zip_root := $(intermediates)/$(name)
    888 
    889 # $(1): Directory to copy
    890 # $(2): Location to copy it to
    891 # The "ls -A" is to prevent "acp s/* d" from failing if s is empty.
    892 define package_files-copy-root
    893   if [ -d "$(strip $(1))" -a "$$(ls -A $(1))" ]; then \
    894     mkdir -p $(2) && \
    895     $(ACP) -rd $(strip $(1))/* $(2); \
    896   fi
    897 endef
    898 
    899 built_ota_tools := \
    900 	$(call intermediates-dir-for,EXECUTABLES,applypatch)/applypatch \
    901 	$(call intermediates-dir-for,EXECUTABLES,applypatch_static)/applypatch_static \
    902 	$(call intermediates-dir-for,EXECUTABLES,check_prereq)/check_prereq \
    903 	$(call intermediates-dir-for,EXECUTABLES,updater)/updater
    904 $(BUILT_TARGET_FILES_PACKAGE): PRIVATE_OTA_TOOLS := $(built_ota_tools)
    905 
    906 $(BUILT_TARGET_FILES_PACKAGE): PRIVATE_RECOVERY_API_VERSION := $(RECOVERY_API_VERSION)
    907 
    908 ifeq ($(TARGET_RELEASETOOLS_EXTENSIONS),)
    909 # default to common dir for device vendor
    910 $(BUILT_TARGET_FILES_PACKAGE): tool_extensions := $(TARGET_DEVICE_DIR)/../common
    911 else
    912 $(BUILT_TARGET_FILES_PACKAGE): tool_extensions := $(TARGET_RELEASETOOLS_EXTENSIONS)
    913 endif
    914 
    915 # Depending on the various images guarantees that the underlying
    916 # directories are up-to-date.
    917 $(BUILT_TARGET_FILES_PACKAGE): \
    918 		$(INSTALLED_BOOTIMAGE_TARGET) \
    919 		$(INSTALLED_RADIOIMAGE_TARGET) \
    920 		$(INSTALLED_RECOVERYIMAGE_TARGET) \
    921 		$(INSTALLED_SYSTEMIMAGE) \
    922 		$(INSTALLED_USERDATAIMAGE_TARGET) \
    923 		$(INSTALLED_ANDROID_INFO_TXT_TARGET) \
    924 		$(built_ota_tools) \
    925 		$(APKCERTS_FILE) \
    926 		$(HOST_OUT_EXECUTABLES)/fs_config \
    927 		| $(ACP)
    928 	@echo "Package target files: $@"
    929 	$(hide) rm -rf $@ $(zip_root)
    930 	$(hide) mkdir -p $(dir $@) $(zip_root)
    931 	@# Components of the recovery image
    932 	$(hide) mkdir -p $(zip_root)/RECOVERY
    933 	$(hide) $(call package_files-copy-root, \
    934 		$(TARGET_RECOVERY_ROOT_OUT),$(zip_root)/RECOVERY/RAMDISK)
    935 ifdef INSTALLED_KERNEL_TARGET
    936 	$(hide) $(ACP) $(INSTALLED_KERNEL_TARGET) $(zip_root)/RECOVERY/kernel
    937 endif
    938 ifdef INSTALLED_2NDBOOTLOADER_TARGET
    939 	$(hide) $(ACP) \
    940 		$(INSTALLED_2NDBOOTLOADER_TARGET) $(zip_root)/RECOVERY/second
    941 endif
    942 ifdef BOARD_KERNEL_CMDLINE
    943 	$(hide) echo "$(BOARD_KERNEL_CMDLINE)" > $(zip_root)/RECOVERY/cmdline
    944 endif
    945 ifdef BOARD_KERNEL_BASE
    946 	$(hide) echo "$(BOARD_KERNEL_BASE)" > $(zip_root)/RECOVERY/base
    947 endif
    948 ifdef BOARD_KERNEL_PAGESIZE
    949 	$(hide) echo "$(BOARD_KERNEL_PAGESIZE)" > $(zip_root)/RECOVERY/pagesize
    950 endif
    951 	@# Components of the boot image
    952 	$(hide) mkdir -p $(zip_root)/BOOT
    953 	$(hide) $(call package_files-copy-root, \
    954 		$(TARGET_ROOT_OUT),$(zip_root)/BOOT/RAMDISK)
    955 ifdef INSTALLED_KERNEL_TARGET
    956 	$(hide) $(ACP) $(INSTALLED_KERNEL_TARGET) $(zip_root)/BOOT/kernel
    957 endif
    958 ifdef INSTALLED_2NDBOOTLOADER_TARGET
    959 	$(hide) $(ACP) \
    960 		$(INSTALLED_2NDBOOTLOADER_TARGET) $(zip_root)/BOOT/second
    961 endif
    962 ifdef BOARD_KERNEL_CMDLINE
    963 	$(hide) echo "$(BOARD_KERNEL_CMDLINE)" > $(zip_root)/BOOT/cmdline
    964 endif
    965 ifdef BOARD_KERNEL_BASE
    966 	$(hide) echo "$(BOARD_KERNEL_BASE)" > $(zip_root)/BOOT/base
    967 endif
    968 ifdef BOARD_KERNEL_PAGESIZE
    969 	$(hide) echo "$(BOARD_KERNEL_PAGESIZE)" > $(zip_root)/BOOT/pagesize
    970 endif
    971 	$(hide) $(foreach t,$(INSTALLED_RADIOIMAGE_TARGET),\
    972 	            mkdir -p $(zip_root)/RADIO; \
    973 	            $(ACP) $(t) $(zip_root)/RADIO/$(notdir $(t));)
    974 	@# Contents of the system image
    975 	$(hide) $(call package_files-copy-root, \
    976 		$(SYSTEMIMAGE_SOURCE_DIR),$(zip_root)/SYSTEM)
    977 	@# Contents of the data image
    978 	$(hide) $(call package_files-copy-root, \
    979 		$(TARGET_OUT_DATA),$(zip_root)/DATA)
    980 	@# Extra contents of the OTA package
    981 	$(hide) mkdir -p $(zip_root)/OTA/bin
    982 	$(hide) $(ACP) $(INSTALLED_ANDROID_INFO_TXT_TARGET) $(zip_root)/OTA/
    983 	$(hide) $(ACP) $(PRIVATE_OTA_TOOLS) $(zip_root)/OTA/bin/
    984 	@# Files that do not end up in any images, but are necessary to
    985 	@# build them.
    986 	$(hide) mkdir -p $(zip_root)/META
    987 	$(hide) $(ACP) $(APKCERTS_FILE) $(zip_root)/META/apkcerts.txt
    988 	$(hide)	echo "$(PRODUCT_OTA_PUBLIC_KEYS)" > $(zip_root)/META/otakeys.txt
    989 	$(hide) echo "recovery_api_version=$(PRIVATE_RECOVERY_API_VERSION)" > $(zip_root)/META/misc_info.txt
    990 ifdef BOARD_FLASH_BLOCK_SIZE
    991 	$(hide) echo "blocksize=$(BOARD_FLASH_BLOCK_SIZE)" >> $(zip_root)/META/misc_info.txt
    992 endif
    993 ifdef BOARD_BOOTIMAGE_PARTITION_SIZE
    994 	$(hide) echo "boot_size=$(BOARD_BOOTIMAGE_PARTITION_SIZE)" >> $(zip_root)/META/misc_info.txt
    995 endif
    996 ifdef BOARD_RECOVERYIMAGE_PARTITION_SIZE
    997 	$(hide) echo "recovery_size=$(BOARD_RECOVERYIMAGE_PARTITION_SIZE)" >> $(zip_root)/META/misc_info.txt
    998 endif
    999 ifdef BOARD_SYSTEMIMAGE_PARTITION_SIZE
   1000 	$(hide) echo "system_size=$(BOARD_SYSTEMIMAGE_PARTITION_SIZE)" >> $(zip_root)/META/misc_info.txt
   1001 endif
   1002 ifdef BOARD_USERDATAIMAGE_PARTITION_SIZE
   1003 	$(hide) echo "userdata_size=$(BOARD_USERDATAIMAGE_PARTITION_SIZE)" >> $(zip_root)/META/misc_info.txt
   1004 endif
   1005 	$(hide) echo "tool_extensions=$(tool_extensions)" >> $(zip_root)/META/misc_info.txt
   1006 ifdef mkyaffs2_extra_flags
   1007 	$(hide) echo "mkyaffs2_extra_flags=$(mkyaffs2_extra_flags)" >> $(zip_root)/META/misc_info.txt
   1008 endif
   1009 	@# Zip everything up, preserving symlinks
   1010 	$(hide) (cd $(zip_root) && zip -qry ../$(notdir $@) .)
   1011 	@# Run fs_config on all the system files in the zip, and save the output
   1012 	$(hide) zipinfo -1 $@ | awk -F/ 'BEGIN { OFS="/" } /^SYSTEM\// {$$1 = "system"; print}' | $(HOST_OUT_EXECUTABLES)/fs_config > $(zip_root)/META/filesystem_config.txt
   1013 	$(hide) (cd $(zip_root) && zip -q ../$(notdir $@) META/filesystem_config.txt)
   1014 
   1015 
   1016 target-files-package: $(BUILT_TARGET_FILES_PACKAGE)
   1017 
   1018 
   1019 ifneq ($(TARGET_SIMULATOR),true)
   1020 ifneq ($(TARGET_PRODUCT),sdk)
   1021 ifneq ($(TARGET_DEVICE),generic)
   1022 ifneq ($(TARGET_NO_KERNEL),true)
   1023 
   1024 # -----------------------------------------------------------------
   1025 # OTA update package
   1026 
   1027 name := $(TARGET_PRODUCT)
   1028 ifeq ($(TARGET_BUILD_TYPE),debug)
   1029   name := $(name)_debug
   1030 endif
   1031 name := $(name)-ota-$(FILE_NAME_TAG)
   1032 
   1033 INTERNAL_OTA_PACKAGE_TARGET := $(PRODUCT_OUT)/$(name).zip
   1034 
   1035 $(INTERNAL_OTA_PACKAGE_TARGET): KEY_CERT_PAIR := $(DEFAULT_KEY_CERT_PAIR)
   1036 
   1037 $(INTERNAL_OTA_PACKAGE_TARGET): $(BUILT_TARGET_FILES_PACKAGE) $(OTATOOLS)
   1038 	@echo "Package OTA: $@"
   1039 	$(hide) ./build/tools/releasetools/ota_from_target_files -v \
   1040 	   -p $(HOST_OUT) \
   1041            -k $(KEY_CERT_PAIR) \
   1042            $(BUILT_TARGET_FILES_PACKAGE) $@
   1043 
   1044 .PHONY: otapackage
   1045 otapackage: $(INTERNAL_OTA_PACKAGE_TARGET)
   1046 
   1047 # -----------------------------------------------------------------
   1048 # The update package
   1049 
   1050 name := $(TARGET_PRODUCT)
   1051 ifeq ($(TARGET_BUILD_TYPE),debug)
   1052   name := $(name)_debug
   1053 endif
   1054 name := $(name)-img-$(FILE_NAME_TAG)
   1055 
   1056 INTERNAL_UPDATE_PACKAGE_TARGET := $(PRODUCT_OUT)/$(name).zip
   1057 
   1058 ifeq ($(TARGET_RELEASETOOLS_EXTENSIONS),)
   1059 # default to common dir for device vendor
   1060 $(INTERNAL_UPDATE_PACKAGE_TARGET): extensions := $(TARGET_DEVICE_DIR)/../common
   1061 else
   1062 $(INTERNAL_UPDATE_PACKAGE_TARGET): extensions := $(TARGET_RELEASETOOLS_EXTENSIONS)
   1063 endif
   1064 
   1065 $(INTERNAL_UPDATE_PACKAGE_TARGET): $(BUILT_TARGET_FILES_PACKAGE) $(OTATOOLS)
   1066 	@echo "Package: $@"
   1067 	$(hide) ./build/tools/releasetools/img_from_target_files -v \
   1068 	   -s $(extensions) \
   1069 	   -p $(HOST_OUT) \
   1070 	   $(BUILT_TARGET_FILES_PACKAGE) $@
   1071 
   1072 .PHONY: updatepackage
   1073 updatepackage: $(INTERNAL_UPDATE_PACKAGE_TARGET)
   1074 
   1075 endif    # TARGET_NO_KERNEL != true
   1076 endif    # TARGET_DEVICE != generic
   1077 endif    # TARGET_PRODUCT != sdk
   1078 endif    # TARGET_SIMULATOR != true
   1079 
   1080 # -----------------------------------------------------------------
   1081 # installed file list
   1082 # Depending on $(INSTALLED_SYSTEMIMAGE) ensures that it
   1083 # gets the DexOpt one if we're doing that.
   1084 INSTALLED_FILES_FILE := $(PRODUCT_OUT)/installed-files.txt
   1085 $(INSTALLED_FILES_FILE): $(INSTALLED_SYSTEMIMAGE)
   1086 	@echo Installed file list: $@
   1087 	@mkdir -p $(dir $@)
   1088 	@rm -f $@
   1089 	$(hide) build/tools/fileslist.py $(TARGET_OUT) $(TARGET_OUT_DATA) > $@
   1090 
   1091 .PHONY: installed-file-list
   1092 installed-file-list: $(INSTALLED_FILES_FILE)
   1093 $(call dist-for-goals, sdk, $(INSTALLED_FILES_FILE))
   1094 $(call dist-for-goals, sdk_addon, $(INSTALLED_FILES_FILE))
   1095 
   1096 # -----------------------------------------------------------------
   1097 # A zip of the tests that are built when running "make tests".
   1098 # This is very similar to BUILT_TARGET_FILES_PACKAGE, but we
   1099 # only grab SYSTEM and DATA, and it's called "*-tests-*.zip".
   1100 #
   1101 name := $(TARGET_PRODUCT)
   1102 ifeq ($(TARGET_BUILD_TYPE),debug)
   1103   name := $(name)_debug
   1104 endif
   1105 name := $(name)-tests-$(FILE_NAME_TAG)
   1106 
   1107 intermediates := $(call intermediates-dir-for,PACKAGING,tests_zip)
   1108 BUILT_TESTS_ZIP_PACKAGE := $(intermediates)/$(name).zip
   1109 $(BUILT_TESTS_ZIP_PACKAGE): intermediates := $(intermediates)
   1110 $(BUILT_TESTS_ZIP_PACKAGE): zip_root := $(intermediates)/$(name)
   1111 
   1112 # Depending on the images guarantees that the underlying
   1113 # directories are up-to-date.
   1114 $(BUILT_TESTS_ZIP_PACKAGE): \
   1115 		$(BUILT_SYSTEMIMAGE) \
   1116 		$(INSTALLED_USERDATAIMAGE_TARGET) \
   1117 		| $(ACP)
   1118 	@echo "Package test files: $@"
   1119 	$(hide) rm -rf $@ $(zip_root)
   1120 	$(hide) mkdir -p $(dir $@) $(zip_root)
   1121 	@# Some parts of the system image
   1122 	$(hide) $(call package_files-copy-root, \
   1123 		$(SYSTEMIMAGE_SOURCE_DIR)/xbin,$(zip_root)/SYSTEM/xbin)
   1124 	$(hide) $(call package_files-copy-root, \
   1125 		$(SYSTEMIMAGE_SOURCE_DIR)/lib,$(zip_root)/SYSTEM/lib)
   1126 	$(hide) $(call package_files-copy-root, \
   1127 		$(SYSTEMIMAGE_SOURCE_DIR)/framework, \
   1128 		$(zip_root)/SYSTEM/framework)
   1129 	$(hide) $(ACP) $(SYSTEMIMAGE_SOURCE_DIR)/build.prop $(zip_root)/SYSTEM
   1130 	@# Contents of the data image
   1131 	$(hide) $(call package_files-copy-root, \
   1132 		$(TARGET_OUT_DATA),$(zip_root)/DATA)
   1133 	$(hide) (cd $(zip_root) && zip -qry ../$(notdir $@) .)
   1134 
   1135 .PHONY: tests-zip-package
   1136 tests-zip-package: $(BUILT_TESTS_ZIP_PACKAGE)
   1137 
   1138 # Target needed by tests build
   1139 .PHONY: tests-build-target
   1140 tests-build-target: $(BUILT_TESTS_ZIP_PACKAGE) \
   1141                     $(BUILT_USERDATAIMAGE_TARGET)
   1142 
   1143 ifneq (,$(filter $(MAKECMDGOALS),tests-build-target))
   1144   $(call dist-for-goals, tests-build-target, \
   1145           $(BUILT_TESTS_ZIP_PACKAGE) \
   1146           $(BUILT_USERDATAIMAGE_TARGET))
   1147 endif
   1148 
   1149 # -----------------------------------------------------------------
   1150 # A zip of the symbols directory.  Keep the full paths to make it
   1151 # more obvious where these files came from.
   1152 #
   1153 name := $(TARGET_PRODUCT)
   1154 ifeq ($(TARGET_BUILD_TYPE),debug)
   1155   name := $(name)_debug
   1156 endif
   1157 name := $(name)-symbols-$(FILE_NAME_TAG)
   1158 
   1159 SYMBOLS_ZIP := $(PRODUCT_OUT)/$(name).zip
   1160 $(SYMBOLS_ZIP): $(INSTALLED_SYSTEMIMAGE) $(INSTALLED_BOOTIMAGE_TARGET)
   1161 	@echo "Package symbols: $@"
   1162 	$(hide) rm -rf $@
   1163 	$(hide) mkdir -p $(dir $@)
   1164 	$(hide) zip -qr $@ $(TARGET_OUT_UNSTRIPPED)
   1165 
   1166 # -----------------------------------------------------------------
   1167 # A zip of the Android Apps. Not keeping full path so that we don't
   1168 # include product names when distributing
   1169 #
   1170 name := $(TARGET_PRODUCT)
   1171 ifeq ($(TARGET_BUILD_TYPE),debug)
   1172   name := $(name)_debug
   1173 endif
   1174 name := $(name)-apps-$(FILE_NAME_TAG)
   1175 
   1176 APPS_ZIP := $(PRODUCT_OUT)/$(name).zip
   1177 $(APPS_ZIP): $(INSTALLED_SYSTEMIMAGE)
   1178 	@echo "Package apps: $@"
   1179 	$(hide) rm -rf $@
   1180 	$(hide) mkdir -p $(dir $@)
   1181 	$(hide) zip -qj $@ $(TARGET_OUT_APPS)/*
   1182 
   1183 
   1184 #------------------------------------------------------------------
   1185 # A zip of emma code coverage meta files. Generated for fully emma
   1186 # instrumented build.
   1187 #
   1188 EMMA_META_ZIP := $(PRODUCT_OUT)/emma_meta.zip
   1189 $(EMMA_META_ZIP): $(INSTALLED_SYSTEMIMAGE)
   1190 	@echo "Collecting Emma coverage meta files."
   1191 	$(hide) find $(TARGET_COMMON_OUT_ROOT) -name "coverage.em" | \
   1192 		zip -@ -q $@
   1193 
   1194 endif	# TARGET_SIMULATOR != true
   1195 
   1196 # -----------------------------------------------------------------
   1197 # dalvik something
   1198 .PHONY: dalvikfiles
   1199 dalvikfiles: $(INTERNAL_DALVIK_MODULES)
   1200 
   1201 # -----------------------------------------------------------------
   1202 # The emulator package
   1203 
   1204 ifneq ($(TARGET_SIMULATOR),true)
   1205 
   1206 INTERNAL_EMULATOR_PACKAGE_FILES += \
   1207         $(HOST_OUT_EXECUTABLES)/emulator$(HOST_EXECUTABLE_SUFFIX) \
   1208         prebuilt/android-arm/kernel/kernel-qemu \
   1209         $(INSTALLED_RAMDISK_TARGET) \
   1210 		$(INSTALLED_SYSTEMIMAGE) \
   1211 		$(INSTALLED_USERDATAIMAGE_TARGET)
   1212 
   1213 name := $(TARGET_PRODUCT)-emulator-$(FILE_NAME_TAG)
   1214 
   1215 INTERNAL_EMULATOR_PACKAGE_TARGET := $(PRODUCT_OUT)/$(name).zip
   1216 
   1217 $(INTERNAL_EMULATOR_PACKAGE_TARGET): $(INTERNAL_EMULATOR_PACKAGE_FILES)
   1218 	@echo "Package: $@"
   1219 	$(hide) zip -qj $@ $(INTERNAL_EMULATOR_PACKAGE_FILES)
   1220 
   1221 endif
   1222 
   1223 # -----------------------------------------------------------------
   1224 # The pdk package (Platform Development Kit)
   1225 
   1226 ifneq (,$(filter pdk,$(MAKECMDGOALS)))
   1227   include development/pdk/Pdk.mk
   1228 endif
   1229 
   1230 # -----------------------------------------------------------------
   1231 # The SDK
   1232 
   1233 ifneq ($(TARGET_SIMULATOR),true)
   1234 
   1235 # The SDK includes host-specific components, so it belongs under HOST_OUT.
   1236 sdk_dir := $(HOST_OUT)/sdk
   1237 
   1238 # Build a name that looks like:
   1239 #
   1240 #     linux-x86   --> android-sdk_12345_linux-x86
   1241 #     darwin-x86  --> android-sdk_12345_mac-x86
   1242 #     windows-x86 --> android-sdk_12345_windows
   1243 #
   1244 sdk_name := android-sdk_$(FILE_NAME_TAG)
   1245 ifeq ($(HOST_OS),darwin)
   1246   INTERNAL_SDK_HOST_OS_NAME := mac
   1247 else
   1248   INTERNAL_SDK_HOST_OS_NAME := $(HOST_OS)
   1249 endif
   1250 ifneq ($(HOST_OS),windows)
   1251   INTERNAL_SDK_HOST_OS_NAME := $(INTERNAL_SDK_HOST_OS_NAME)-$(HOST_ARCH)
   1252 endif
   1253 sdk_name := $(sdk_name)_$(INTERNAL_SDK_HOST_OS_NAME)
   1254 
   1255 sdk_dep_file := $(sdk_dir)/sdk_deps.mk
   1256 
   1257 ATREE_FILES :=
   1258 -include $(sdk_dep_file)
   1259 
   1260 # if we don't have a real list, then use "everything"
   1261 ifeq ($(strip $(ATREE_FILES)),)
   1262 ATREE_FILES := \
   1263 	$(ALL_PREBUILT) \
   1264 	$(ALL_COPIED_HEADERS) \
   1265 	$(ALL_GENERATED_SOURCES) \
   1266 	$(ALL_DEFAULT_INSTALLED_MODULES) \
   1267 	$(INSTALLED_RAMDISK_TARGET) \
   1268 	$(ALL_DOCS) \
   1269 	$(ALL_SDK_FILES)
   1270 endif
   1271 
   1272 atree_dir := development/build
   1273 
   1274 sdk_atree_files := \
   1275 	$(atree_dir)/sdk.exclude.atree \
   1276 	$(atree_dir)/sdk.atree \
   1277 	$(atree_dir)/sdk-$(HOST_OS)-$(HOST_ARCH).atree \
   1278 	sdk/build/tools.atree
   1279 
   1280 deps := \
   1281 	$(target_notice_file_txt) \
   1282 	$(tools_notice_file_txt) \
   1283 	$(OUT_DOCS)/offline-sdk-timestamp \
   1284 	$(SYMBOLS_ZIP) \
   1285 	$(INSTALLED_SYSTEMIMAGE) \
   1286 	$(INSTALLED_USERDATAIMAGE_TARGET) \
   1287 	$(INSTALLED_RAMDISK_TARGET) \
   1288 	$(INSTALLED_SDK_BUILD_PROP_TARGET) \
   1289 	$(INSTALLED_BUILD_PROP_TARGET) \
   1290 	$(ATREE_FILES) \
   1291 	$(atree_dir)/sdk.atree \
   1292 	sdk/build/tools.atree \
   1293 	$(HOST_OUT_EXECUTABLES)/atree \
   1294     $(HOST_OUT_EXECUTABLES)/line_endings
   1295 
   1296 INTERNAL_SDK_TARGET := $(sdk_dir)/$(sdk_name).zip
   1297 $(INTERNAL_SDK_TARGET): PRIVATE_NAME := $(sdk_name)
   1298 $(INTERNAL_SDK_TARGET): PRIVATE_DIR := $(sdk_dir)/$(sdk_name)
   1299 $(INTERNAL_SDK_TARGET): PRIVATE_DEP_FILE := $(sdk_dep_file)
   1300 $(INTERNAL_SDK_TARGET): PRIVATE_INPUT_FILES := $(sdk_atree_files)
   1301 
   1302 # Set SDK_GNU_ERROR to non-empty to fail when a GNU target is built.
   1303 #
   1304 #SDK_GNU_ERROR := true
   1305 
   1306 $(INTERNAL_SDK_TARGET): $(deps)
   1307 	@echo "Package SDK: $@"
   1308 	$(hide) rm -rf $(PRIVATE_DIR) $@
   1309 	$(hide) for f in $(target_gnu_MODULES); do \
   1310 	  if [ -f $$f ]; then \
   1311 	    echo SDK: $(if $(SDK_GNU_ERROR),ERROR:,warning:) \
   1312 	        including GNU target $$f >&2; \
   1313 	    FAIL=$(SDK_GNU_ERROR); \
   1314 	  fi; \
   1315 	done; \
   1316 	if [ $$FAIL ]; then exit 1; fi
   1317 	$(hide) ( \
   1318 		$(HOST_OUT_EXECUTABLES)/atree \
   1319 		$(addprefix -f ,$(PRIVATE_INPUT_FILES)) \
   1320 			-m $(PRIVATE_DEP_FILE) \
   1321 			-I . \
   1322 			-I $(PRODUCT_OUT) \
   1323 			-I $(HOST_OUT) \
   1324 			-I $(TARGET_COMMON_OUT_ROOT) \
   1325 			-v "PLATFORM_NAME=android-$(PLATFORM_VERSION)" \
   1326 			-o $(PRIVATE_DIR) && \
   1327 		cp -f $(target_notice_file_txt) \
   1328 				$(PRIVATE_DIR)/platforms/android-$(PLATFORM_VERSION)/images/NOTICE.txt && \
   1329 		cp -f $(tools_notice_file_txt) $(PRIVATE_DIR)/tools/NOTICE.txt && \
   1330 		HOST_OUT_EXECUTABLES=$(HOST_OUT_EXECUTABLES) HOST_OS=$(HOST_OS) \
   1331                 development/build/tools/sdk_clean.sh $(PRIVATE_DIR) && \
   1332 		chmod -R ug+rwX $(PRIVATE_DIR) && \
   1333 		cd $(dir $@) && zip -rq $(notdir $@) $(PRIVATE_NAME) \
   1334 	) || ( rm -rf $(PRIVATE_DIR) $@ && exit 44 )
   1335 
   1336 
   1337 # Is a Windows SDK requested? If so, we need some definitions from here
   1338 # in order to find the Linux SDK used to create the Windows one.
   1339 ifneq ($(filter win_sdk,$(MAKECMDGOALS)),)
   1340 LINUX_SDK_NAME := $(sdk_name)
   1341 LINUX_SDK_DIR  := $(sdk_dir)
   1342 include $(TOPDIR)development/build/tools/windows_sdk.mk
   1343 endif
   1344 
   1345 endif # !simulator
   1346 
   1347 # -----------------------------------------------------------------
   1348 # Findbugs
   1349 INTERNAL_FINDBUGS_XML_TARGET := $(PRODUCT_OUT)/findbugs.xml
   1350 INTERNAL_FINDBUGS_HTML_TARGET := $(PRODUCT_OUT)/findbugs.html
   1351 $(INTERNAL_FINDBUGS_XML_TARGET): $(ALL_FINDBUGS_FILES)
   1352 	@echo UnionBugs: $@
   1353 	$(hide) prebuilt/common/findbugs/bin/unionBugs $(ALL_FINDBUGS_FILES) \
   1354 	> $@
   1355 $(INTERNAL_FINDBUGS_HTML_TARGET): $(INTERNAL_FINDBUGS_XML_TARGET)
   1356 	@echo ConvertXmlToText: $@
   1357 	$(hide) prebuilt/common/findbugs/bin/convertXmlToText -html:fancy.xsl \
   1358 	$(INTERNAL_FINDBUGS_XML_TARGET)	> $@
   1359 
   1360 # -----------------------------------------------------------------
   1361 # Findbugs
   1362 
   1363 # -----------------------------------------------------------------
   1364 # These are some additional build tasks that need to be run.
   1365 include $(sort $(wildcard $(BUILD_SYSTEM)/tasks/*.mk))
   1366