blob: 8a5d3ee9a3017f59a5a74c3836c361cb7c66ea27 [file] [log] [blame]
Steve Kondik5bd66602016-07-15 10:39:58 -07001#!/bin/bash
2#
3# Copyright (C) 2016 The CyanogenMod Project
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16#
17
18PRODUCT_COPY_FILES_LIST=()
19PRODUCT_COPY_FILES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +020020PRODUCT_COPY_FILES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -070021PRODUCT_PACKAGES_LIST=()
22PRODUCT_PACKAGES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +020023PRODUCT_PACKAGES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -070024PACKAGE_LIST=()
25VENDOR_STATE=-1
26VENDOR_RADIO_STATE=-1
27COMMON=-1
28ARCHES=
29FULLY_DEODEXED=-1
30
Rashed Abdel-Tawabe7d9b5c2017-08-05 23:11:35 -040031TMPDIR=$(mktemp -d)
Volodymyr Zhdanove54a1592020-10-22 01:33:24 +030032HOST="$(uname | tr '[:upper:]' '[:lower:]')"
Steve Kondik5bd66602016-07-15 10:39:58 -070033
34#
35# cleanup
36#
37# kill our tmpfiles with fire on exit
38#
39function cleanup() {
40 rm -rf "${TMPDIR:?}"
41}
42
Gabriele Mb8e54572017-10-11 12:55:51 +020043trap cleanup 0
Steve Kondik5bd66602016-07-15 10:39:58 -070044
45#
46# setup_vendor
47#
48# $1: device name
49# $2: vendor name
theimpulson9a911af2019-08-14 03:25:12 +000050# $3: OMNI root directory
Steve Kondik5bd66602016-07-15 10:39:58 -070051# $4: is common device - optional, default to false
52# $5: cleanup - optional, default to true
Jake Whatley9843b322017-01-25 21:49:16 -050053# $6: custom vendor makefile name - optional, default to false
Steve Kondik5bd66602016-07-15 10:39:58 -070054#
55# Must be called before any other functions can be used. This
56# sets up the internal state for a new vendor configuration.
57#
58function setup_vendor() {
59 local DEVICE="$1"
60 if [ -z "$DEVICE" ]; then
61 echo "\$DEVICE must be set before including this script!"
62 exit 1
63 fi
64
65 export VENDOR="$2"
66 if [ -z "$VENDOR" ]; then
67 echo "\$VENDOR must be set before including this script!"
68 exit 1
69 fi
70
theimpulson9a911af2019-08-14 03:25:12 +000071 export OMNI_ROOT="$3"
72 if [ ! -d "$OMNI_ROOT" ]; then
73 echo "\$OMNI_ROOT must be set and valid before including this script!"
Steve Kondik5bd66602016-07-15 10:39:58 -070074 exit 1
75 fi
76
77 export OUTDIR=vendor/"$VENDOR"/"$DEVICE"
theimpulson9a911af2019-08-14 03:25:12 +000078 if [ ! -d "$OMNI_ROOT/$OUTDIR" ]; then
79 mkdir -p "$OMNI_ROOT/$OUTDIR"
Steve Kondik5bd66602016-07-15 10:39:58 -070080 fi
81
Jake Whatley9843b322017-01-25 21:49:16 -050082 VNDNAME="$6"
83 if [ -z "$VNDNAME" ]; then
84 VNDNAME="$DEVICE"
85 fi
86
theimpulsonbb72ab82019-08-14 06:03:32 +000087 export PRODUCTMK="$OMNI_ROOT"/"$OUTDIR"/"$VNDNAME"-vendor.mk
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -070088 export ANDROIDBP="$OMNI_ROOT"/"$OUTDIR"/Android.bp
theimpulson9a911af2019-08-14 03:25:12 +000089 export ANDROIDMK="$OMNI_ROOT"/"$OUTDIR"/Android.mk
90 export BOARDMK="$OMNI_ROOT"/"$OUTDIR"/BoardConfigVendor.mk
Steve Kondik5bd66602016-07-15 10:39:58 -070091
92 if [ "$4" == "true" ] || [ "$4" == "1" ]; then
93 COMMON=1
94 else
95 COMMON=0
96 fi
97
Gabriele Mc44696d2017-05-01 18:22:04 +020098 if [ "$5" == "false" ] || [ "$5" == "0" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -070099 VENDOR_STATE=1
100 VENDOR_RADIO_STATE=1
101 else
102 VENDOR_STATE=0
103 VENDOR_RADIO_STATE=0
104 fi
Volodymyr Zhdanove54a1592020-10-22 01:33:24 +0300105
106 if [ -z "$PATCHELF" ]; then
107 export PATCHELF="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/bin/patchelf
108 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700109}
110
Vladimir Oltean75d8e052018-06-24 20:22:41 +0300111# Helper functions for parsing a spec.
112# notes: an optional "|SHA1" that may appear in the format is stripped
113# early from the spec in the parse_file_list function, and
114# should not be present inside the input parameter passed
115# to these functions.
116
117#
118# input: spec in the form of "src[:dst][;args]"
119# output: "src"
120#
121function src_file() {
122 local SPEC="$1"
123 local SPLIT=(${SPEC//:/ })
124 local ARGS="$(target_args ${SPEC})"
125 # Regardless of there being a ":" delimiter or not in the spec,
126 # the source file is always either the first, or the only entry.
127 local SRC="${SPLIT[0]}"
128 # Remove target_args suffix, if present
129 echo "${SRC%;${ARGS}}"
130}
131
Steve Kondik5bd66602016-07-15 10:39:58 -0700132#
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300133# input: spec in the form of "src[:dst][;args]"
134# output: "dst" if present, "src" otherwise.
Steve Kondik5bd66602016-07-15 10:39:58 -0700135#
136function target_file() {
dianlujitao4918b8a2020-01-02 15:26:44 +0800137 local SPEC="${1%%;*}"
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300138 local SPLIT=(${SPEC//:/ })
139 local ARGS="$(target_args ${SPEC})"
140 local DST=
141 case ${#SPLIT[@]} in
142 1)
143 # The spec doesn't have a : delimiter
144 DST="${SPLIT[0]}"
145 ;;
146 *)
147 # The spec actually has a src:dst format
148 DST="${SPLIT[1]}"
149 ;;
150 esac
151 # Remove target_args suffix, if present
152 echo "${DST%;${ARGS}}"
Steve Kondik5bd66602016-07-15 10:39:58 -0700153}
154
155#
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300156# input: spec in the form of "src[:dst][;args]"
157# output: "args" if present, "" otherwise.
Steve Kondik5bd66602016-07-15 10:39:58 -0700158#
159function target_args() {
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300160 local SPEC="$1"
161 local SPLIT=(${SPEC//;/ })
162 local ARGS=
163 case ${#SPLIT[@]} in
164 1)
165 # No ";" delimiter in the spec.
166 ;;
167 *)
168 # The "args" are whatever comes after the ";" character.
169 # Basically the spec stripped of whatever is to the left of ";".
170 ARGS="${SPEC#${SPLIT[0]};}"
171 ;;
172 esac
173 echo "${ARGS}"
Steve Kondik5bd66602016-07-15 10:39:58 -0700174}
175
176#
177# prefix_match:
178#
Vladimir Oltean011b6b62018-06-12 01:17:35 +0300179# input:
180# - $1: prefix
181# - (global variable) PRODUCT_PACKAGES_LIST: array of [src:]dst[;args] specs.
182# output:
183# - new array consisting of dst[;args] entries where $1 is a prefix of ${dst}.
Steve Kondik5bd66602016-07-15 10:39:58 -0700184#
185function prefix_match() {
186 local PREFIX="$1"
Vladimir Oltean7220f362018-04-02 22:37:09 +0300187 for LINE in "${PRODUCT_PACKAGES_LIST[@]}"; do
188 local FILE=$(target_file "$LINE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700189 if [[ "$FILE" =~ ^"$PREFIX" ]]; then
Vladimir Oltean011b6b62018-06-12 01:17:35 +0300190 local ARGS=$(target_args "$LINE")
191 if [ -z "${ARGS}" ]; then
192 echo "${FILE#$PREFIX}"
193 else
194 echo "${FILE#$PREFIX};${ARGS}"
195 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700196 fi
197 done
198}
199
200#
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400201# prefix_match_file:
202#
203# $1: the prefix to match on
204# $2: the file to match the prefix for
205#
206# Internal function which returns true if a filename contains the
207# specified prefix.
208#
209function prefix_match_file() {
210 local PREFIX="$1"
211 local FILE="$2"
212 if [[ "$FILE" =~ ^"$PREFIX" ]]; then
213 return 0
214 else
215 return 1
216 fi
217}
218
219#
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -0700220# suffix_match_file:
221#
222# $1: the suffix to match on
223# $2: the file to match the suffix for
224#
225# Internal function which returns true if a filename contains the
226# specified suffix.
227#
228function suffix_match_file() {
229 local SUFFIX="$1"
230 local FILE="$2"
231 if [[ "$FILE" = *"$SUFFIX" ]]; then
232 return 0
233 else
234 return 1
235 fi
236}
237
238#
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400239# truncate_file
240#
241# $1: the filename to truncate
242# $2: the argument to output the truncated filename to
243#
244# Internal function which truncates a filename by removing the first dir
245# in the path. ex. vendor/lib/libsdmextension.so -> lib/libsdmextension.so
246#
247function truncate_file() {
248 local FILE="$1"
249 RETURN_FILE="$2"
250 local FIND="${FILE%%/*}"
251 local LOCATION="${#FIND}+1"
252 echo ${FILE:$LOCATION}
253}
254
255#
Steve Kondik5bd66602016-07-15 10:39:58 -0700256# write_product_copy_files:
257#
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400258# $1: make treble compatible makefile - optional and deprecated, default to true
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400259#
Steve Kondik5bd66602016-07-15 10:39:58 -0700260# Creates the PRODUCT_COPY_FILES section in the product makefile for all
261# items in the list which do not start with a dash (-).
262#
263function write_product_copy_files() {
264 local COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
265 local TARGET=
266 local FILE=
267 local LINEEND=
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400268 local TREBLE_COMPAT=$1
Steve Kondik5bd66602016-07-15 10:39:58 -0700269
270 if [ "$COUNT" -eq "0" ]; then
271 return 0
272 fi
273
274 printf '%s\n' "PRODUCT_COPY_FILES += \\" >> "$PRODUCTMK"
275 for (( i=1; i<COUNT+1; i++ )); do
276 FILE="${PRODUCT_COPY_FILES_LIST[$i-1]}"
277 LINEEND=" \\"
278 if [ "$i" -eq "$COUNT" ]; then
279 LINEEND=""
280 fi
281
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300282 TARGET=$(target_file "$FILE")
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400283 if prefix_match_file "product/" $TARGET ; then
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400284 local OUTTARGET=$(truncate_file $TARGET)
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400285 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_PRODUCT)/%s%s\n' \
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400286 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400287 elif prefix_match_file "system/product/" $TARGET ; then
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400288 local OUTTARGET=$(truncate_file $TARGET)
289 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_PRODUCT)/%s%s\n' \
290 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Luca Stefani776be462020-09-09 15:53:58 +0200291 elif prefix_match_file "system_ext/" $TARGET ; then
292 local OUTTARGET=$(truncate_file $TARGET)
293 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM_EXT)/%s%s\n' \
294 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
295 elif prefix_match_file "system/system_ext/" $TARGET ; then
296 local OUTTARGET=$(truncate_file $TARGET)
297 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM_EXT)/%s%s\n' \
298 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400299 elif prefix_match_file "odm/" $TARGET ; then
300 local OUTTARGET=$(truncate_file $TARGET)
301 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
302 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400303 elif prefix_match_file "vendor/odm/" $TARGET ; then
304 local OUTTARGET=$(truncate_file $TARGET)
305 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
306 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
307 elif prefix_match_file "system/vendor/odm/" $TARGET ; then
308 local OUTTARGET=$(truncate_file $TARGET)
309 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
310 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
311 elif prefix_match_file "vendor/" $TARGET ; then
312 local OUTTARGET=$(truncate_file $TARGET)
313 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
314 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
315 elif prefix_match_file "system/vendor/" $TARGET ; then
316 local OUTTARGET=$(truncate_file $TARGET)
317 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
318 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400319 elif prefix_match_file "system/" $TARGET ; then
320 local OUTTARGET=$(truncate_file $TARGET)
321 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
322 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400323 else
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400324 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400325 "$OUTDIR" "$TARGET" "$TARGET" "$LINEEND" >> "$PRODUCTMK"
326 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700327 done
328 return 0
329}
330
331#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700332# write_blueprint_packages:
Steve Kondik5bd66602016-07-15 10:39:58 -0700333#
334# $1: The LOCAL_MODULE_CLASS for the given module list
Luca Stefani776be462020-09-09 15:53:58 +0200335# $2: /system, /odm, /product, /system_ext, or /vendor partition
Steve Kondik5bd66602016-07-15 10:39:58 -0700336# $3: type-specific extra flags
337# $4: Name of the array holding the target list
338#
339# Internal function which writes out the BUILD_PREBUILT stanzas
340# for all modules in the list. This is called by write_product_packages
341# after the modules are categorized.
342#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700343function write_blueprint_packages() {
344
345 local CLASS="$1"
346 local PARTITION="$2"
347 local EXTRA="$3"
348
349 # Yes, this is a horrible hack - we create a new array using indirection
350 local ARR_NAME="$4[@]"
351 local FILELIST=("${!ARR_NAME}")
352
353 local FILE=
354 local ARGS=
355 local BASENAME=
356 local EXTENSION=
357 local PKGNAME=
358 local SRC=
359
360 for P in "${FILELIST[@]}"; do
361 FILE=$(target_file "$P")
362 ARGS=$(target_args "$P")
363
364 BASENAME=$(basename "$FILE")
365 DIRNAME=$(dirname "$FILE")
366 EXTENSION=${BASENAME##*.}
367 PKGNAME=${BASENAME%.*}
368
369 # Add to final package list
370 PACKAGE_LIST+=("$PKGNAME")
371
372 SRC="proprietary"
373 if [ "$PARTITION" = "system" ]; then
374 SRC+="/system"
375 elif [ "$PARTITION" = "vendor" ]; then
376 SRC+="/vendor"
377 elif [ "$PARTITION" = "product" ]; then
378 SRC+="/product"
Luca Stefani776be462020-09-09 15:53:58 +0200379 elif [ "$PARTITION" = "system_ext" ]; then
380 SRC+="/system_ext"
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700381 elif [ "$PARTITION" = "odm" ]; then
382 SRC+="/odm"
383 fi
384
385 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
386 printf 'cc_prebuilt_library_shared {\n'
387 printf '\tname: "%s",\n' "$PKGNAME"
388 printf '\towner: "%s",\n' "$VENDOR"
389 printf '\tstrip: {\n'
390 printf '\t\tnone: true,\n'
391 printf '\t},\n'
392 printf '\ttarget: {\n'
393 if [ "$EXTRA" = "both" ]; then
394 printf '\t\tandroid_arm: {\n'
395 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
396 printf '\t\t},\n'
397 printf '\t\tandroid_arm64: {\n'
398 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
399 printf '\t\t},\n'
400 elif [ "$EXTRA" = "64" ]; then
401 printf '\t\tandroid_arm64: {\n'
402 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
403 printf '\t\t},\n'
404 else
405 printf '\t\tandroid_arm: {\n'
406 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
407 printf '\t\t},\n'
408 fi
409 printf '\t},\n'
410 if [ "$EXTRA" != "none" ]; then
411 printf '\tcompile_multilib: "%s",\n' "$EXTRA"
412 fi
dianlujitao848101c2020-09-12 00:15:13 +0800413 printf '\tcheck_elf_files: false,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700414 elif [ "$CLASS" = "APPS" ]; then
415 printf 'android_app_import {\n'
416 printf '\tname: "%s",\n' "$PKGNAME"
417 printf '\towner: "%s",\n' "$VENDOR"
418 if [ "$EXTRA" = "priv-app" ]; then
419 SRC="$SRC/priv-app"
420 else
421 SRC="$SRC/app"
422 fi
423 printf '\tapk: "%s/%s",\n' "$SRC" "$FILE"
424 if [ "$ARGS" = "PRESIGNED" ]; then
425 printf '\tpresigned: true,\n'
426 elif [ ! -z "$ARGS" ]; then
427 printf '\tcertificate: "%s",\n' "$ARGS"
428 else
429 printf '\tcertificate: "platform",\n'
430 fi
431 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
432 printf 'dex_import {\n'
433 printf '\tname: "%s",\n' "$PKGNAME"
434 printf '\towner: "%s",\n' "$VENDOR"
435 printf '\tjars: ["%s/framework/%s"],\n' "$SRC" "$FILE"
436 elif [ "$CLASS" = "ETC" ]; then
437 if [ "$EXTENSION" = "xml" ]; then
438 printf 'prebuilt_etc_xml {\n'
439 else
440 printf 'prebuilt_etc {\n'
441 fi
442 printf '\tname: "%s",\n' "$PKGNAME"
443 printf '\towner: "%s",\n' "$VENDOR"
444 printf '\tsrc: "%s/etc/%s",\n' "$SRC" "$FILE"
LuK1337f7f18712020-10-06 19:29:02 +0200445 printf '\tfilename_from_src: true,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700446 elif [ "$CLASS" = "EXECUTABLES" ]; then
447 if [ "$EXTENSION" = "sh" ]; then
448 printf 'sh_binary {\n'
449 else
450 printf 'cc_prebuilt_binary {\n'
451 fi
452 printf '\tname: "%s",\n' "$PKGNAME"
453 printf '\towner: "%s",\n' "$VENDOR"
454 if [ "$ARGS" = "rootfs" ]; then
455 SRC="$SRC/rootfs"
456 if [ "$EXTRA" = "sbin" ]; then
457 SRC="$SRC/sbin"
458 printf '\tdist {\n'
459 printf '\t\tdest: "%s",\n' "root/sbin"
460 printf '\t},'
461 fi
462 else
463 SRC="$SRC/bin"
464 fi
465 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
Sebastiano Barezzifd4b2b32021-07-14 21:33:10 +0200466 if [ "$EXTENSION" != "sh" ]; then
467 printf '\tcheck_elf_files: false,\n'
468 fi
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700469 unset EXTENSION
470 else
471 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
472 fi
473 if [ "$CLASS" = "APPS" ]; then
474 printf '\tdex_preopt: {\n'
475 printf '\t\tenabled: false,\n'
476 printf '\t},\n'
477 fi
Andreas Schneiderdbcf9db2020-05-25 17:03:17 +0200478 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700479 if [ "$DIRNAME" != "." ]; then
Andreas Schneider408526a2020-05-23 15:58:43 +0200480 printf '\trelative_install_path: "%s",\n' "$DIRNAME"
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700481 fi
482 fi
Andreas Schneiderdbcf9db2020-05-25 17:03:17 +0200483 if [ "$CLASS" = "ETC" ] ; then
484 if [ "$DIRNAME" != "." ]; then
485 printf '\tsub_dir: "%s",\n' "$DIRNAME"
486 fi
487 fi
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700488 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
489 printf '\tprefer: true,\n'
490 fi
491 if [ "$EXTRA" = "priv-app" ]; then
492 printf '\tprivileged: true,\n'
493 fi
494 if [ "$PARTITION" = "vendor" ]; then
495 printf '\tsoc_specific: true,\n'
496 elif [ "$PARTITION" = "product" ]; then
497 printf '\tproduct_specific: true,\n'
Luca Stefani776be462020-09-09 15:53:58 +0200498 elif [ "$PARTITION" = "system_ext" ]; then
499 printf '\tsystem_ext_specific: true,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700500 elif [ "$PARTITION" = "odm" ]; then
501 printf '\tdevice_specific: true,\n'
502 fi
503 printf '}\n\n'
504 done
505}
506
507#
508# write_makefile_packages:
509#
510# $1: The LOCAL_MODULE_CLASS for the given module list
Luca Stefani776be462020-09-09 15:53:58 +0200511# $2: /odm, /product, /system_ext, or /vendor partition
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700512# $3: type-specific extra flags
513# $4: Name of the array holding the target list
514#
515# Internal function which writes out the BUILD_PREBUILT stanzas
516# for all modules in the list. This is called by write_product_packages
517# after the modules are categorized.
518#
519function write_makefile_packages() {
Steve Kondik5bd66602016-07-15 10:39:58 -0700520
521 local CLASS="$1"
razorlovesa0d296b2019-07-29 02:21:34 -0500522 local PARTITION="$2"
Steve Kondik5bd66602016-07-15 10:39:58 -0700523 local EXTRA="$3"
524
525 # Yes, this is a horrible hack - we create a new array using indirection
526 local ARR_NAME="$4[@]"
527 local FILELIST=("${!ARR_NAME}")
528
529 local FILE=
530 local ARGS=
531 local BASENAME=
532 local EXTENSION=
533 local PKGNAME=
534 local SRC=
535
536 for P in "${FILELIST[@]}"; do
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300537 FILE=$(target_file "$P")
Steve Kondik5bd66602016-07-15 10:39:58 -0700538 ARGS=$(target_args "$P")
539
540 BASENAME=$(basename "$FILE")
M1cha3e8c5bf2017-01-04 09:00:11 +0100541 DIRNAME=$(dirname "$FILE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700542 EXTENSION=${BASENAME##*.}
Mohd Farazcb0f4872019-10-08 16:13:50 +0530543 EXTENSION="."$EXTENSION
544 if [ "$EXTENSION" = ".jar" ]; then
545 EXTENSION="\$(COMMON_JAVA_PACKAGE_SUFFIX)"
546 elif [ "$EXTENSION" = ".apk" ]; then
547 EXTENSION="\$(COMMON_ANDROID_PACKAGE_SUFFIX)"
548 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700549 PKGNAME=${BASENAME%.*}
550
551 # Add to final package list
552 PACKAGE_LIST+=("$PKGNAME")
553
554 SRC="proprietary"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400555 if [ "$PARTITION" = "system" ]; then
556 SRC+="/system"
557 elif [ "$PARTITION" = "vendor" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -0700558 SRC+="/vendor"
razorlovesa0d296b2019-07-29 02:21:34 -0500559 elif [ "$PARTITION" = "product" ]; then
560 SRC+="/product"
Luca Stefani776be462020-09-09 15:53:58 +0200561 elif [ "$PARTITION" = "system_ext" ]; then
562 SRC+="/system_ext"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700563 elif [ "$PARTITION" = "odm" ]; then
564 SRC+="/odm"
Steve Kondik5bd66602016-07-15 10:39:58 -0700565 fi
566
567 printf 'include $(CLEAR_VARS)\n'
568 printf 'LOCAL_MODULE := %s\n' "$PKGNAME"
569 printf 'LOCAL_MODULE_OWNER := %s\n' "$VENDOR"
570 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
571 if [ "$EXTRA" = "both" ]; then
572 printf 'LOCAL_SRC_FILES_64 := %s/lib64/%s\n' "$SRC" "$FILE"
573 printf 'LOCAL_SRC_FILES_32 := %s/lib/%s\n' "$SRC" "$FILE"
574 #if [ "$VENDOR_PKG" = "true" ]; then
575 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
576 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
577 #else
578 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_SHARED_LIBRARIES)"
579 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_SHARED_LIBRARIES)"
580 #fi
581 elif [ "$EXTRA" = "64" ]; then
582 printf 'LOCAL_SRC_FILES := %s/lib64/%s\n' "$SRC" "$FILE"
583 else
584 printf 'LOCAL_SRC_FILES := %s/lib/%s\n' "$SRC" "$FILE"
585 fi
586 if [ "$EXTRA" != "none" ]; then
587 printf 'LOCAL_MULTILIB := %s\n' "$EXTRA"
588 fi
589 elif [ "$CLASS" = "APPS" ]; then
Michael Bestas9c6f2eb2018-01-25 21:05:36 +0200590 if [ "$EXTRA" = "priv-app" ]; then
591 SRC="$SRC/priv-app"
592 else
593 SRC="$SRC/app"
Steve Kondik5bd66602016-07-15 10:39:58 -0700594 fi
595 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
596 local CERT=platform
597 if [ ! -z "$ARGS" ]; then
598 CERT="$ARGS"
599 fi
600 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
601 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
602 printf 'LOCAL_SRC_FILES := %s/framework/%s\n' "$SRC" "$FILE"
Elektroschmockdd792302016-10-04 21:11:43 +0200603 local CERT=platform
604 if [ ! -z "$ARGS" ]; then
605 CERT="$ARGS"
606 fi
607 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
Steve Kondik5bd66602016-07-15 10:39:58 -0700608 elif [ "$CLASS" = "ETC" ]; then
609 printf 'LOCAL_SRC_FILES := %s/etc/%s\n' "$SRC" "$FILE"
610 elif [ "$CLASS" = "EXECUTABLES" ]; then
611 if [ "$ARGS" = "rootfs" ]; then
612 SRC="$SRC/rootfs"
613 if [ "$EXTRA" = "sbin" ]; then
614 SRC="$SRC/sbin"
615 printf '%s\n' "LOCAL_MODULE_PATH := \$(TARGET_ROOT_OUT_SBIN)"
616 printf '%s\n' "LOCAL_UNSTRIPPED_PATH := \$(TARGET_ROOT_OUT_SBIN_UNSTRIPPED)"
617 fi
618 else
619 SRC="$SRC/bin"
620 fi
621 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
622 unset EXTENSION
623 else
624 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
625 fi
626 printf 'LOCAL_MODULE_TAGS := optional\n'
627 printf 'LOCAL_MODULE_CLASS := %s\n' "$CLASS"
Hashbang173575f3bb2016-08-28 20:38:45 -0400628 if [ "$CLASS" = "APPS" ]; then
629 printf 'LOCAL_DEX_PREOPT := false\n'
630 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700631 if [ ! -z "$EXTENSION" ]; then
Mohd Farazcb0f4872019-10-08 16:13:50 +0530632 printf 'LOCAL_MODULE_SUFFIX := %s\n' "$EXTENSION"
Steve Kondik5bd66602016-07-15 10:39:58 -0700633 fi
M1cha3e8c5bf2017-01-04 09:00:11 +0100634 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ]; then
635 if [ "$DIRNAME" != "." ]; then
636 printf 'LOCAL_MODULE_RELATIVE_PATH := %s\n' "$DIRNAME"
637 fi
638 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700639 if [ "$EXTRA" = "priv-app" ]; then
640 printf 'LOCAL_PRIVILEGED_MODULE := true\n'
641 fi
razorlovesa0d296b2019-07-29 02:21:34 -0500642 if [ "$PARTITION" = "vendor" ]; then
Ethan Chen4f738f52018-02-17 20:03:54 -0800643 printf 'LOCAL_VENDOR_MODULE := true\n'
razorlovesa0d296b2019-07-29 02:21:34 -0500644 elif [ "$PARTITION" = "product" ]; then
645 printf 'LOCAL_PRODUCT_MODULE := true\n'
Luca Stefani776be462020-09-09 15:53:58 +0200646 elif [ "$PARTITION" = "system_ext" ]; then
647 printf 'LOCAL_SYSTEM_EXT_MODULE := true\n'
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700648 elif [ "$PARTITION" = "odm" ]; then
649 printf 'LOCAL_ODM_MODULE := true\n'
Steve Kondik5bd66602016-07-15 10:39:58 -0700650 fi
651 printf 'include $(BUILD_PREBUILT)\n\n'
652 done
653}
654
655#
656# write_product_packages:
657#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700658# This function will create prebuilt entries in the
659# Android.bp and associated PRODUCT_PACKAGES list in the
Steve Kondik5bd66602016-07-15 10:39:58 -0700660# product makefile for all files in the blob list which
661# start with a single dash (-) character.
662#
663function write_product_packages() {
664 PACKAGE_LIST=()
665
666 local COUNT=${#PRODUCT_PACKAGES_LIST[@]}
667
668 if [ "$COUNT" = "0" ]; then
669 return 0
670 fi
671
672 # Figure out what's 32-bit, what's 64-bit, and what's multilib
673 # I really should not be doing this in bash due to shitty array passing :(
674 local T_LIB32=( $(prefix_match "lib/") )
675 local T_LIB64=( $(prefix_match "lib64/") )
676 local MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${T_LIB64[@]}")) )
677 local LIB32=( $(comm -23 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
678 local LIB64=( $(comm -23 <(printf '%s\n' "${T_LIB64[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
679
680 if [ "${#MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700681 write_blueprint_packages "SHARED_LIBRARIES" "" "both" "MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700682 fi
683 if [ "${#LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700684 write_blueprint_packages "SHARED_LIBRARIES" "" "32" "LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700685 fi
686 if [ "${#LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700687 write_blueprint_packages "SHARED_LIBRARIES" "" "64" "LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700688 fi
689
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400690 local T_S_LIB32=( $(prefix_match "system/lib/") )
691 local T_S_LIB64=( $(prefix_match "system/lib64/") )
692 local S_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${T_S_LIB64[@]}")) )
693 local S_LIB32=( $(comm -23 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
694 local S_LIB64=( $(comm -23 <(printf '%s\n' "${T_S_LIB64[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
695
696 if [ "${#S_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700697 write_blueprint_packages "SHARED_LIBRARIES" "system" "both" "S_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400698 fi
699 if [ "${#S_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700700 write_blueprint_packages "SHARED_LIBRARIES" "system" "32" "S_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400701 fi
702 if [ "${#S_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700703 write_blueprint_packages "SHARED_LIBRARIES" "system" "64" "S_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400704 fi
705
Steve Kondik5bd66602016-07-15 10:39:58 -0700706 local T_V_LIB32=( $(prefix_match "vendor/lib/") )
707 local T_V_LIB64=( $(prefix_match "vendor/lib64/") )
708 local V_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${T_V_LIB64[@]}")) )
709 local V_LIB32=( $(comm -23 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
710 local V_LIB64=( $(comm -23 <(printf '%s\n' "${T_V_LIB64[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
711
712 if [ "${#V_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700713 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "both" "V_MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700714 fi
715 if [ "${#V_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700716 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "32" "V_LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700717 fi
718 if [ "${#V_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700719 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "64" "V_LIB64" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500720 fi
721
722 local T_P_LIB32=( $(prefix_match "product/lib/") )
723 local T_P_LIB64=( $(prefix_match "product/lib64/") )
724 local P_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${T_P_LIB64[@]}")) )
725 local P_LIB32=( $(comm -23 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
726 local P_LIB64=( $(comm -23 <(printf '%s\n' "${T_P_LIB64[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
727
728 if [ "${#P_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700729 write_blueprint_packages "SHARED_LIBRARIES" "product" "both" "P_MULTILIBS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500730 fi
731 if [ "${#P_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700732 write_blueprint_packages "SHARED_LIBRARIES" "product" "32" "P_LIB32" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500733 fi
734 if [ "${#P_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700735 write_blueprint_packages "SHARED_LIBRARIES" "product" "64" "P_LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700736 fi
737
Luca Stefani776be462020-09-09 15:53:58 +0200738 local T_SE_LIB32=( $(prefix_match "system_ext/lib/") )
739 local T_SE_LIB64=( $(prefix_match "system_ext/lib64/") )
740 local SE_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_SE_LIB32[@]}") <(printf '%s\n' "${T_SE_LIB64[@]}")) )
741 local SE_LIB32=( $(comm -23 <(printf '%s\n' "${T_SE_LIB32[@]}") <(printf '%s\n' "${SE_MULTILIBS[@]}")) )
742 local SE_LIB64=( $(comm -23 <(printf '%s\n' "${T_SE_LIB64[@]}") <(printf '%s\n' "${SE_MULTILIBS[@]}")) )
743
744 if [ "${#SE_MULTILIBS[@]}" -gt "0" ]; then
745 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "both" "SE_MULTILIBS" >> "$ANDROIDBP"
746 fi
747 if [ "${#SE_LIB32[@]}" -gt "0" ]; then
748 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "32" "SE_LIB32" >> "$ANDROIDBP"
749 fi
750 if [ "${#SE_LIB64[@]}" -gt "0" ]; then
751 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "64" "SE_LIB64" >> "$ANDROIDBP"
752 fi
753
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700754 local T_O_LIB32=( $(prefix_match "odm/lib/") )
755 local T_O_LIB64=( $(prefix_match "odm/lib64/") )
756 local O_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${T_O_LIB64[@]}")) )
757 local O_LIB32=( $(comm -23 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
758 local O_LIB64=( $(comm -23 <(printf '%s\n' "${T_O_LIB64[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
759
760 if [ "${#O_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700761 write_blueprint_packages "SHARED_LIBRARIES" "odm" "both" "O_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700762 fi
763 if [ "${#O_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700764 write_blueprint_packages "SHARED_LIBRARIES" "odm" "32" "O_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700765 fi
766 if [ "${#O_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700767 write_blueprint_packages "SHARED_LIBRARIES" "odm" "64" "O_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700768 fi
769
Steve Kondik5bd66602016-07-15 10:39:58 -0700770 # Apps
771 local APPS=( $(prefix_match "app/") )
772 if [ "${#APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100773 write_blueprint_packages "APPS" "" "" "APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700774 fi
775 local PRIV_APPS=( $(prefix_match "priv-app/") )
776 if [ "${#PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100777 write_blueprint_packages "APPS" "" "priv-app" "PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700778 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400779 local S_APPS=( $(prefix_match "system/app/") )
780 if [ "${#S_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100781 write_blueprint_packages "APPS" "system" "" "S_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400782 fi
783 local S_PRIV_APPS=( $(prefix_match "system/priv-app/") )
784 if [ "${#S_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100785 write_blueprint_packages "APPS" "system" "priv-app" "S_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400786 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700787 local V_APPS=( $(prefix_match "vendor/app/") )
788 if [ "${#V_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100789 write_blueprint_packages "APPS" "vendor" "" "V_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700790 fi
791 local V_PRIV_APPS=( $(prefix_match "vendor/priv-app/") )
792 if [ "${#V_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100793 write_blueprint_packages "APPS" "vendor" "priv-app" "V_PRIV_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500794 fi
795 local P_APPS=( $(prefix_match "product/app/") )
796 if [ "${#P_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100797 write_blueprint_packages "APPS" "product" "" "P_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500798 fi
799 local P_PRIV_APPS=( $(prefix_match "product/priv-app/") )
800 if [ "${#P_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100801 write_blueprint_packages "APPS" "product" "priv-app" "P_PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700802 fi
Luca Stefani776be462020-09-09 15:53:58 +0200803 local SE_APPS=( $(prefix_match "system_ext/app/") )
804 if [ "${#SE_APPS[@]}" -gt "0" ]; then
805 write_blueprint_packages "APPS" "system_ext" "" "SE_APPS" >> "$ANDROIDBP"
806 fi
807 local SE_PRIV_APPS=( $(prefix_match "system_ext/priv-app/") )
808 if [ "${#SE_PRIV_APPS[@]}" -gt "0" ]; then
809 write_blueprint_packages "APPS" "system_ext" "priv-app" "SE_PRIV_APPS" >> "$ANDROIDBP"
810 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700811 local O_APPS=( $(prefix_match "odm/app/") )
812 if [ "${#O_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100813 write_blueprint_packages "APPS" "odm" "" "O_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700814 fi
815 local O_PRIV_APPS=( $(prefix_match "odm/priv-app/") )
816 if [ "${#O_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100817 write_blueprint_packages "APPS" "odm" "priv-app" "O_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700818 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700819
820 # Framework
821 local FRAMEWORK=( $(prefix_match "framework/") )
822 if [ "${#FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700823 write_blueprint_packages "JAVA_LIBRARIES" "" "" "FRAMEWORK" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700824 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400825 local S_FRAMEWORK=( $(prefix_match "system/framework/") )
826 if [ "${#S_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700827 write_blueprint_packages "JAVA_LIBRARIES" "system" "" "S_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400828 fi
Christian Oder974b5902017-10-08 23:15:52 +0200829 local V_FRAMEWORK=( $(prefix_match "vendor/framework/") )
Michael Bestas26eb01e2018-02-27 22:31:55 +0200830 if [ "${#V_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700831 write_blueprint_packages "JAVA_LIBRARIES" "vendor" "" "V_FRAMEWORK" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500832 fi
833 local P_FRAMEWORK=( $(prefix_match "product/framework/") )
834 if [ "${#P_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700835 write_blueprint_packages "JAVA_LIBRARIES" "product" "" "P_FRAMEWORK" >> "$ANDROIDBP"
Christian Oder974b5902017-10-08 23:15:52 +0200836 fi
Luca Stefani776be462020-09-09 15:53:58 +0200837 local SE_FRAMEWORK=( $(prefix_match "system_ext/framework/") )
Alexander Koskovich052c77d2020-09-16 17:58:53 -0700838 if [ "${#SE_FRAMEWORK[@]}" -gt "0" ]; then
Luca Stefani776be462020-09-09 15:53:58 +0200839 write_blueprint_packages "JAVA_LIBRARIES" "system_ext" "" "SE_FRAMEWORK" >> "$ANDROIDBP"
840 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700841 local O_FRAMEWORK=( $(prefix_match "odm/framework/") )
842 if [ "${#O_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700843 write_blueprint_packages "JAVA_LIBRARIES" "odm" "" "O_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700844 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700845
846 # Etc
847 local ETC=( $(prefix_match "etc/") )
848 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700849 write_blueprint_packages "ETC" "" "" "ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700850 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400851 local S_ETC=( $(prefix_match "system/etc/") )
852 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700853 write_blueprint_packages "ETC" "system" "" "S_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400854 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700855 local V_ETC=( $(prefix_match "vendor/etc/") )
856 if [ "${#V_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700857 write_blueprint_packages "ETC" "vendor" "" "V_ETC" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500858 fi
859 local P_ETC=( $(prefix_match "product/etc/") )
860 if [ "${#P_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700861 write_blueprint_packages "ETC" "product" "" "P_ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700862 fi
Luca Stefani776be462020-09-09 15:53:58 +0200863 local SE_ETC=( $(prefix_match "system_ext/etc/") )
864 if [ "${#SE_ETC[@]}" -gt "0" ]; then
865 write_blueprint_packages "ETC" "system_ext" "" "SE_ETC" >> "$ANDROIDBP"
866 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700867 local O_ETC=( $(prefix_match "odm/etc/") )
868 if [ "${#O_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700869 write_blueprint_packages "ETC" "odm" "" "O_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700870 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700871
872 # Executables
873 local BIN=( $(prefix_match "bin/") )
874 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700875 write_blueprint_packages "EXECUTABLES" "" "" "BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700876 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400877 local S_BIN=( $(prefix_match "system/bin/") )
878 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700879 write_blueprint_packages "EXECUTABLES" "system" "" "S_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400880 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700881 local V_BIN=( $(prefix_match "vendor/bin/") )
882 if [ "${#V_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700883 write_blueprint_packages "EXECUTABLES" "vendor" "" "V_BIN" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500884 fi
885 local P_BIN=( $(prefix_match "product/bin/") )
886 if [ "${#P_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700887 write_blueprint_packages "EXECUTABLES" "product" "" "P_BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700888 fi
Luca Stefani776be462020-09-09 15:53:58 +0200889 local SE_BIN=( $(prefix_match "system_ext/bin/") )
890 if [ "${#SE_BIN[@]}" -gt "0" ]; then
891 write_blueprint_packages "EXECUTABLES" "system_ext" "" "SE_BIN" >> "$ANDROIDBP"
892 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700893 local O_BIN=( $(prefix_match "odm/bin/") )
894 if [ "${#O_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700895 write_blueprint_packages "EXECUTABLES" "odm" "" "O_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700896 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700897 local SBIN=( $(prefix_match "sbin/") )
898 if [ "${#SBIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700899 write_makefile_packages "EXECUTABLES" "" "sbin" "SBIN" >> "$ANDROIDMK"
Steve Kondik5bd66602016-07-15 10:39:58 -0700900 fi
901
902
903 # Actually write out the final PRODUCT_PACKAGES list
904 local PACKAGE_COUNT=${#PACKAGE_LIST[@]}
905
906 if [ "$PACKAGE_COUNT" -eq "0" ]; then
907 return 0
908 fi
909
910 printf '\n%s\n' "PRODUCT_PACKAGES += \\" >> "$PRODUCTMK"
911 for (( i=1; i<PACKAGE_COUNT+1; i++ )); do
912 local LINEEND=" \\"
913 if [ "$i" -eq "$PACKAGE_COUNT" ]; then
914 LINEEND=""
915 fi
916 printf ' %s%s\n' "${PACKAGE_LIST[$i-1]}" "$LINEEND" >> "$PRODUCTMK"
917 done
918}
919
920#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700921# write_blueprint_header:
Steve Kondik5bd66602016-07-15 10:39:58 -0700922#
923# $1: file which will be written to
924#
Michael Bestasa2934df2020-12-19 03:50:32 +0200925# writes out the warning message regarding manual file modifications.
Steve Kondik5bd66602016-07-15 10:39:58 -0700926# note that this is not an append operation, and should
927# be executed first!
928#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700929function write_blueprint_header() {
930 if [ -f $1 ]; then
931 rm $1
932 fi
933
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700934 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
935
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700936 cat << EOF >> $1
Michael Bestasa2934df2020-12-19 03:50:32 +0200937// Automatically generated file. DO NOT MODIFY
938//
939// This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700940
941EOF
942}
943
944#
945# write_makefile_header:
946#
947# $1: file which will be written to
948#
Michael Bestasa2934df2020-12-19 03:50:32 +0200949# writes out the warning message regarding manual file modifications.
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700950# note that this is not an append operation, and should
951# be executed first!
952#
953function write_makefile_header() {
Jake Whatley9843b322017-01-25 21:49:16 -0500954 if [ -f $1 ]; then
955 rm $1
956 fi
957
Steve Kondik5bd66602016-07-15 10:39:58 -0700958 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
959
Jake Whatley9843b322017-01-25 21:49:16 -0500960 cat << EOF >> $1
Michael Bestasa2934df2020-12-19 03:50:32 +0200961# Automatically generated file. DO NOT MODIFY
Steve Kondik5bd66602016-07-15 10:39:58 -0700962#
Steve Kondik5bd66602016-07-15 10:39:58 -0700963# This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
964
965EOF
966}
967
968#
969# write_headers:
970#
971# $1: devices falling under common to be added to guard - optional
Jake Whatley9843b322017-01-25 21:49:16 -0500972# $2: custom guard - optional
Steve Kondik5bd66602016-07-15 10:39:58 -0700973#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700974# Calls write_makefile_header for each of the makefiles and
975# write_blueprint_header for Android.bp and creates the initial
976# path declaration and device guard for the Android.mk
Steve Kondik5bd66602016-07-15 10:39:58 -0700977#
978function write_headers() {
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700979 write_makefile_header "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500980
981 GUARD="$2"
982 if [ -z "$GUARD" ]; then
983 GUARD="TARGET_DEVICE"
984 fi
985
Steve Kondik5bd66602016-07-15 10:39:58 -0700986 cat << EOF >> "$ANDROIDMK"
987LOCAL_PATH := \$(call my-dir)
988
989EOF
990 if [ "$COMMON" -ne 1 ]; then
991 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500992ifeq (\$($GUARD),$DEVICE)
Steve Kondik5bd66602016-07-15 10:39:58 -0700993
994EOF
995 else
996 if [ -z "$1" ]; then
997 echo "Argument with devices to be added to guard must be set!"
998 exit 1
999 fi
1000 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -05001001ifneq (\$(filter $1,\$($GUARD)),)
Steve Kondik5bd66602016-07-15 10:39:58 -07001002
1003EOF
1004 fi
1005
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001006 write_makefile_header "$BOARDMK"
1007 write_makefile_header "$PRODUCTMK"
1008 write_blueprint_header "$ANDROIDBP"
1009
1010 cat << EOF >> "$ANDROIDBP"
1011soong_namespace {
1012}
1013
1014EOF
1015
1016 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
1017 cat << EOF >> "$PRODUCTMK"
1018PRODUCT_SOONG_NAMESPACES += \\
1019 vendor/$VENDOR/$DEVICE
1020
1021EOF
Steve Kondik5bd66602016-07-15 10:39:58 -07001022}
1023
1024#
1025# write_footers:
1026#
1027# Closes the inital guard and any other finalization tasks. Must
1028# be called as the final step.
1029#
1030function write_footers() {
1031 cat << EOF >> "$ANDROIDMK"
1032endif
1033EOF
1034}
1035
1036# Return success if adb is up and not in recovery
1037function _adb_connected {
1038 {
Jake Whatley9843b322017-01-25 21:49:16 -05001039 if [[ "$(adb get-state)" == device ]]
Steve Kondik5bd66602016-07-15 10:39:58 -07001040 then
1041 return 0
1042 fi
1043 } 2>/dev/null
1044
1045 return 1
1046};
1047
1048#
1049# parse_file_list:
1050#
1051# $1: input file
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001052# $2: blob section in file - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001053#
1054# Sets PRODUCT_PACKAGES and PRODUCT_COPY_FILES while parsing the input file
1055#
1056function parse_file_list() {
1057 if [ -z "$1" ]; then
1058 echo "An input file is expected!"
1059 exit 1
1060 elif [ ! -f "$1" ]; then
1061 echo "Input file "$1" does not exist!"
1062 exit 1
1063 fi
1064
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001065 if [ -n "$2" ]; then
1066 echo "Using section \"$2\""
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001067 LIST=$TMPDIR/files.txt
Vladimir Olteanfa79f212019-01-19 00:44:07 +02001068 # Match all lines starting with first line found to start* with '#'
1069 # comment and contain** $2, and ending with first line to be empty*.
1070 # *whitespaces (tabs, spaces) at the beginning of lines are discarded
1071 # **the $2 match is case-insensitive
1072 cat $1 | sed -n '/^[[:space:]]*#.*'"$2"'/I,/^[[:space:]]*$/ p' > $LIST
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001073 else
1074 LIST=$1
1075 fi
1076
1077
Steve Kondik5bd66602016-07-15 10:39:58 -07001078 PRODUCT_PACKAGES_LIST=()
1079 PRODUCT_PACKAGES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001080 PRODUCT_PACKAGES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001081 PRODUCT_COPY_FILES_LIST=()
1082 PRODUCT_COPY_FILES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001083 PRODUCT_COPY_FILES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001084
1085 while read -r line; do
1086 if [ -z "$line" ]; then continue; fi
1087
1088 # If the line has a pipe delimiter, a sha1 hash should follow.
1089 # This indicates the file should be pinned and not overwritten
1090 # when extracting files.
1091 local SPLIT=(${line//\|/ })
1092 local COUNT=${#SPLIT[@]}
1093 local SPEC=${SPLIT[0]}
1094 local HASH="x"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001095 local FIXUP_HASH="x"
Steve Kondik5bd66602016-07-15 10:39:58 -07001096 if [ "$COUNT" -gt "1" ]; then
1097 HASH=${SPLIT[1]}
1098 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001099 if [ "$COUNT" -gt "2" ]; then
1100 FIXUP_HASH=${SPLIT[2]}
1101 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001102
1103 # if line starts with a dash, it needs to be packaged
1104 if [[ "$SPEC" =~ ^- ]]; then
1105 PRODUCT_PACKAGES_LIST+=("${SPEC#-}")
1106 PRODUCT_PACKAGES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001107 PRODUCT_PACKAGES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001108 else
1109 PRODUCT_COPY_FILES_LIST+=("$SPEC")
1110 PRODUCT_COPY_FILES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001111 PRODUCT_COPY_FILES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001112 fi
1113
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001114 done < <(egrep -v '(^#|^[[:space:]]*$)' "$LIST" | LC_ALL=C sort | uniq)
Steve Kondik5bd66602016-07-15 10:39:58 -07001115}
1116
1117#
1118# write_makefiles:
1119#
1120# $1: file containing the list of items to extract
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001121# $2: make treble compatible makefile - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001122#
1123# Calls write_product_copy_files and write_product_packages on
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001124# the given file and appends to the Android.bp as well as
Steve Kondik5bd66602016-07-15 10:39:58 -07001125# the product makefile.
1126#
1127function write_makefiles() {
1128 parse_file_list "$1"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001129 write_product_copy_files "$2"
Steve Kondik5bd66602016-07-15 10:39:58 -07001130 write_product_packages
1131}
1132
1133#
1134# append_firmware_calls_to_makefiles:
1135#
1136# Appends to Android.mk the calls to all images present in radio folder
1137# (filesmap file used by releasetools to map firmware images should be kept in the device tree)
1138#
1139function append_firmware_calls_to_makefiles() {
1140 cat << EOF >> "$ANDROIDMK"
1141ifeq (\$(LOCAL_PATH)/radio, \$(wildcard \$(LOCAL_PATH)/radio))
1142
1143RADIO_FILES := \$(wildcard \$(LOCAL_PATH)/radio/*)
1144\$(foreach f, \$(notdir \$(RADIO_FILES)), \\
1145 \$(call add-radio-file,radio/\$(f)))
1146\$(call add-radio-file,../../../device/$VENDOR/$DEVICE/radio/filesmap)
1147
1148endif
1149
1150EOF
1151}
1152
1153#
1154# get_file:
1155#
1156# $1: input file
1157# $2: target file/folder
1158# $3: source of the file (can be "adb" or a local folder)
1159#
1160# Silently extracts the input file to defined target
1161# Returns success if file can be pulled from the device or found locally
1162#
1163function get_file() {
1164 local SRC="$3"
1165
1166 if [ "$SRC" = "adb" ]; then
1167 # try to pull
1168 adb pull "$1" "$2" >/dev/null 2>&1 && return 0
1169
1170 return 1
1171 else
1172 # try to copy
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001173 cp -r "$SRC/$1" "$2" 2>/dev/null && return 0
1174 cp -r "$SRC/${1#/system}" "$2" 2>/dev/null && return 0
Vladimir Oltean6780da32019-01-06 19:38:31 +02001175 cp -r "$SRC/system/$1" "$2" 2>/dev/null && return 0
Steve Kondik5bd66602016-07-15 10:39:58 -07001176
1177 return 1
1178 fi
1179};
1180
1181#
1182# oat2dex:
1183#
1184# $1: extracted apk|jar (to check if deodex is required)
1185# $2: odexed apk|jar to deodex
1186# $3: source of the odexed apk|jar
1187#
1188# Convert apk|jar .odex in the corresposing classes.dex
1189#
1190function oat2dex() {
theimpulson9a911af2019-08-14 03:25:12 +00001191 local OMNI_TARGET="$1"
Steve Kondik5bd66602016-07-15 10:39:58 -07001192 local OEM_TARGET="$2"
1193 local SRC="$3"
1194 local TARGET=
Joe Maplesfb3941c2018-01-05 14:51:33 -05001195 local OAT=
Steve Kondik5bd66602016-07-15 10:39:58 -07001196
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001197 if [ -z "$BAKSMALIJAR" ] || [ -z "$SMALIJAR" ]; then
1198 export BAKSMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/baksmali.jar
1199 export SMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/smali.jar
Steve Kondik5bd66602016-07-15 10:39:58 -07001200 fi
1201
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001202 if [ -z "$VDEXEXTRACTOR" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001203 export VDEXEXTRACTOR="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/vdexExtractor
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001204 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001205
codeworkx85eda752018-09-23 12:36:57 +02001206 if [ -z "$CDEXCONVERTER" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001207 export CDEXCONVERTER="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/compact_dex_converter
codeworkx85eda752018-09-23 12:36:57 +02001208 fi
1209
Steve Kondik5bd66602016-07-15 10:39:58 -07001210 # Extract existing boot.oats to the temp folder
1211 if [ -z "$ARCHES" ]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001212 echo "Checking if system is odexed and locating boot.oats..."
Steve Kondik5bd66602016-07-15 10:39:58 -07001213 for ARCH in "arm64" "arm" "x86_64" "x86"; do
Jake Whatley9843b322017-01-25 21:49:16 -05001214 mkdir -p "$TMPDIR/system/framework/$ARCH"
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001215 if get_file "/system/framework/$ARCH" "$TMPDIR/system/framework/" "$SRC"; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001216 ARCHES+="$ARCH "
Jake Whatley9843b322017-01-25 21:49:16 -05001217 else
1218 rmdir "$TMPDIR/system/framework/$ARCH"
Steve Kondik5bd66602016-07-15 10:39:58 -07001219 fi
1220 done
1221 fi
1222
1223 if [ -z "$ARCHES" ]; then
1224 FULLY_DEODEXED=1 && return 0 # system is fully deodexed, return
1225 fi
1226
theimpulson9a911af2019-08-14 03:25:12 +00001227 if [ ! -f "$OMNI_TARGET" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001228 return;
1229 fi
1230
theimpulson9a911af2019-08-14 03:25:12 +00001231 if grep "classes.dex" "$OMNI_TARGET" >/dev/null; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001232 return 0 # target apk|jar is already odexed, return
1233 fi
1234
1235 for ARCH in $ARCHES; do
Jake Whatley9843b322017-01-25 21:49:16 -05001236 BOOTOAT="$TMPDIR/system/framework/$ARCH/boot.oat"
Steve Kondik5bd66602016-07-15 10:39:58 -07001237
Joe Maplesfb3941c2018-01-05 14:51:33 -05001238 local OAT="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").odex"
1239 local VDEX="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").vdex"
Steve Kondik5bd66602016-07-15 10:39:58 -07001240
Joe Maplesfb3941c2018-01-05 14:51:33 -05001241 if get_file "$OAT" "$TMPDIR" "$SRC"; then
1242 if get_file "$VDEX" "$TMPDIR" "$SRC"; then
1243 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$VDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001244 CLASSES=$(ls "$TMPDIR/$(basename "${OEM_TARGET%.*}")_classes"*)
1245 for CLASS in $CLASSES; do
1246 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1247 # Check if we have to deal with CompactDex
1248 if [[ "$CLASS" == *.cdex ]]; then
1249 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1250 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1251 else
1252 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1253 fi
1254 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001255 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001256 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$TMPDIR/$(basename "$OAT")"
1257 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001258 fi
theimpulson9a911af2019-08-14 03:25:12 +00001259 elif [[ "$OMNI_TARGET" =~ .jar$ ]]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001260 JAROAT="$TMPDIR/system/framework/$ARCH/boot-$(basename ${OEM_TARGET%.*}).oat"
Luca Stefani082f1e82018-10-07 12:44:53 +02001261 JARVDEX="/system/framework/boot-$(basename ${OEM_TARGET%.*}).vdex"
Jake Whatley9843b322017-01-25 21:49:16 -05001262 if [ ! -f "$JAROAT" ]; then
Luca Stefani082f1e82018-10-07 12:44:53 +02001263 JAROAT=$BOOTOAT
Jake Whatley9843b322017-01-25 21:49:16 -05001264 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001265 # try to extract classes.dex from boot.vdex for frameworks jars
1266 # fallback to boot.oat if vdex is not available
Luca Stefani082f1e82018-10-07 12:44:53 +02001267 if get_file "$JARVDEX" "$TMPDIR" "$SRC"; then
Luca Stefani6f92e6b2018-10-31 19:16:05 +01001268 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$JARVDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001269 CLASSES=$(ls "$TMPDIR/$(basename "${JARVDEX%.*}")_classes"*)
1270 for CLASS in $CLASSES; do
1271 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1272 # Check if we have to deal with CompactDex
1273 if [[ "$CLASS" == *.cdex ]]; then
1274 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1275 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1276 else
1277 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1278 fi
1279 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001280 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001281 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$JAROAT/$OEM_TARGET"
1282 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001283 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001284 else
1285 continue
1286 fi
1287
Steve Kondik5bd66602016-07-15 10:39:58 -07001288 done
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001289
1290 rm -rf "$TMPDIR/dexout"
Steve Kondik5bd66602016-07-15 10:39:58 -07001291}
1292
1293#
1294# init_adb_connection:
1295#
1296# Starts adb server and waits for the device
1297#
1298function init_adb_connection() {
1299 adb start-server # Prevent unexpected starting server message from adb get-state in the next line
1300 if ! _adb_connected; then
1301 echo "No device is online. Waiting for one..."
1302 echo "Please connect USB and/or enable USB debugging"
1303 until _adb_connected; do
1304 sleep 1
1305 done
1306 echo "Device Found."
1307 fi
1308
1309 # Retrieve IP and PORT info if we're using a TCP connection
1310 TCPIPPORT=$(adb devices | egrep '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+[^0-9]+' \
1311 | head -1 | awk '{print $1}')
1312 adb root &> /dev/null
1313 sleep 0.3
1314 if [ -n "$TCPIPPORT" ]; then
1315 # adb root just killed our connection
1316 # so reconnect...
1317 adb connect "$TCPIPPORT"
1318 fi
1319 adb wait-for-device &> /dev/null
1320 sleep 0.3
1321}
1322
1323#
1324# fix_xml:
1325#
1326# $1: xml file to fix
1327#
1328function fix_xml() {
1329 local XML="$1"
1330 local TEMP_XML="$TMPDIR/`basename "$XML"`.temp"
1331
Dobroslaw Kijowski3af2a8d2017-05-18 12:35:02 +02001332 grep -a '^<?xml version' "$XML" > "$TEMP_XML"
1333 grep -av '^<?xml version' "$XML" >> "$TEMP_XML"
Steve Kondik5bd66602016-07-15 10:39:58 -07001334
1335 mv "$TEMP_XML" "$XML"
1336}
1337
Vladimir Olteande985fe2019-01-17 03:07:34 +02001338function get_hash() {
1339 local FILE="$1"
1340
1341 if [ "$(uname)" == "Darwin" ]; then
1342 shasum "${FILE}" | awk '{print $1}'
1343 else
1344 sha1sum "${FILE}" | awk '{print $1}'
1345 fi
1346}
1347
Vladimir Olteana7d20492019-01-17 03:05:52 +02001348function print_spec() {
1349 local SPEC_PRODUCT_PACKAGE="$1"
1350 local SPEC_SRC_FILE="$2"
1351 local SPEC_DST_FILE="$3"
1352 local SPEC_ARGS="$4"
1353 local SPEC_HASH="$5"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001354 local SPEC_FIXUP_HASH="$6"
Vladimir Olteana7d20492019-01-17 03:05:52 +02001355
1356 local PRODUCT_PACKAGE=""
1357 if [ ${SPEC_PRODUCT_PACKAGE} = true ]; then
1358 PRODUCT_PACKAGE="-"
1359 fi
1360 local SRC=""
1361 if [ ! -z "${SPEC_SRC_FILE}" ] && [ "${SPEC_SRC_FILE}" != "${SPEC_DST_FILE}" ]; then
1362 SRC="${SPEC_SRC_FILE}:"
1363 fi
1364 local DST=""
1365 if [ ! -z "${SPEC_DST_FILE}" ]; then
1366 DST="${SPEC_DST_FILE}"
1367 fi
1368 local ARGS=""
1369 if [ ! -z "${SPEC_ARGS}" ]; then
1370 ARGS=";${SPEC_ARGS}"
1371 fi
1372 local HASH=""
1373 if [ ! -z "${SPEC_HASH}" ] && [ "${SPEC_HASH}" != "x" ]; then
1374 HASH="|${SPEC_HASH}"
1375 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001376 local FIXUP_HASH=""
1377 if [ ! -z "${SPEC_FIXUP_HASH}" ] && [ "${SPEC_FIXUP_HASH}" != "x" ] && [ "${SPEC_FIXUP_HASH}" != "${SPEC_HASH}" ]; then
1378 FIXUP_HASH="|${SPEC_FIXUP_HASH}"
1379 fi
1380 printf '%s%s%s%s%s%s\n' "${PRODUCT_PACKAGE}" "${SRC}" "${DST}" "${ARGS}" "${HASH}" "${FIXUP_HASH}"
1381}
1382
1383# To be overridden by device-level extract-files.sh
1384# Parameters:
1385# $1: spec name of a blob. Can be used for filtering.
1386# If the spec is "src:dest", then $1 is "dest".
1387# If the spec is "src", then $1 is "src".
1388# $2: path to blob file. Can be used for fixups.
1389#
1390function blob_fixup() {
1391 :
Vladimir Olteana7d20492019-01-17 03:05:52 +02001392}
1393
Steve Kondik5bd66602016-07-15 10:39:58 -07001394#
1395# extract:
1396#
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001397# Positional parameters:
1398# $1: file containing the list of items to extract (aka proprietary-files.txt)
Dan Pasanen0cc05012017-03-21 09:06:11 -05001399# $2: path to extracted system folder, an ota zip file, or "adb" to extract from device
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001400# $3: section in list file to extract - optional. Setting section via $3 is deprecated.
1401#
1402# Non-positional parameters (coming after $2):
1403# --section: preferred way of selecting the portion to parse and extract from
1404# proprietary-files.txt
Vladimir Olteana7d20492019-01-17 03:05:52 +02001405# --kang: if present, this option will activate the printing of hashes for the
1406# extracted blobs. Useful with --section for subsequent pinning of
1407# blobs taken from other origins.
Steve Kondik5bd66602016-07-15 10:39:58 -07001408#
1409function extract() {
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001410 # Consume positional parameters
1411 local PROPRIETARY_FILES_TXT="$1"; shift
1412 local SRC="$1"; shift
1413 local SECTION=""
Vladimir Olteana7d20492019-01-17 03:05:52 +02001414 local KANG=false
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001415
1416 # Consume optional, non-positional parameters
1417 while [ "$#" -gt 0 ]; do
1418 case "$1" in
1419 -s|--section)
1420 SECTION="$2"; shift
1421 ;;
Vladimir Olteana7d20492019-01-17 03:05:52 +02001422 -k|--kang)
1423 KANG=true
1424 DISABLE_PINNING=1
1425 ;;
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001426 *)
1427 # Backwards-compatibility with the old behavior, where $3, if
1428 # present, denoted an optional positional ${SECTION} argument.
1429 # Users of ${SECTION} are encouraged to migrate from setting it as
1430 # positional $3, to non-positional --section ${SECTION}, the
1431 # reason being that it doesn't scale to have more than 1 optional
1432 # positional argument.
1433 SECTION="$1"
1434 ;;
1435 esac
1436 shift
1437 done
1438
Steve Kondik5bd66602016-07-15 10:39:58 -07001439 if [ -z "$OUTDIR" ]; then
1440 echo "Output dir not set!"
1441 exit 1
1442 fi
1443
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001444 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001445
1446 # Allow failing, so we can try $DEST and/or $FILE
1447 set +e
1448
1449 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1450 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
Vladimir Olteande985fe2019-01-17 03:07:34 +02001451 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
Vladimir Olteana7d20492019-01-17 03:05:52 +02001452 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
Steve Kondik5bd66602016-07-15 10:39:58 -07001453 local COUNT=${#FILELIST[@]}
theimpulson9a911af2019-08-14 03:25:12 +00001454 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
Steve Kondik5bd66602016-07-15 10:39:58 -07001455 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1456
1457 if [ "$SRC" = "adb" ]; then
1458 init_adb_connection
1459 fi
1460
Dan Pasanen0cc05012017-03-21 09:06:11 -05001461 if [ -f "$SRC" ] && [ "${SRC##*.}" == "zip" ]; then
conbold9baced42017-11-10 16:33:38 +01001462 DUMPDIR="$TMPDIR"/system_dump
Dan Pasanen0cc05012017-03-21 09:06:11 -05001463
1464 # Check if we're working with the same zip that was passed last time.
1465 # If so, let's just use what's already extracted.
1466 MD5=`md5sum "$SRC"| awk '{print $1}'`
1467 OLDMD5=`cat "$DUMPDIR"/zipmd5.txt`
1468
1469 if [ "$MD5" != "$OLDMD5" ]; then
1470 rm -rf "$DUMPDIR"
1471 mkdir "$DUMPDIR"
1472 unzip "$SRC" -d "$DUMPDIR"
1473 echo "$MD5" > "$DUMPDIR"/zipmd5.txt
1474
1475 # Stop if an A/B OTA zip is detected. We cannot extract these.
1476 if [ -a "$DUMPDIR"/payload.bin ]; then
1477 echo "A/B style OTA zip detected. This is not supported at this time. Stopping..."
1478 exit 1
Dan Pasanen0cc05012017-03-21 09:06:11 -05001479 fi
dianlujitao85ddca62020-04-21 23:03:20 +08001480
Luca Stefani776be462020-09-09 15:53:58 +02001481 for PARTITION in "system" "odm" "product" "system_ext" "vendor"
dianlujitao85ddca62020-04-21 23:03:20 +08001482 do
1483 # If OTA is block based, extract it.
dianlujitaoe2cbe262020-04-21 23:01:13 +08001484 if [ -a "$DUMPDIR"/"$PARTITION".new.dat.br ]; then
1485 echo "Converting "$PARTITION".new.dat.br to "$PARTITION".new.dat"
1486 brotli -d "$DUMPDIR"/"$PARTITION".new.dat.br
1487 rm "$DUMPDIR"/"$PARTITION".new.dat.br
1488 fi
dianlujitao85ddca62020-04-21 23:03:20 +08001489 if [ -a "$DUMPDIR"/"$PARTITION".new.dat ]; then
1490 echo "Converting "$PARTITION".new.dat to "$PARTITION".img"
1491 python "$OMNI_ROOT"/vendor/omni/build/tools/sdat2img.py "$DUMPDIR"/"$PARTITION".transfer.list "$DUMPDIR"/"$PARTITION".new.dat "$DUMPDIR"/"$PARTITION".img 2>&1
1492 rm -rf "$DUMPDIR"/"$PARTITION".new.dat "$DUMPDIR"/"$PARTITION"
1493 mkdir "$DUMPDIR"/"$PARTITION" "$DUMPDIR"/tmp
1494 echo "Requesting sudo access to mount the "$PARTITION".img"
1495 sudo mount -o loop "$DUMPDIR"/"$PARTITION".img "$DUMPDIR"/tmp
1496 cp -r "$DUMPDIR"/tmp/* "$DUMPDIR"/"$PARTITION"/
1497 sudo umount "$DUMPDIR"/tmp
1498 rm -rf "$DUMPDIR"/tmp "$DUMPDIR"/"$PARTITION".img
1499 fi
1500 done
Dan Pasanen0cc05012017-03-21 09:06:11 -05001501 fi
1502
1503 SRC="$DUMPDIR"
1504 fi
1505
Steve Kondik5bd66602016-07-15 10:39:58 -07001506 if [ "$VENDOR_STATE" -eq "0" ]; then
1507 echo "Cleaning output directory ($OUTPUT_ROOT).."
1508 rm -rf "${OUTPUT_TMP:?}"
1509 mkdir -p "${OUTPUT_TMP:?}"
Jake Whatley9843b322017-01-25 21:49:16 -05001510 if [ -d "$OUTPUT_ROOT" ]; then
1511 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1512 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001513 VENDOR_STATE=1
1514 fi
1515
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001516 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
Steve Kondik5bd66602016-07-15 10:39:58 -07001517
1518 for (( i=1; i<COUNT+1; i++ )); do
1519
Vladimir Oltean8e2de652018-06-24 20:41:30 +03001520 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
Vladimir Olteanb06f3aa2018-06-24 20:38:04 +03001521 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
Vladimir Olteand6391332018-06-24 20:42:01 +03001522 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001523 local OUTPUT_DIR=
1524 local TMP_DIR=
1525 local SRC_FILE=
1526 local DST_FILE=
Vladimir Olteana7d20492019-01-17 03:05:52 +02001527 local IS_PRODUCT_PACKAGE=false
1528
1529 # Note: this relies on the fact that the ${FILELIST[@]} array
1530 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1531 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1532 IS_PRODUCT_PACKAGE=true
1533 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001534
Vladimir Olteand6391332018-06-24 20:42:01 +03001535 if [ "${SPEC_ARGS}" = "rootfs" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001536 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1537 TMP_DIR="${OUTPUT_TMP}/rootfs"
1538 SRC_FILE="/${SPEC_SRC_FILE}"
1539 DST_FILE="/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001540 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001541 OUTPUT_DIR="${OUTPUT_ROOT}"
1542 TMP_DIR="${OUTPUT_TMP}"
1543 SRC_FILE="/system/${SPEC_SRC_FILE}"
1544 DST_FILE="/system/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001545 fi
1546
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001547 # Strip the file path in the vendor repo of "system", if present
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001548 local BLOB_DISPLAY_NAME="${DST_FILE#/system/}"
dianlujitao4ddcfb72020-04-06 12:43:16 +08001549 local VENDOR_REPO_FILE="$OUTPUT_DIR/${BLOB_DISPLAY_NAME}"
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001550 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001551
Gabriele M58270a32017-11-13 23:15:29 +01001552 # Check pinned files
Vladimir Olteane688cf92019-01-17 02:47:02 +02001553 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001554 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Gabriele M58270a32017-11-13 23:15:29 +01001555 local KEEP=""
Vladimir Olteande985fe2019-01-17 03:07:34 +02001556 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001557 if [ -f "${VENDOR_REPO_FILE}" ]; then
1558 local PINNED="${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001559 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001560 local PINNED="${TMP_DIR}${DST_FILE#/system}"
Gabriele M58270a32017-11-13 23:15:29 +01001561 fi
1562 if [ -f "$PINNED" ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001563 local TMP_HASH=$(get_hash "${PINNED}")
1564 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
Gabriele M58270a32017-11-13 23:15:29 +01001565 KEEP="1"
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001566 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1567 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001568 fi
1569 fi
1570 fi
1571 fi
1572
Vladimir Olteana7d20492019-01-17 03:05:52 +02001573 if [ "${KANG}" = false ]; then
1574 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1575 fi
1576
Gabriele M58270a32017-11-13 23:15:29 +01001577 if [ "$KEEP" = "1" ]; then
Vladimir Olteana7d20492019-01-17 03:05:52 +02001578 printf ' + keeping pinned file with hash %s\n' "${HASH}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001579 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001580 FOUND=false
1581 # Try Lineage target first.
1582 # Also try to search for files stripped of
1583 # the "/system" prefix, if we're actually extracting
1584 # from a system image.
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001585 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001586 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${SRC} && {
1587 FOUND=true
1588 break
1589 }
1590 done
1591
1592 if [ "${FOUND}" = false ]; then
Bruno Martins74e00eb2021-04-10 14:36:50 +01001593 colored_echo red " !! ${BLOB_DISPLAY_NAME}: file not found in source"
Vladimir Oltean11329372018-10-18 00:44:02 +03001594 continue
Steve Kondik5bd66602016-07-15 10:39:58 -07001595 fi
1596 fi
1597
Vladimir Olteande985fe2019-01-17 03:07:34 +02001598 # Blob fixup pipeline has 2 parts: one that is fixed and
1599 # one that is user-configurable
1600 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1601 # Deodex apk|jar if that's the case
1602 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1603 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "$SRC"
1604 if [ -f "$TMPDIR/classes.dex" ]; then
dianlujitaoded7c1e2020-04-06 12:45:36 +08001605 touch -t 200901010000 "$TMPDIR/classes"*
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001606 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1607 rm "$TMPDIR/classes"*
Vladimir Olteande985fe2019-01-17 03:07:34 +02001608 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001609 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001610 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1611 fix_xml "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001612 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001613 # Now run user-supplied fixup function
1614 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1615 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
Steve Kondik5bd66602016-07-15 10:39:58 -07001616
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001617 if [ -f "${VENDOR_REPO_FILE}" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001618 local DIR=$(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001619 local TYPE="${DIR##*/}"
1620 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001621 chmod 755 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001622 else
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001623 chmod 644 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001624 fi
1625 fi
1626
Vladimir Olteana7d20492019-01-17 03:05:52 +02001627 if [ "${KANG}" = true ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001628 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1629 fi
1630
1631 # Check and print whether the fixup pipeline actually did anything.
1632 # This isn't done right after the fixup pipeline because we want this print
1633 # to come after print_spec above, when in kang mode.
1634 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1635 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1636 # Now sanity-check the spec for this blob.
1637 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
Bruno Martins74e00eb2021-04-10 14:36:50 +01001638 colored_echo yellow "WARNING: The ${BLOB_DISPLAY_NAME} file was fixed up, but it is pinned."
1639 colored_echo yellow "This is a mistake and you want to either remove the hash completely, or add an extra one."
Vladimir Olteande985fe2019-01-17 03:07:34 +02001640 fi
Vladimir Olteana7d20492019-01-17 03:05:52 +02001641 fi
1642
Steve Kondik5bd66602016-07-15 10:39:58 -07001643 done
1644
1645 # Don't allow failing
1646 set -e
1647}
1648
1649#
Rashed Abdel-Tawab5b97a982019-09-29 01:19:57 -04001650# extract2:
1651#
1652# Positional parameters:
1653# $1: file containing the list of items to extract (aka proprietary-files.txt)
1654#
1655# Non-positional parameters (coming after $2):
1656# --section: selects the portion to parse and extracts from proprietary-files.txt
1657# --kang: if present, this option will activate the printing of hashes for the
1658# extracted blobs. Useful with --section for subsequent pinning of
1659# blobs taken from other origins.
1660#
1661function extract2() {
1662 # Consume positional parameters
1663 local PROPRIETARY_FILES_TXT="$1"; shift
1664 local SECTION=""
1665 local KANG=false
1666
1667 # Consume optional, non-positional parameters
1668 while [ "$#" -gt 0 ]; do
1669 case "$1" in
1670 --adb)
1671 ADB=true
1672 ;;
1673 --system)
1674 SYSTEM_SRC="$2"; shift
1675 ;;
1676 --vendor)
1677 VENDOR_SRC="$2"; shift
1678 ;;
1679 --odm)
1680 ODM_SRC="$2"; shift
1681 ;;
1682 --product)
1683 PRODUCT_SRC="$2"; shift
1684 ;;
1685 -s|--section)
1686 SECTION="$2"; shift
1687 ;;
1688 -k|--kang)
1689 KANG=true
1690 DISABLE_PINNING=1
1691 ;;
1692 esac
1693 shift
1694 done
1695
1696 if [ -z "$ADB" ] || [ -z "$SYSTEM_SRC" && -z "$VENDOR_SRC" && -z "$ODM_SRC" && -z "$PRODUCT_SRC" ]; then
1697 echo "No sources set! You must select --adb or pass paths to partition dumps."
1698 exit 1
1699 fi
1700
1701 if [ -z "$OUTDIR" ]; then
1702 echo "Output dir not set!"
1703 exit 1
1704 fi
1705
1706 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
1707
1708 # Allow failing, so we can try $DEST and/or $FILE
1709 set +e
1710
1711 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1712 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
1713 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
1714 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
1715 local COUNT=${#FILELIST[@]}
1716 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
1717 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1718
1719 if [ "$ADB" = true ]; then
1720 init_adb_connection
1721 fi
1722
1723 if [ "$VENDOR_STATE" -eq "0" ]; then
1724 echo "Cleaning output directory ($OUTPUT_ROOT).."
1725 rm -rf "${OUTPUT_TMP:?}"
1726 mkdir -p "${OUTPUT_TMP:?}"
1727 if [ -d "$OUTPUT_ROOT" ]; then
1728 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1729 fi
1730 VENDOR_STATE=1
1731 fi
1732
1733 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
1734
1735 for (( i=1; i<COUNT+1; i++ )); do
1736
1737 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
1738 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
1739 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
1740 local OUTPUT_DIR=
1741 local TMP_DIR=
1742 local SRC_FILE=
1743 local DST_FILE=
1744 local IS_PRODUCT_PACKAGE=false
1745
1746 # Note: this relies on the fact that the ${FILELIST[@]} array
1747 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1748 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1749 IS_PRODUCT_PACKAGE=true
1750 fi
1751
1752 if [ "${SPEC_ARGS}" = "rootfs" ]; then
1753 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1754 TMP_DIR="${OUTPUT_TMP}/rootfs"
1755 else
1756 OUTPUT_DIR="${OUTPUT_ROOT}"
1757 TMP_DIR="${OUTPUT_TMP}"
1758 fi
1759 SRC_FILE="${SPEC_SRC_FILE}"
1760 DST_FILE="${SPEC_DST_FILE}"
1761
1762 local VENDOR_REPO_FILE="$OUTPUT_DIR/${DST_FILE}"
1763 local BLOB_DISPLAY_NAME="${DST_FILE}"
1764 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
1765
1766 # Check pinned files
1767 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1768 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1769 local KEEP=""
1770 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
1771 if [ -f "${VENDOR_REPO_FILE}" ]; then
1772 local PINNED="${VENDOR_REPO_FILE}"
1773 else
1774 local PINNED="${TMP_DIR}${DST_FILE}"
1775 fi
1776 if [ -f "$PINNED" ]; then
1777 local TMP_HASH=$(get_hash "${PINNED}")
1778 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
1779 KEEP="1"
1780 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1781 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
1782 fi
1783 fi
1784 fi
1785 fi
1786
1787 if [ "${KANG}" = false ]; then
1788 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1789 fi
1790
1791 if [ "$KEEP" = "1" ]; then
1792 printf ' + keeping pinned file with hash %s\n' "${HASH}"
1793 else
1794 FOUND=false
1795 PARTITION_SOURCE_DIR=
1796 # Try Lineage target first.
1797 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
1798 PARTITION=$(echo "$CANDIDATE" | cut -d/ -f1)
1799 if [ "$PARTITION" = "system" ]; then
1800 PARTITION_SOURCE_DIR="$SYSTEM_SRC"
1801 elif [ "$PARTITION" = "vendor" ]; then
1802 PARTITION_SOURCE_DIR="$VENDOR_SRC"
1803 elif [ "$PARTITION" = "product" ]; then
1804 PARTITION_SOURCE_DIR="$PRODUCT_SRC"
1805 elif [ "$PARTITION" = "odm" ]; then
1806 PARTITION_SOURCE_DIR="$ODM_SRC"
1807 fi
1808 CANDIDATE_RELATIVE_NAME=$(echo "$CANDIDATE" | cut -d/ -f2-)
1809 get_file ${CANDIDATE_RELATIVE_NAME} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1810 FOUND=true
1811 break
1812 }
1813 # Search with the full system/ prefix if the file was not found on the system partition
1814 # because we may be searching in a mounted system-as-root system.img
1815 if [[ "${FOUND}" = false && "$PARTITION" = "system" ]]; then
1816 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1817 FOUND=true
1818 break
1819 }
1820 fi
1821 done
1822
1823 if [ -z "${PARTITION_SOURCE_DIR}" ]; then
1824 echo "$CANDIDATE has no preceeding partition path. Prepend system/, vendor/, product/, or odm/ to this entry."
1825 fi
1826
1827 if [ "${FOUND}" = false ]; then
1828 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
1829 continue
1830 fi
1831 fi
1832
1833 # Blob fixup pipeline has 2 parts: one that is fixed and
1834 # one that is user-configurable
1835 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1836 # Deodex apk|jar if that's the case
1837 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1838 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "${SYSTEM_SRC}"
1839 if [ -f "$TMPDIR/classes.dex" ]; then
1840 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1841 rm "$TMPDIR/classes"*
1842 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
1843 fi
1844 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1845 fix_xml "${VENDOR_REPO_FILE}"
1846 fi
1847 # Now run user-supplied fixup function
1848 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1849 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1850
1851 if [ -f "${VENDOR_REPO_FILE}" ]; then
1852 local DIR=$(dirname "${VENDOR_REPO_FILE}")
1853 local TYPE="${DIR##*/}"
1854 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
1855 chmod 755 "${VENDOR_REPO_FILE}"
1856 else
1857 chmod 644 "${VENDOR_REPO_FILE}"
1858 fi
1859 fi
1860
1861 if [ "${KANG}" = true ]; then
1862 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1863 fi
1864
1865 # Check and print whether the fixup pipeline actually did anything.
1866 # This isn't done right after the fixup pipeline because we want this print
1867 # to come after print_spec above, when in kang mode.
1868 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1869 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1870 # Now sanity-check the spec for this blob.
1871 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1872 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1873 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1874 fi
1875 fi
1876
1877 done
1878
1879 # Don't allow failing
1880 set -e
1881}
1882
1883#
Steve Kondik5bd66602016-07-15 10:39:58 -07001884# extract_firmware:
1885#
1886# $1: file containing the list of items to extract
1887# $2: path to extracted radio folder
1888#
1889function extract_firmware() {
1890 if [ -z "$OUTDIR" ]; then
1891 echo "Output dir not set!"
1892 exit 1
1893 fi
1894
1895 parse_file_list "$1"
1896
1897 # Don't allow failing
1898 set -e
1899
1900 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} )
1901 local COUNT=${#FILELIST[@]}
1902 local SRC="$2"
theimpulson9a911af2019-08-14 03:25:12 +00001903 local OUTPUT_DIR="$OMNI_ROOT"/"$OUTDIR"/radio
Steve Kondik5bd66602016-07-15 10:39:58 -07001904
1905 if [ "$VENDOR_RADIO_STATE" -eq "0" ]; then
1906 echo "Cleaning firmware output directory ($OUTPUT_DIR).."
1907 rm -rf "${OUTPUT_DIR:?}/"*
1908 VENDOR_RADIO_STATE=1
1909 fi
1910
1911 echo "Extracting $COUNT files in $1 from $SRC:"
1912
1913 for (( i=1; i<COUNT+1; i++ )); do
1914 local FILE="${FILELIST[$i-1]}"
1915 printf ' - %s \n' "/radio/$FILE"
1916
1917 if [ ! -d "$OUTPUT_DIR" ]; then
1918 mkdir -p "$OUTPUT_DIR"
1919 fi
1920 cp "$SRC/$FILE" "$OUTPUT_DIR/$FILE"
1921 chmod 644 "$OUTPUT_DIR/$FILE"
1922 done
1923}
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -07001924
1925function extract_img_data() {
1926 local image_file="$1"
1927 local out_dir="$2"
1928 local logFile="$TMPDIR/debugfs.log"
1929
1930 if [ ! -d "$out_dir" ]; then
1931 mkdir -p "$out_dir"
1932 fi
1933
1934 if [[ "$HOST_OS" == "Darwin" ]]; then
1935 debugfs -R "rdump / \"$out_dir\"" "$image_file" &> "$logFile" || {
1936 echo "[-] Failed to extract data from '$image_file'"
1937 abort 1
1938 }
1939 else
1940 debugfs -R 'ls -p' "$image_file" 2>/dev/null | cut -d '/' -f6 | while read -r entry
1941 do
1942 debugfs -R "rdump \"$entry\" \"$out_dir\"" "$image_file" >> "$logFile" 2>&1 || {
1943 echo "[-] Failed to extract data from '$image_file'"
1944 abort 1
1945 }
1946 done
1947 fi
1948
1949 local symlink_err="rdump: Attempt to read block from filesystem resulted in short read while reading symlink"
1950 if grep -Fq "$symlink_err" "$logFile"; then
1951 echo "[-] Symlinks have not been properly processed from $image_file"
1952 echo "[!] If you don't have a compatible debugfs version, modify 'execute-all.sh' to disable 'USE_DEBUGFS' flag"
1953 abort 1
1954 fi
1955}
1956
1957declare -ra VENDOR_SKIP_FILES=(
1958 "bin/toybox_vendor"
1959 "bin/toolbox"
1960 "bin/grep"
1961 "build.prop"
1962 "compatibility_matrix.xml"
1963 "default.prop"
1964 "etc/NOTICE.xml.gz"
1965 "etc/vintf/compatibility_matrix.xml"
1966 "etc/vintf/manifest.xml"
1967 "etc/wifi/wpa_supplicant.conf"
1968 "manifest.xml"
1969 "overlay/DisplayCutoutEmulationCorner/DisplayCutoutEmulationCornerOverlay.apk"
1970 "overlay/DisplayCutoutEmulationDouble/DisplayCutoutEmulationDoubleOverlay.apk"
1971 "overlay/DisplayCutoutEmulationTall/DisplayCutoutEmulationTallOverlay.apk"
1972 "overlay/DisplayCutoutNoCutout/NoCutoutOverlay.apk"
1973 "overlay/framework-res__auto_generated_rro.apk"
1974 "overlay/SysuiDarkTheme/SysuiDarkThemeOverlay.apk"
1975)
1976
1977function array_contains() {
1978 local element
1979 for element in "${@:2}"; do [[ "$element" == "$1" ]] && return 0; done
1980 return 1
1981}
1982
1983function generate_prop_list_from_image() {
1984 local image_file="$1"
1985 local image_dir="$TMPDIR/image-temp"
1986 local output_list="$2"
1987 local output_list_tmp="$TMPDIR/_proprietary-blobs.txt"
1988 local -n skipped_vendor_files="$3"
1989
1990 extract_img_data "$image_file" "$image_dir"
1991
1992 find "$image_dir" -not -type d | sed "s#^$image_dir/##" | while read -r FILE
1993 do
1994 # Skip VENDOR_SKIP_FILES since it will be re-generated at build time
1995 if array_contains "$FILE" "${VENDOR_SKIP_FILES[@]}"; then
1996 continue
1997 fi
1998 # Skip device defined skipped files since they will be re-generated at build time
1999 if array_contains "$FILE" "${skipped_vendor_files[@]}"; then
2000 continue
2001 fi
2002 if suffix_match_file ".apk" "$FILE" ; then
2003 echo "-vendor/$FILE" >> "$output_list_tmp"
2004 else
2005 echo "vendor/$FILE" >> "$output_list_tmp"
2006 fi
2007 done
2008
2009 # Sort merged file with all lists
2010 sort -u "$output_list_tmp" > "$output_list"
2011
2012 # Clean-up
2013 rm -f "$output_list_tmp"
2014}
Bruno Martins0f425f12021-04-10 14:57:32 +01002015
2016function colored_echo() {
2017 IFS=" "
2018 local color=$1;
2019 shift
2020 if ! [[ $color =~ '^[0-9]$' ]] ; then
2021 case $(echo $color | tr '[:upper:]' '[:lower:]') in
2022 black) color=0 ;;
2023 red) color=1 ;;
2024 green) color=2 ;;
2025 yellow) color=3 ;;
2026 blue) color=4 ;;
2027 magenta) color=5 ;;
2028 cyan) color=6 ;;
2029 white|*) color=7 ;; # white or invalid color
2030 esac
2031 fi
Bruno Martins5064db22021-06-21 14:47:40 +01002032 if [ -t 1 ] ; then tput setaf $color; fi
Bruno Martins0f425f12021-04-10 14:57:32 +01002033 printf '%s\n' "$*"
Bruno Martins5064db22021-06-21 14:47:40 +01002034 if [ -t 1 ] ; then tput sgr0; fi
Bruno Martins0f425f12021-04-10 14:57:32 +01002035}