blob: af8863d7bdb5a212a137efdd9424931a09efd81e [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)
Steve Kondik5bd66602016-07-15 10:39:58 -070032
33#
34# cleanup
35#
36# kill our tmpfiles with fire on exit
37#
38function cleanup() {
39 rm -rf "${TMPDIR:?}"
40}
41
Gabriele Mb8e54572017-10-11 12:55:51 +020042trap cleanup 0
Steve Kondik5bd66602016-07-15 10:39:58 -070043
44#
45# setup_vendor
46#
47# $1: device name
48# $2: vendor name
theimpulson9a911af2019-08-14 03:25:12 +000049# $3: OMNI root directory
Steve Kondik5bd66602016-07-15 10:39:58 -070050# $4: is common device - optional, default to false
51# $5: cleanup - optional, default to true
Jake Whatley9843b322017-01-25 21:49:16 -050052# $6: custom vendor makefile name - optional, default to false
Steve Kondik5bd66602016-07-15 10:39:58 -070053#
54# Must be called before any other functions can be used. This
55# sets up the internal state for a new vendor configuration.
56#
57function setup_vendor() {
58 local DEVICE="$1"
59 if [ -z "$DEVICE" ]; then
60 echo "\$DEVICE must be set before including this script!"
61 exit 1
62 fi
63
64 export VENDOR="$2"
65 if [ -z "$VENDOR" ]; then
66 echo "\$VENDOR must be set before including this script!"
67 exit 1
68 fi
69
theimpulson9a911af2019-08-14 03:25:12 +000070 export OMNI_ROOT="$3"
71 if [ ! -d "$OMNI_ROOT" ]; then
72 echo "\$OMNI_ROOT must be set and valid before including this script!"
Steve Kondik5bd66602016-07-15 10:39:58 -070073 exit 1
74 fi
75
76 export OUTDIR=vendor/"$VENDOR"/"$DEVICE"
theimpulson9a911af2019-08-14 03:25:12 +000077 if [ ! -d "$OMNI_ROOT/$OUTDIR" ]; then
78 mkdir -p "$OMNI_ROOT/$OUTDIR"
Steve Kondik5bd66602016-07-15 10:39:58 -070079 fi
80
Jake Whatley9843b322017-01-25 21:49:16 -050081 VNDNAME="$6"
82 if [ -z "$VNDNAME" ]; then
83 VNDNAME="$DEVICE"
84 fi
85
theimpulsonbb72ab82019-08-14 06:03:32 +000086 export PRODUCTMK="$OMNI_ROOT"/"$OUTDIR"/"$VNDNAME"-vendor.mk
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -070087 export ANDROIDBP="$OMNI_ROOT"/"$OUTDIR"/Android.bp
theimpulson9a911af2019-08-14 03:25:12 +000088 export ANDROIDMK="$OMNI_ROOT"/"$OUTDIR"/Android.mk
89 export BOARDMK="$OMNI_ROOT"/"$OUTDIR"/BoardConfigVendor.mk
Steve Kondik5bd66602016-07-15 10:39:58 -070090
91 if [ "$4" == "true" ] || [ "$4" == "1" ]; then
92 COMMON=1
93 else
94 COMMON=0
95 fi
96
Gabriele Mc44696d2017-05-01 18:22:04 +020097 if [ "$5" == "false" ] || [ "$5" == "0" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -070098 VENDOR_STATE=1
99 VENDOR_RADIO_STATE=1
100 else
101 VENDOR_STATE=0
102 VENDOR_RADIO_STATE=0
103 fi
104}
105
Vladimir Oltean75d8e052018-06-24 20:22:41 +0300106# Helper functions for parsing a spec.
107# notes: an optional "|SHA1" that may appear in the format is stripped
108# early from the spec in the parse_file_list function, and
109# should not be present inside the input parameter passed
110# to these functions.
111
112#
113# input: spec in the form of "src[:dst][;args]"
114# output: "src"
115#
116function src_file() {
117 local SPEC="$1"
118 local SPLIT=(${SPEC//:/ })
119 local ARGS="$(target_args ${SPEC})"
120 # Regardless of there being a ":" delimiter or not in the spec,
121 # the source file is always either the first, or the only entry.
122 local SRC="${SPLIT[0]}"
123 # Remove target_args suffix, if present
124 echo "${SRC%;${ARGS}}"
125}
126
Steve Kondik5bd66602016-07-15 10:39:58 -0700127#
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300128# input: spec in the form of "src[:dst][;args]"
129# output: "dst" if present, "src" otherwise.
Steve Kondik5bd66602016-07-15 10:39:58 -0700130#
131function target_file() {
dianlujitao4918b8a2020-01-02 15:26:44 +0800132 local SPEC="${1%%;*}"
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300133 local SPLIT=(${SPEC//:/ })
134 local ARGS="$(target_args ${SPEC})"
135 local DST=
136 case ${#SPLIT[@]} in
137 1)
138 # The spec doesn't have a : delimiter
139 DST="${SPLIT[0]}"
140 ;;
141 *)
142 # The spec actually has a src:dst format
143 DST="${SPLIT[1]}"
144 ;;
145 esac
146 # Remove target_args suffix, if present
147 echo "${DST%;${ARGS}}"
Steve Kondik5bd66602016-07-15 10:39:58 -0700148}
149
150#
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300151# input: spec in the form of "src[:dst][;args]"
152# output: "args" if present, "" otherwise.
Steve Kondik5bd66602016-07-15 10:39:58 -0700153#
154function target_args() {
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300155 local SPEC="$1"
156 local SPLIT=(${SPEC//;/ })
157 local ARGS=
158 case ${#SPLIT[@]} in
159 1)
160 # No ";" delimiter in the spec.
161 ;;
162 *)
163 # The "args" are whatever comes after the ";" character.
164 # Basically the spec stripped of whatever is to the left of ";".
165 ARGS="${SPEC#${SPLIT[0]};}"
166 ;;
167 esac
168 echo "${ARGS}"
Steve Kondik5bd66602016-07-15 10:39:58 -0700169}
170
171#
172# prefix_match:
173#
Vladimir Oltean011b6b62018-06-12 01:17:35 +0300174# input:
175# - $1: prefix
176# - (global variable) PRODUCT_PACKAGES_LIST: array of [src:]dst[;args] specs.
177# output:
178# - new array consisting of dst[;args] entries where $1 is a prefix of ${dst}.
Steve Kondik5bd66602016-07-15 10:39:58 -0700179#
180function prefix_match() {
181 local PREFIX="$1"
Vladimir Oltean7220f362018-04-02 22:37:09 +0300182 for LINE in "${PRODUCT_PACKAGES_LIST[@]}"; do
183 local FILE=$(target_file "$LINE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700184 if [[ "$FILE" =~ ^"$PREFIX" ]]; then
Vladimir Oltean011b6b62018-06-12 01:17:35 +0300185 local ARGS=$(target_args "$LINE")
186 if [ -z "${ARGS}" ]; then
187 echo "${FILE#$PREFIX}"
188 else
189 echo "${FILE#$PREFIX};${ARGS}"
190 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700191 fi
192 done
193}
194
195#
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400196# prefix_match_file:
197#
198# $1: the prefix to match on
199# $2: the file to match the prefix for
200#
201# Internal function which returns true if a filename contains the
202# specified prefix.
203#
204function prefix_match_file() {
205 local PREFIX="$1"
206 local FILE="$2"
207 if [[ "$FILE" =~ ^"$PREFIX" ]]; then
208 return 0
209 else
210 return 1
211 fi
212}
213
214#
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -0700215# suffix_match_file:
216#
217# $1: the suffix to match on
218# $2: the file to match the suffix for
219#
220# Internal function which returns true if a filename contains the
221# specified suffix.
222#
223function suffix_match_file() {
224 local SUFFIX="$1"
225 local FILE="$2"
226 if [[ "$FILE" = *"$SUFFIX" ]]; then
227 return 0
228 else
229 return 1
230 fi
231}
232
233#
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400234# truncate_file
235#
236# $1: the filename to truncate
237# $2: the argument to output the truncated filename to
238#
239# Internal function which truncates a filename by removing the first dir
240# in the path. ex. vendor/lib/libsdmextension.so -> lib/libsdmextension.so
241#
242function truncate_file() {
243 local FILE="$1"
244 RETURN_FILE="$2"
245 local FIND="${FILE%%/*}"
246 local LOCATION="${#FIND}+1"
247 echo ${FILE:$LOCATION}
248}
249
250#
Steve Kondik5bd66602016-07-15 10:39:58 -0700251# write_product_copy_files:
252#
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400253# $1: make treble compatible makefile - optional and deprecated, default to true
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400254#
Steve Kondik5bd66602016-07-15 10:39:58 -0700255# Creates the PRODUCT_COPY_FILES section in the product makefile for all
256# items in the list which do not start with a dash (-).
257#
258function write_product_copy_files() {
259 local COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
260 local TARGET=
261 local FILE=
262 local LINEEND=
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400263 local TREBLE_COMPAT=$1
Steve Kondik5bd66602016-07-15 10:39:58 -0700264
265 if [ "$COUNT" -eq "0" ]; then
266 return 0
267 fi
268
269 printf '%s\n' "PRODUCT_COPY_FILES += \\" >> "$PRODUCTMK"
270 for (( i=1; i<COUNT+1; i++ )); do
271 FILE="${PRODUCT_COPY_FILES_LIST[$i-1]}"
272 LINEEND=" \\"
273 if [ "$i" -eq "$COUNT" ]; then
274 LINEEND=""
275 fi
276
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300277 TARGET=$(target_file "$FILE")
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400278 if prefix_match_file "product/" $TARGET ; then
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400279 local OUTTARGET=$(truncate_file $TARGET)
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400280 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_PRODUCT)/%s%s\n' \
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400281 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400282 elif prefix_match_file "system/product/" $TARGET ; then
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400283 local OUTTARGET=$(truncate_file $TARGET)
284 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_PRODUCT)/%s%s\n' \
285 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Luca Stefani776be462020-09-09 15:53:58 +0200286 elif prefix_match_file "system_ext/" $TARGET ; then
287 local OUTTARGET=$(truncate_file $TARGET)
288 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM_EXT)/%s%s\n' \
289 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
290 elif prefix_match_file "system/system_ext/" $TARGET ; then
291 local OUTTARGET=$(truncate_file $TARGET)
292 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM_EXT)/%s%s\n' \
293 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400294 elif prefix_match_file "odm/" $TARGET ; then
295 local OUTTARGET=$(truncate_file $TARGET)
296 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
297 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400298 elif prefix_match_file "vendor/odm/" $TARGET ; then
299 local OUTTARGET=$(truncate_file $TARGET)
300 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
301 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
302 elif prefix_match_file "system/vendor/odm/" $TARGET ; then
303 local OUTTARGET=$(truncate_file $TARGET)
304 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
305 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
306 elif prefix_match_file "vendor/" $TARGET ; then
307 local OUTTARGET=$(truncate_file $TARGET)
308 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
309 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
310 elif prefix_match_file "system/vendor/" $TARGET ; then
311 local OUTTARGET=$(truncate_file $TARGET)
312 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
313 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400314 elif prefix_match_file "system/" $TARGET ; then
315 local OUTTARGET=$(truncate_file $TARGET)
316 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
317 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400318 else
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400319 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400320 "$OUTDIR" "$TARGET" "$TARGET" "$LINEEND" >> "$PRODUCTMK"
321 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700322 done
323 return 0
324}
325
326#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700327# write_blueprint_packages:
Steve Kondik5bd66602016-07-15 10:39:58 -0700328#
329# $1: The LOCAL_MODULE_CLASS for the given module list
Luca Stefani776be462020-09-09 15:53:58 +0200330# $2: /system, /odm, /product, /system_ext, or /vendor partition
Steve Kondik5bd66602016-07-15 10:39:58 -0700331# $3: type-specific extra flags
332# $4: Name of the array holding the target list
333#
334# Internal function which writes out the BUILD_PREBUILT stanzas
335# for all modules in the list. This is called by write_product_packages
336# after the modules are categorized.
337#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700338function write_blueprint_packages() {
339
340 local CLASS="$1"
341 local PARTITION="$2"
342 local EXTRA="$3"
343
344 # Yes, this is a horrible hack - we create a new array using indirection
345 local ARR_NAME="$4[@]"
346 local FILELIST=("${!ARR_NAME}")
347
348 local FILE=
349 local ARGS=
350 local BASENAME=
351 local EXTENSION=
352 local PKGNAME=
353 local SRC=
354
355 for P in "${FILELIST[@]}"; do
356 FILE=$(target_file "$P")
357 ARGS=$(target_args "$P")
358
359 BASENAME=$(basename "$FILE")
360 DIRNAME=$(dirname "$FILE")
361 EXTENSION=${BASENAME##*.}
362 PKGNAME=${BASENAME%.*}
363
364 # Add to final package list
365 PACKAGE_LIST+=("$PKGNAME")
366
367 SRC="proprietary"
368 if [ "$PARTITION" = "system" ]; then
369 SRC+="/system"
370 elif [ "$PARTITION" = "vendor" ]; then
371 SRC+="/vendor"
372 elif [ "$PARTITION" = "product" ]; then
373 SRC+="/product"
Luca Stefani776be462020-09-09 15:53:58 +0200374 elif [ "$PARTITION" = "system_ext" ]; then
375 SRC+="/system_ext"
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700376 elif [ "$PARTITION" = "odm" ]; then
377 SRC+="/odm"
378 fi
379
380 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
381 printf 'cc_prebuilt_library_shared {\n'
382 printf '\tname: "%s",\n' "$PKGNAME"
383 printf '\towner: "%s",\n' "$VENDOR"
384 printf '\tstrip: {\n'
385 printf '\t\tnone: true,\n'
386 printf '\t},\n'
387 printf '\ttarget: {\n'
388 if [ "$EXTRA" = "both" ]; then
389 printf '\t\tandroid_arm: {\n'
390 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
391 printf '\t\t},\n'
392 printf '\t\tandroid_arm64: {\n'
393 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
394 printf '\t\t},\n'
395 elif [ "$EXTRA" = "64" ]; then
396 printf '\t\tandroid_arm64: {\n'
397 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
398 printf '\t\t},\n'
399 else
400 printf '\t\tandroid_arm: {\n'
401 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
402 printf '\t\t},\n'
403 fi
404 printf '\t},\n'
405 if [ "$EXTRA" != "none" ]; then
406 printf '\tcompile_multilib: "%s",\n' "$EXTRA"
407 fi
dianlujitao848101c2020-09-12 00:15:13 +0800408 printf '\tcheck_elf_files: false,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700409 elif [ "$CLASS" = "APPS" ]; then
410 printf 'android_app_import {\n'
411 printf '\tname: "%s",\n' "$PKGNAME"
412 printf '\towner: "%s",\n' "$VENDOR"
413 if [ "$EXTRA" = "priv-app" ]; then
414 SRC="$SRC/priv-app"
415 else
416 SRC="$SRC/app"
417 fi
418 printf '\tapk: "%s/%s",\n' "$SRC" "$FILE"
419 if [ "$ARGS" = "PRESIGNED" ]; then
420 printf '\tpresigned: true,\n'
421 elif [ ! -z "$ARGS" ]; then
422 printf '\tcertificate: "%s",\n' "$ARGS"
423 else
424 printf '\tcertificate: "platform",\n'
425 fi
426 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
427 printf 'dex_import {\n'
428 printf '\tname: "%s",\n' "$PKGNAME"
429 printf '\towner: "%s",\n' "$VENDOR"
430 printf '\tjars: ["%s/framework/%s"],\n' "$SRC" "$FILE"
431 elif [ "$CLASS" = "ETC" ]; then
432 if [ "$EXTENSION" = "xml" ]; then
433 printf 'prebuilt_etc_xml {\n'
434 else
435 printf 'prebuilt_etc {\n'
436 fi
437 printf '\tname: "%s",\n' "$PKGNAME"
438 printf '\towner: "%s",\n' "$VENDOR"
439 printf '\tsrc: "%s/etc/%s",\n' "$SRC" "$FILE"
440 elif [ "$CLASS" = "EXECUTABLES" ]; then
441 if [ "$EXTENSION" = "sh" ]; then
442 printf 'sh_binary {\n'
443 else
444 printf 'cc_prebuilt_binary {\n'
445 fi
446 printf '\tname: "%s",\n' "$PKGNAME"
447 printf '\towner: "%s",\n' "$VENDOR"
448 if [ "$ARGS" = "rootfs" ]; then
449 SRC="$SRC/rootfs"
450 if [ "$EXTRA" = "sbin" ]; then
451 SRC="$SRC/sbin"
452 printf '\tdist {\n'
453 printf '\t\tdest: "%s",\n' "root/sbin"
454 printf '\t},'
455 fi
456 else
457 SRC="$SRC/bin"
458 fi
459 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
460 unset EXTENSION
461 else
462 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
463 fi
464 if [ "$CLASS" = "APPS" ]; then
465 printf '\tdex_preopt: {\n'
466 printf '\t\tenabled: false,\n'
467 printf '\t},\n'
468 fi
Andreas Schneiderdbcf9db2020-05-25 17:03:17 +0200469 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700470 if [ "$DIRNAME" != "." ]; then
Andreas Schneider408526a2020-05-23 15:58:43 +0200471 printf '\trelative_install_path: "%s",\n' "$DIRNAME"
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700472 fi
473 fi
Andreas Schneiderdbcf9db2020-05-25 17:03:17 +0200474 if [ "$CLASS" = "ETC" ] ; then
475 if [ "$DIRNAME" != "." ]; then
476 printf '\tsub_dir: "%s",\n' "$DIRNAME"
477 fi
478 fi
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700479 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
480 printf '\tprefer: true,\n'
481 fi
482 if [ "$EXTRA" = "priv-app" ]; then
483 printf '\tprivileged: true,\n'
484 fi
485 if [ "$PARTITION" = "vendor" ]; then
486 printf '\tsoc_specific: true,\n'
487 elif [ "$PARTITION" = "product" ]; then
488 printf '\tproduct_specific: true,\n'
Luca Stefani776be462020-09-09 15:53:58 +0200489 elif [ "$PARTITION" = "system_ext" ]; then
490 printf '\tsystem_ext_specific: true,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700491 elif [ "$PARTITION" = "odm" ]; then
492 printf '\tdevice_specific: true,\n'
493 fi
494 printf '}\n\n'
495 done
496}
497
498#
499# write_makefile_packages:
500#
501# $1: The LOCAL_MODULE_CLASS for the given module list
Luca Stefani776be462020-09-09 15:53:58 +0200502# $2: /odm, /product, /system_ext, or /vendor partition
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700503# $3: type-specific extra flags
504# $4: Name of the array holding the target list
505#
506# Internal function which writes out the BUILD_PREBUILT stanzas
507# for all modules in the list. This is called by write_product_packages
508# after the modules are categorized.
509#
510function write_makefile_packages() {
Steve Kondik5bd66602016-07-15 10:39:58 -0700511
512 local CLASS="$1"
razorlovesa0d296b2019-07-29 02:21:34 -0500513 local PARTITION="$2"
Steve Kondik5bd66602016-07-15 10:39:58 -0700514 local EXTRA="$3"
515
516 # Yes, this is a horrible hack - we create a new array using indirection
517 local ARR_NAME="$4[@]"
518 local FILELIST=("${!ARR_NAME}")
519
520 local FILE=
521 local ARGS=
522 local BASENAME=
523 local EXTENSION=
524 local PKGNAME=
525 local SRC=
526
527 for P in "${FILELIST[@]}"; do
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300528 FILE=$(target_file "$P")
Steve Kondik5bd66602016-07-15 10:39:58 -0700529 ARGS=$(target_args "$P")
530
531 BASENAME=$(basename "$FILE")
M1cha3e8c5bf2017-01-04 09:00:11 +0100532 DIRNAME=$(dirname "$FILE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700533 EXTENSION=${BASENAME##*.}
Mohd Farazcb0f4872019-10-08 16:13:50 +0530534 EXTENSION="."$EXTENSION
535 if [ "$EXTENSION" = ".jar" ]; then
536 EXTENSION="\$(COMMON_JAVA_PACKAGE_SUFFIX)"
537 elif [ "$EXTENSION" = ".apk" ]; then
538 EXTENSION="\$(COMMON_ANDROID_PACKAGE_SUFFIX)"
539 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700540 PKGNAME=${BASENAME%.*}
541
542 # Add to final package list
543 PACKAGE_LIST+=("$PKGNAME")
544
545 SRC="proprietary"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400546 if [ "$PARTITION" = "system" ]; then
547 SRC+="/system"
548 elif [ "$PARTITION" = "vendor" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -0700549 SRC+="/vendor"
razorlovesa0d296b2019-07-29 02:21:34 -0500550 elif [ "$PARTITION" = "product" ]; then
551 SRC+="/product"
Luca Stefani776be462020-09-09 15:53:58 +0200552 elif [ "$PARTITION" = "system_ext" ]; then
553 SRC+="/system_ext"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700554 elif [ "$PARTITION" = "odm" ]; then
555 SRC+="/odm"
Steve Kondik5bd66602016-07-15 10:39:58 -0700556 fi
557
558 printf 'include $(CLEAR_VARS)\n'
559 printf 'LOCAL_MODULE := %s\n' "$PKGNAME"
560 printf 'LOCAL_MODULE_OWNER := %s\n' "$VENDOR"
561 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
562 if [ "$EXTRA" = "both" ]; then
563 printf 'LOCAL_SRC_FILES_64 := %s/lib64/%s\n' "$SRC" "$FILE"
564 printf 'LOCAL_SRC_FILES_32 := %s/lib/%s\n' "$SRC" "$FILE"
565 #if [ "$VENDOR_PKG" = "true" ]; then
566 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
567 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
568 #else
569 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_SHARED_LIBRARIES)"
570 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_SHARED_LIBRARIES)"
571 #fi
572 elif [ "$EXTRA" = "64" ]; then
573 printf 'LOCAL_SRC_FILES := %s/lib64/%s\n' "$SRC" "$FILE"
574 else
575 printf 'LOCAL_SRC_FILES := %s/lib/%s\n' "$SRC" "$FILE"
576 fi
577 if [ "$EXTRA" != "none" ]; then
578 printf 'LOCAL_MULTILIB := %s\n' "$EXTRA"
579 fi
580 elif [ "$CLASS" = "APPS" ]; then
Michael Bestas9c6f2eb2018-01-25 21:05:36 +0200581 if [ "$EXTRA" = "priv-app" ]; then
582 SRC="$SRC/priv-app"
583 else
584 SRC="$SRC/app"
Steve Kondik5bd66602016-07-15 10:39:58 -0700585 fi
586 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
587 local CERT=platform
588 if [ ! -z "$ARGS" ]; then
589 CERT="$ARGS"
590 fi
591 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
592 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
593 printf 'LOCAL_SRC_FILES := %s/framework/%s\n' "$SRC" "$FILE"
Elektroschmockdd792302016-10-04 21:11:43 +0200594 local CERT=platform
595 if [ ! -z "$ARGS" ]; then
596 CERT="$ARGS"
597 fi
598 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
Steve Kondik5bd66602016-07-15 10:39:58 -0700599 elif [ "$CLASS" = "ETC" ]; then
600 printf 'LOCAL_SRC_FILES := %s/etc/%s\n' "$SRC" "$FILE"
601 elif [ "$CLASS" = "EXECUTABLES" ]; then
602 if [ "$ARGS" = "rootfs" ]; then
603 SRC="$SRC/rootfs"
604 if [ "$EXTRA" = "sbin" ]; then
605 SRC="$SRC/sbin"
606 printf '%s\n' "LOCAL_MODULE_PATH := \$(TARGET_ROOT_OUT_SBIN)"
607 printf '%s\n' "LOCAL_UNSTRIPPED_PATH := \$(TARGET_ROOT_OUT_SBIN_UNSTRIPPED)"
608 fi
609 else
610 SRC="$SRC/bin"
611 fi
612 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
613 unset EXTENSION
614 else
615 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
616 fi
617 printf 'LOCAL_MODULE_TAGS := optional\n'
618 printf 'LOCAL_MODULE_CLASS := %s\n' "$CLASS"
Hashbang173575f3bb2016-08-28 20:38:45 -0400619 if [ "$CLASS" = "APPS" ]; then
620 printf 'LOCAL_DEX_PREOPT := false\n'
621 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700622 if [ ! -z "$EXTENSION" ]; then
Mohd Farazcb0f4872019-10-08 16:13:50 +0530623 printf 'LOCAL_MODULE_SUFFIX := %s\n' "$EXTENSION"
Steve Kondik5bd66602016-07-15 10:39:58 -0700624 fi
M1cha3e8c5bf2017-01-04 09:00:11 +0100625 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ]; then
626 if [ "$DIRNAME" != "." ]; then
627 printf 'LOCAL_MODULE_RELATIVE_PATH := %s\n' "$DIRNAME"
628 fi
629 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700630 if [ "$EXTRA" = "priv-app" ]; then
631 printf 'LOCAL_PRIVILEGED_MODULE := true\n'
632 fi
razorlovesa0d296b2019-07-29 02:21:34 -0500633 if [ "$PARTITION" = "vendor" ]; then
Ethan Chen4f738f52018-02-17 20:03:54 -0800634 printf 'LOCAL_VENDOR_MODULE := true\n'
razorlovesa0d296b2019-07-29 02:21:34 -0500635 elif [ "$PARTITION" = "product" ]; then
636 printf 'LOCAL_PRODUCT_MODULE := true\n'
Luca Stefani776be462020-09-09 15:53:58 +0200637 elif [ "$PARTITION" = "system_ext" ]; then
638 printf 'LOCAL_SYSTEM_EXT_MODULE := true\n'
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700639 elif [ "$PARTITION" = "odm" ]; then
640 printf 'LOCAL_ODM_MODULE := true\n'
Steve Kondik5bd66602016-07-15 10:39:58 -0700641 fi
642 printf 'include $(BUILD_PREBUILT)\n\n'
643 done
644}
645
646#
647# write_product_packages:
648#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700649# This function will create prebuilt entries in the
650# Android.bp and associated PRODUCT_PACKAGES list in the
Steve Kondik5bd66602016-07-15 10:39:58 -0700651# product makefile for all files in the blob list which
652# start with a single dash (-) character.
653#
654function write_product_packages() {
655 PACKAGE_LIST=()
656
657 local COUNT=${#PRODUCT_PACKAGES_LIST[@]}
658
659 if [ "$COUNT" = "0" ]; then
660 return 0
661 fi
662
663 # Figure out what's 32-bit, what's 64-bit, and what's multilib
664 # I really should not be doing this in bash due to shitty array passing :(
665 local T_LIB32=( $(prefix_match "lib/") )
666 local T_LIB64=( $(prefix_match "lib64/") )
667 local MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${T_LIB64[@]}")) )
668 local LIB32=( $(comm -23 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
669 local LIB64=( $(comm -23 <(printf '%s\n' "${T_LIB64[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
670
671 if [ "${#MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700672 write_blueprint_packages "SHARED_LIBRARIES" "" "both" "MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700673 fi
674 if [ "${#LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700675 write_blueprint_packages "SHARED_LIBRARIES" "" "32" "LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700676 fi
677 if [ "${#LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700678 write_blueprint_packages "SHARED_LIBRARIES" "" "64" "LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700679 fi
680
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400681 local T_S_LIB32=( $(prefix_match "system/lib/") )
682 local T_S_LIB64=( $(prefix_match "system/lib64/") )
683 local S_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${T_S_LIB64[@]}")) )
684 local S_LIB32=( $(comm -23 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
685 local S_LIB64=( $(comm -23 <(printf '%s\n' "${T_S_LIB64[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
686
687 if [ "${#S_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700688 write_blueprint_packages "SHARED_LIBRARIES" "system" "both" "S_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400689 fi
690 if [ "${#S_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700691 write_blueprint_packages "SHARED_LIBRARIES" "system" "32" "S_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400692 fi
693 if [ "${#S_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700694 write_blueprint_packages "SHARED_LIBRARIES" "system" "64" "S_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400695 fi
696
Steve Kondik5bd66602016-07-15 10:39:58 -0700697 local T_V_LIB32=( $(prefix_match "vendor/lib/") )
698 local T_V_LIB64=( $(prefix_match "vendor/lib64/") )
699 local V_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${T_V_LIB64[@]}")) )
700 local V_LIB32=( $(comm -23 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
701 local V_LIB64=( $(comm -23 <(printf '%s\n' "${T_V_LIB64[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
702
703 if [ "${#V_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700704 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "both" "V_MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700705 fi
706 if [ "${#V_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700707 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "32" "V_LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700708 fi
709 if [ "${#V_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700710 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "64" "V_LIB64" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500711 fi
712
713 local T_P_LIB32=( $(prefix_match "product/lib/") )
714 local T_P_LIB64=( $(prefix_match "product/lib64/") )
715 local P_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${T_P_LIB64[@]}")) )
716 local P_LIB32=( $(comm -23 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
717 local P_LIB64=( $(comm -23 <(printf '%s\n' "${T_P_LIB64[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
718
719 if [ "${#P_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700720 write_blueprint_packages "SHARED_LIBRARIES" "product" "both" "P_MULTILIBS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500721 fi
722 if [ "${#P_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700723 write_blueprint_packages "SHARED_LIBRARIES" "product" "32" "P_LIB32" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500724 fi
725 if [ "${#P_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700726 write_blueprint_packages "SHARED_LIBRARIES" "product" "64" "P_LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700727 fi
728
Luca Stefani776be462020-09-09 15:53:58 +0200729 local T_SE_LIB32=( $(prefix_match "system_ext/lib/") )
730 local T_SE_LIB64=( $(prefix_match "system_ext/lib64/") )
731 local SE_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_SE_LIB32[@]}") <(printf '%s\n' "${T_SE_LIB64[@]}")) )
732 local SE_LIB32=( $(comm -23 <(printf '%s\n' "${T_SE_LIB32[@]}") <(printf '%s\n' "${SE_MULTILIBS[@]}")) )
733 local SE_LIB64=( $(comm -23 <(printf '%s\n' "${T_SE_LIB64[@]}") <(printf '%s\n' "${SE_MULTILIBS[@]}")) )
734
735 if [ "${#SE_MULTILIBS[@]}" -gt "0" ]; then
736 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "both" "SE_MULTILIBS" >> "$ANDROIDBP"
737 fi
738 if [ "${#SE_LIB32[@]}" -gt "0" ]; then
739 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "32" "SE_LIB32" >> "$ANDROIDBP"
740 fi
741 if [ "${#SE_LIB64[@]}" -gt "0" ]; then
742 write_blueprint_packages "SHARED_LIBRARIES" "system_ext" "64" "SE_LIB64" >> "$ANDROIDBP"
743 fi
744
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700745 local T_O_LIB32=( $(prefix_match "odm/lib/") )
746 local T_O_LIB64=( $(prefix_match "odm/lib64/") )
747 local O_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${T_O_LIB64[@]}")) )
748 local O_LIB32=( $(comm -23 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
749 local O_LIB64=( $(comm -23 <(printf '%s\n' "${T_O_LIB64[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
750
751 if [ "${#O_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700752 write_blueprint_packages "SHARED_LIBRARIES" "odm" "both" "O_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700753 fi
754 if [ "${#O_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700755 write_blueprint_packages "SHARED_LIBRARIES" "odm" "32" "O_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700756 fi
757 if [ "${#O_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700758 write_blueprint_packages "SHARED_LIBRARIES" "odm" "64" "O_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700759 fi
760
Steve Kondik5bd66602016-07-15 10:39:58 -0700761 # Apps
762 local APPS=( $(prefix_match "app/") )
763 if [ "${#APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100764 write_blueprint_packages "APPS" "" "" "APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700765 fi
766 local PRIV_APPS=( $(prefix_match "priv-app/") )
767 if [ "${#PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100768 write_blueprint_packages "APPS" "" "priv-app" "PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700769 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400770 local S_APPS=( $(prefix_match "system/app/") )
771 if [ "${#S_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100772 write_blueprint_packages "APPS" "system" "" "S_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400773 fi
774 local S_PRIV_APPS=( $(prefix_match "system/priv-app/") )
775 if [ "${#S_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100776 write_blueprint_packages "APPS" "system" "priv-app" "S_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400777 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700778 local V_APPS=( $(prefix_match "vendor/app/") )
779 if [ "${#V_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100780 write_blueprint_packages "APPS" "vendor" "" "V_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700781 fi
782 local V_PRIV_APPS=( $(prefix_match "vendor/priv-app/") )
783 if [ "${#V_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100784 write_blueprint_packages "APPS" "vendor" "priv-app" "V_PRIV_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500785 fi
786 local P_APPS=( $(prefix_match "product/app/") )
787 if [ "${#P_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100788 write_blueprint_packages "APPS" "product" "" "P_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500789 fi
790 local P_PRIV_APPS=( $(prefix_match "product/priv-app/") )
791 if [ "${#P_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100792 write_blueprint_packages "APPS" "product" "priv-app" "P_PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700793 fi
Luca Stefani776be462020-09-09 15:53:58 +0200794 local SE_APPS=( $(prefix_match "system_ext/app/") )
795 if [ "${#SE_APPS[@]}" -gt "0" ]; then
796 write_blueprint_packages "APPS" "system_ext" "" "SE_APPS" >> "$ANDROIDBP"
797 fi
798 local SE_PRIV_APPS=( $(prefix_match "system_ext/priv-app/") )
799 if [ "${#SE_PRIV_APPS[@]}" -gt "0" ]; then
800 write_blueprint_packages "APPS" "system_ext" "priv-app" "SE_PRIV_APPS" >> "$ANDROIDBP"
801 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700802 local O_APPS=( $(prefix_match "odm/app/") )
803 if [ "${#O_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100804 write_blueprint_packages "APPS" "odm" "" "O_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700805 fi
806 local O_PRIV_APPS=( $(prefix_match "odm/priv-app/") )
807 if [ "${#O_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100808 write_blueprint_packages "APPS" "odm" "priv-app" "O_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700809 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700810
811 # Framework
812 local FRAMEWORK=( $(prefix_match "framework/") )
813 if [ "${#FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700814 write_blueprint_packages "JAVA_LIBRARIES" "" "" "FRAMEWORK" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700815 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400816 local S_FRAMEWORK=( $(prefix_match "system/framework/") )
817 if [ "${#S_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700818 write_blueprint_packages "JAVA_LIBRARIES" "system" "" "S_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400819 fi
Christian Oder974b5902017-10-08 23:15:52 +0200820 local V_FRAMEWORK=( $(prefix_match "vendor/framework/") )
Michael Bestas26eb01e2018-02-27 22:31:55 +0200821 if [ "${#V_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700822 write_blueprint_packages "JAVA_LIBRARIES" "vendor" "" "V_FRAMEWORK" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500823 fi
824 local P_FRAMEWORK=( $(prefix_match "product/framework/") )
825 if [ "${#P_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700826 write_blueprint_packages "JAVA_LIBRARIES" "product" "" "P_FRAMEWORK" >> "$ANDROIDBP"
Christian Oder974b5902017-10-08 23:15:52 +0200827 fi
Luca Stefani776be462020-09-09 15:53:58 +0200828 local SE_FRAMEWORK=( $(prefix_match "system_ext/framework/") )
Alexander Koskovich052c77d2020-09-16 17:58:53 -0700829 if [ "${#SE_FRAMEWORK[@]}" -gt "0" ]; then
Luca Stefani776be462020-09-09 15:53:58 +0200830 write_blueprint_packages "JAVA_LIBRARIES" "system_ext" "" "SE_FRAMEWORK" >> "$ANDROIDBP"
831 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700832 local O_FRAMEWORK=( $(prefix_match "odm/framework/") )
833 if [ "${#O_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700834 write_blueprint_packages "JAVA_LIBRARIES" "odm" "" "O_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700835 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700836
837 # Etc
838 local ETC=( $(prefix_match "etc/") )
839 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700840 write_blueprint_packages "ETC" "" "" "ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700841 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400842 local S_ETC=( $(prefix_match "system/etc/") )
843 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700844 write_blueprint_packages "ETC" "system" "" "S_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400845 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700846 local V_ETC=( $(prefix_match "vendor/etc/") )
847 if [ "${#V_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700848 write_blueprint_packages "ETC" "vendor" "" "V_ETC" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500849 fi
850 local P_ETC=( $(prefix_match "product/etc/") )
851 if [ "${#P_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700852 write_blueprint_packages "ETC" "product" "" "P_ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700853 fi
Luca Stefani776be462020-09-09 15:53:58 +0200854 local SE_ETC=( $(prefix_match "system_ext/etc/") )
855 if [ "${#SE_ETC[@]}" -gt "0" ]; then
856 write_blueprint_packages "ETC" "system_ext" "" "SE_ETC" >> "$ANDROIDBP"
857 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700858 local O_ETC=( $(prefix_match "odm/etc/") )
859 if [ "${#O_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700860 write_blueprint_packages "ETC" "odm" "" "O_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700861 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700862
863 # Executables
864 local BIN=( $(prefix_match "bin/") )
865 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700866 write_blueprint_packages "EXECUTABLES" "" "" "BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700867 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400868 local S_BIN=( $(prefix_match "system/bin/") )
869 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700870 write_blueprint_packages "EXECUTABLES" "system" "" "S_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400871 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700872 local V_BIN=( $(prefix_match "vendor/bin/") )
873 if [ "${#V_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700874 write_blueprint_packages "EXECUTABLES" "vendor" "" "V_BIN" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500875 fi
876 local P_BIN=( $(prefix_match "product/bin/") )
877 if [ "${#P_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700878 write_blueprint_packages "EXECUTABLES" "product" "" "P_BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700879 fi
Luca Stefani776be462020-09-09 15:53:58 +0200880 local SE_BIN=( $(prefix_match "system_ext/bin/") )
881 if [ "${#SE_BIN[@]}" -gt "0" ]; then
882 write_blueprint_packages "EXECUTABLES" "system_ext" "" "SE_BIN" >> "$ANDROIDBP"
883 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700884 local O_BIN=( $(prefix_match "odm/bin/") )
885 if [ "${#O_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700886 write_blueprint_packages "EXECUTABLES" "odm" "" "O_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700887 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700888 local SBIN=( $(prefix_match "sbin/") )
889 if [ "${#SBIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700890 write_makefile_packages "EXECUTABLES" "" "sbin" "SBIN" >> "$ANDROIDMK"
Steve Kondik5bd66602016-07-15 10:39:58 -0700891 fi
892
893
894 # Actually write out the final PRODUCT_PACKAGES list
895 local PACKAGE_COUNT=${#PACKAGE_LIST[@]}
896
897 if [ "$PACKAGE_COUNT" -eq "0" ]; then
898 return 0
899 fi
900
901 printf '\n%s\n' "PRODUCT_PACKAGES += \\" >> "$PRODUCTMK"
902 for (( i=1; i<PACKAGE_COUNT+1; i++ )); do
903 local LINEEND=" \\"
904 if [ "$i" -eq "$PACKAGE_COUNT" ]; then
905 LINEEND=""
906 fi
907 printf ' %s%s\n' "${PACKAGE_LIST[$i-1]}" "$LINEEND" >> "$PRODUCTMK"
908 done
909}
910
911#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700912# write_blueprint_header:
Steve Kondik5bd66602016-07-15 10:39:58 -0700913#
914# $1: file which will be written to
915#
916# writes out the copyright header with the current year.
917# note that this is not an append operation, and should
918# be executed first!
919#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700920function write_blueprint_header() {
921 if [ -f $1 ]; then
922 rm $1
923 fi
924
925 YEAR=$(date +"%Y")
926
927 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
928
929 printf "/**\n" > $1
930 NUM_REGEX='^[0-9]+$'
931 if [[ ! $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] || [ $INITIAL_COPYRIGHT_YEAR -lt 2019 ]; then
932 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=2019
933 else
934 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=$INITIAL_COPYRIGHT_YEAR
935 fi
936
937 if [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
938 printf " * Copyright (C) $YEAR The LineageOS Project\n" >> $1
939 elif [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -le 2019 ]; then
940 printf " * Copyright (C) 2019-$YEAR The LineageOS Project\n" >> $1
941 else
942 printf " * Copyright (C) $BLUEPRINT_INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
943 fi
944
945 cat << EOF >> $1
946 *
947 * Licensed under the Apache License, Version 2.0 (the "License");
948 * you may not use this file except in compliance with the License.
949 * You may obtain a copy of the License at
950 *
951 * http://www.apache.org/licenses/LICENSE-2.0
952 *
953 * Unless required by applicable law or agreed to in writing, software
954 * distributed under the License is distributed on an "AS IS" BASIS,
955 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
956 * See the License for the specific language governing permissions and
957 * limitations under the License.
958 *
959 * This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
960 */
961
962EOF
963}
964
965#
966# write_makefile_header:
967#
968# $1: file which will be written to
969#
970# writes out the copyright header with the current year.
971# note that this is not an append operation, and should
972# be executed first!
973#
974function write_makefile_header() {
Jake Whatley9843b322017-01-25 21:49:16 -0500975 if [ -f $1 ]; then
976 rm $1
977 fi
978
Steve Kondik5bd66602016-07-15 10:39:58 -0700979 YEAR=$(date +"%Y")
980
981 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
982
Jake Whatley9843b322017-01-25 21:49:16 -0500983 NUM_REGEX='^[0-9]+$'
984 if [[ $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] && [ $INITIAL_COPYRIGHT_YEAR -le $YEAR ]; then
985 if [ $INITIAL_COPYRIGHT_YEAR -lt 2016 ]; then
986 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-2016 The CyanogenMod Project\n" > $1
987 elif [ $INITIAL_COPYRIGHT_YEAR -eq 2016 ]; then
988 printf "# Copyright (C) 2016 The CyanogenMod Project\n" > $1
989 fi
990 if [ $YEAR -eq 2017 ]; then
991 printf "# Copyright (C) 2017 The LineageOS Project\n" >> $1
992 elif [ $INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
993 printf "# Copyright (C) $YEAR The LineageOS Project\n" >> $1
994 elif [ $INITIAL_COPYRIGHT_YEAR -le 2017 ]; then
995 printf "# Copyright (C) 2017-$YEAR The LineageOS Project\n" >> $1
996 else
997 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
998 fi
999 else
1000 printf "# Copyright (C) $YEAR The LineageOS Project\n" > $1
1001 fi
1002
1003 cat << EOF >> $1
Steve Kondik5bd66602016-07-15 10:39:58 -07001004#
1005# Licensed under the Apache License, Version 2.0 (the "License");
1006# you may not use this file except in compliance with the License.
1007# You may obtain a copy of the License at
1008#
1009# http://www.apache.org/licenses/LICENSE-2.0
1010#
1011# Unless required by applicable law or agreed to in writing, software
1012# distributed under the License is distributed on an "AS IS" BASIS,
1013# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1014# See the License for the specific language governing permissions and
1015# limitations under the License.
1016
1017# This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
1018
1019EOF
1020}
1021
1022#
1023# write_headers:
1024#
1025# $1: devices falling under common to be added to guard - optional
Jake Whatley9843b322017-01-25 21:49:16 -05001026# $2: custom guard - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001027#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001028# Calls write_makefile_header for each of the makefiles and
1029# write_blueprint_header for Android.bp and creates the initial
1030# path declaration and device guard for the Android.mk
Steve Kondik5bd66602016-07-15 10:39:58 -07001031#
1032function write_headers() {
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001033 write_makefile_header "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -05001034
1035 GUARD="$2"
1036 if [ -z "$GUARD" ]; then
1037 GUARD="TARGET_DEVICE"
1038 fi
1039
Steve Kondik5bd66602016-07-15 10:39:58 -07001040 cat << EOF >> "$ANDROIDMK"
1041LOCAL_PATH := \$(call my-dir)
1042
1043EOF
1044 if [ "$COMMON" -ne 1 ]; then
1045 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -05001046ifeq (\$($GUARD),$DEVICE)
Steve Kondik5bd66602016-07-15 10:39:58 -07001047
1048EOF
1049 else
1050 if [ -z "$1" ]; then
1051 echo "Argument with devices to be added to guard must be set!"
1052 exit 1
1053 fi
1054 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -05001055ifneq (\$(filter $1,\$($GUARD)),)
Steve Kondik5bd66602016-07-15 10:39:58 -07001056
1057EOF
1058 fi
1059
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001060 write_makefile_header "$BOARDMK"
1061 write_makefile_header "$PRODUCTMK"
1062 write_blueprint_header "$ANDROIDBP"
1063
1064 cat << EOF >> "$ANDROIDBP"
1065soong_namespace {
1066}
1067
1068EOF
1069
1070 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
1071 cat << EOF >> "$PRODUCTMK"
1072PRODUCT_SOONG_NAMESPACES += \\
1073 vendor/$VENDOR/$DEVICE
1074
1075EOF
Steve Kondik5bd66602016-07-15 10:39:58 -07001076}
1077
1078#
1079# write_footers:
1080#
1081# Closes the inital guard and any other finalization tasks. Must
1082# be called as the final step.
1083#
1084function write_footers() {
1085 cat << EOF >> "$ANDROIDMK"
1086endif
1087EOF
1088}
1089
1090# Return success if adb is up and not in recovery
1091function _adb_connected {
1092 {
Jake Whatley9843b322017-01-25 21:49:16 -05001093 if [[ "$(adb get-state)" == device ]]
Steve Kondik5bd66602016-07-15 10:39:58 -07001094 then
1095 return 0
1096 fi
1097 } 2>/dev/null
1098
1099 return 1
1100};
1101
1102#
1103# parse_file_list:
1104#
1105# $1: input file
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001106# $2: blob section in file - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001107#
1108# Sets PRODUCT_PACKAGES and PRODUCT_COPY_FILES while parsing the input file
1109#
1110function parse_file_list() {
1111 if [ -z "$1" ]; then
1112 echo "An input file is expected!"
1113 exit 1
1114 elif [ ! -f "$1" ]; then
1115 echo "Input file "$1" does not exist!"
1116 exit 1
1117 fi
1118
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001119 if [ -n "$2" ]; then
1120 echo "Using section \"$2\""
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001121 LIST=$TMPDIR/files.txt
Vladimir Olteanfa79f212019-01-19 00:44:07 +02001122 # Match all lines starting with first line found to start* with '#'
1123 # comment and contain** $2, and ending with first line to be empty*.
1124 # *whitespaces (tabs, spaces) at the beginning of lines are discarded
1125 # **the $2 match is case-insensitive
1126 cat $1 | sed -n '/^[[:space:]]*#.*'"$2"'/I,/^[[:space:]]*$/ p' > $LIST
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001127 else
1128 LIST=$1
1129 fi
1130
1131
Steve Kondik5bd66602016-07-15 10:39:58 -07001132 PRODUCT_PACKAGES_LIST=()
1133 PRODUCT_PACKAGES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001134 PRODUCT_PACKAGES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001135 PRODUCT_COPY_FILES_LIST=()
1136 PRODUCT_COPY_FILES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001137 PRODUCT_COPY_FILES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001138
1139 while read -r line; do
1140 if [ -z "$line" ]; then continue; fi
1141
1142 # If the line has a pipe delimiter, a sha1 hash should follow.
1143 # This indicates the file should be pinned and not overwritten
1144 # when extracting files.
1145 local SPLIT=(${line//\|/ })
1146 local COUNT=${#SPLIT[@]}
1147 local SPEC=${SPLIT[0]}
1148 local HASH="x"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001149 local FIXUP_HASH="x"
Steve Kondik5bd66602016-07-15 10:39:58 -07001150 if [ "$COUNT" -gt "1" ]; then
1151 HASH=${SPLIT[1]}
1152 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001153 if [ "$COUNT" -gt "2" ]; then
1154 FIXUP_HASH=${SPLIT[2]}
1155 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001156
1157 # if line starts with a dash, it needs to be packaged
1158 if [[ "$SPEC" =~ ^- ]]; then
1159 PRODUCT_PACKAGES_LIST+=("${SPEC#-}")
1160 PRODUCT_PACKAGES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001161 PRODUCT_PACKAGES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001162 else
1163 PRODUCT_COPY_FILES_LIST+=("$SPEC")
1164 PRODUCT_COPY_FILES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001165 PRODUCT_COPY_FILES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001166 fi
1167
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001168 done < <(egrep -v '(^#|^[[:space:]]*$)' "$LIST" | LC_ALL=C sort | uniq)
Steve Kondik5bd66602016-07-15 10:39:58 -07001169}
1170
1171#
1172# write_makefiles:
1173#
1174# $1: file containing the list of items to extract
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001175# $2: make treble compatible makefile - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001176#
1177# Calls write_product_copy_files and write_product_packages on
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001178# the given file and appends to the Android.bp as well as
Steve Kondik5bd66602016-07-15 10:39:58 -07001179# the product makefile.
1180#
1181function write_makefiles() {
1182 parse_file_list "$1"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001183 write_product_copy_files "$2"
Steve Kondik5bd66602016-07-15 10:39:58 -07001184 write_product_packages
1185}
1186
1187#
1188# append_firmware_calls_to_makefiles:
1189#
1190# Appends to Android.mk the calls to all images present in radio folder
1191# (filesmap file used by releasetools to map firmware images should be kept in the device tree)
1192#
1193function append_firmware_calls_to_makefiles() {
1194 cat << EOF >> "$ANDROIDMK"
1195ifeq (\$(LOCAL_PATH)/radio, \$(wildcard \$(LOCAL_PATH)/radio))
1196
1197RADIO_FILES := \$(wildcard \$(LOCAL_PATH)/radio/*)
1198\$(foreach f, \$(notdir \$(RADIO_FILES)), \\
1199 \$(call add-radio-file,radio/\$(f)))
1200\$(call add-radio-file,../../../device/$VENDOR/$DEVICE/radio/filesmap)
1201
1202endif
1203
1204EOF
1205}
1206
1207#
1208# get_file:
1209#
1210# $1: input file
1211# $2: target file/folder
1212# $3: source of the file (can be "adb" or a local folder)
1213#
1214# Silently extracts the input file to defined target
1215# Returns success if file can be pulled from the device or found locally
1216#
1217function get_file() {
1218 local SRC="$3"
1219
1220 if [ "$SRC" = "adb" ]; then
1221 # try to pull
1222 adb pull "$1" "$2" >/dev/null 2>&1 && return 0
1223
1224 return 1
1225 else
1226 # try to copy
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001227 cp -r "$SRC/$1" "$2" 2>/dev/null && return 0
1228 cp -r "$SRC/${1#/system}" "$2" 2>/dev/null && return 0
Vladimir Oltean6780da32019-01-06 19:38:31 +02001229 cp -r "$SRC/system/$1" "$2" 2>/dev/null && return 0
Steve Kondik5bd66602016-07-15 10:39:58 -07001230
1231 return 1
1232 fi
1233};
1234
1235#
1236# oat2dex:
1237#
1238# $1: extracted apk|jar (to check if deodex is required)
1239# $2: odexed apk|jar to deodex
1240# $3: source of the odexed apk|jar
1241#
1242# Convert apk|jar .odex in the corresposing classes.dex
1243#
1244function oat2dex() {
theimpulson9a911af2019-08-14 03:25:12 +00001245 local OMNI_TARGET="$1"
Steve Kondik5bd66602016-07-15 10:39:58 -07001246 local OEM_TARGET="$2"
1247 local SRC="$3"
1248 local TARGET=
Joe Maplesfb3941c2018-01-05 14:51:33 -05001249 local OAT=
XiNGRZd7793bc2019-12-24 10:37:13 +08001250 local HOST="$(uname | tr '[:upper:]' '[:lower:]')"
Steve Kondik5bd66602016-07-15 10:39:58 -07001251
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001252 if [ -z "$BAKSMALIJAR" ] || [ -z "$SMALIJAR" ]; then
1253 export BAKSMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/baksmali.jar
1254 export SMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/smali.jar
Steve Kondik5bd66602016-07-15 10:39:58 -07001255 fi
1256
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001257 if [ -z "$VDEXEXTRACTOR" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001258 export VDEXEXTRACTOR="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/vdexExtractor
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001259 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001260
codeworkx85eda752018-09-23 12:36:57 +02001261 if [ -z "$CDEXCONVERTER" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001262 export CDEXCONVERTER="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/compact_dex_converter
codeworkx85eda752018-09-23 12:36:57 +02001263 fi
1264
Steve Kondik5bd66602016-07-15 10:39:58 -07001265 # Extract existing boot.oats to the temp folder
1266 if [ -z "$ARCHES" ]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001267 echo "Checking if system is odexed and locating boot.oats..."
Steve Kondik5bd66602016-07-15 10:39:58 -07001268 for ARCH in "arm64" "arm" "x86_64" "x86"; do
Jake Whatley9843b322017-01-25 21:49:16 -05001269 mkdir -p "$TMPDIR/system/framework/$ARCH"
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001270 if get_file "/system/framework/$ARCH" "$TMPDIR/system/framework/" "$SRC"; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001271 ARCHES+="$ARCH "
Jake Whatley9843b322017-01-25 21:49:16 -05001272 else
1273 rmdir "$TMPDIR/system/framework/$ARCH"
Steve Kondik5bd66602016-07-15 10:39:58 -07001274 fi
1275 done
1276 fi
1277
1278 if [ -z "$ARCHES" ]; then
1279 FULLY_DEODEXED=1 && return 0 # system is fully deodexed, return
1280 fi
1281
theimpulson9a911af2019-08-14 03:25:12 +00001282 if [ ! -f "$OMNI_TARGET" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001283 return;
1284 fi
1285
theimpulson9a911af2019-08-14 03:25:12 +00001286 if grep "classes.dex" "$OMNI_TARGET" >/dev/null; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001287 return 0 # target apk|jar is already odexed, return
1288 fi
1289
1290 for ARCH in $ARCHES; do
Jake Whatley9843b322017-01-25 21:49:16 -05001291 BOOTOAT="$TMPDIR/system/framework/$ARCH/boot.oat"
Steve Kondik5bd66602016-07-15 10:39:58 -07001292
Joe Maplesfb3941c2018-01-05 14:51:33 -05001293 local OAT="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").odex"
1294 local VDEX="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").vdex"
Steve Kondik5bd66602016-07-15 10:39:58 -07001295
Joe Maplesfb3941c2018-01-05 14:51:33 -05001296 if get_file "$OAT" "$TMPDIR" "$SRC"; then
1297 if get_file "$VDEX" "$TMPDIR" "$SRC"; then
1298 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$VDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001299 CLASSES=$(ls "$TMPDIR/$(basename "${OEM_TARGET%.*}")_classes"*)
1300 for CLASS in $CLASSES; do
1301 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1302 # Check if we have to deal with CompactDex
1303 if [[ "$CLASS" == *.cdex ]]; then
1304 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1305 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1306 else
1307 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1308 fi
1309 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001310 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001311 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$TMPDIR/$(basename "$OAT")"
1312 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001313 fi
theimpulson9a911af2019-08-14 03:25:12 +00001314 elif [[ "$OMNI_TARGET" =~ .jar$ ]]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001315 JAROAT="$TMPDIR/system/framework/$ARCH/boot-$(basename ${OEM_TARGET%.*}).oat"
Luca Stefani082f1e82018-10-07 12:44:53 +02001316 JARVDEX="/system/framework/boot-$(basename ${OEM_TARGET%.*}).vdex"
Jake Whatley9843b322017-01-25 21:49:16 -05001317 if [ ! -f "$JAROAT" ]; then
Luca Stefani082f1e82018-10-07 12:44:53 +02001318 JAROAT=$BOOTOAT
Jake Whatley9843b322017-01-25 21:49:16 -05001319 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001320 # try to extract classes.dex from boot.vdex for frameworks jars
1321 # fallback to boot.oat if vdex is not available
Luca Stefani082f1e82018-10-07 12:44:53 +02001322 if get_file "$JARVDEX" "$TMPDIR" "$SRC"; then
Luca Stefani6f92e6b2018-10-31 19:16:05 +01001323 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$JARVDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001324 CLASSES=$(ls "$TMPDIR/$(basename "${JARVDEX%.*}")_classes"*)
1325 for CLASS in $CLASSES; do
1326 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1327 # Check if we have to deal with CompactDex
1328 if [[ "$CLASS" == *.cdex ]]; then
1329 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1330 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1331 else
1332 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1333 fi
1334 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001335 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001336 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$JAROAT/$OEM_TARGET"
1337 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001338 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001339 else
1340 continue
1341 fi
1342
Steve Kondik5bd66602016-07-15 10:39:58 -07001343 done
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001344
1345 rm -rf "$TMPDIR/dexout"
Steve Kondik5bd66602016-07-15 10:39:58 -07001346}
1347
1348#
1349# init_adb_connection:
1350#
1351# Starts adb server and waits for the device
1352#
1353function init_adb_connection() {
1354 adb start-server # Prevent unexpected starting server message from adb get-state in the next line
1355 if ! _adb_connected; then
1356 echo "No device is online. Waiting for one..."
1357 echo "Please connect USB and/or enable USB debugging"
1358 until _adb_connected; do
1359 sleep 1
1360 done
1361 echo "Device Found."
1362 fi
1363
1364 # Retrieve IP and PORT info if we're using a TCP connection
1365 TCPIPPORT=$(adb devices | egrep '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+[^0-9]+' \
1366 | head -1 | awk '{print $1}')
1367 adb root &> /dev/null
1368 sleep 0.3
1369 if [ -n "$TCPIPPORT" ]; then
1370 # adb root just killed our connection
1371 # so reconnect...
1372 adb connect "$TCPIPPORT"
1373 fi
1374 adb wait-for-device &> /dev/null
1375 sleep 0.3
1376}
1377
1378#
1379# fix_xml:
1380#
1381# $1: xml file to fix
1382#
1383function fix_xml() {
1384 local XML="$1"
1385 local TEMP_XML="$TMPDIR/`basename "$XML"`.temp"
1386
Dobroslaw Kijowski3af2a8d2017-05-18 12:35:02 +02001387 grep -a '^<?xml version' "$XML" > "$TEMP_XML"
1388 grep -av '^<?xml version' "$XML" >> "$TEMP_XML"
Steve Kondik5bd66602016-07-15 10:39:58 -07001389
1390 mv "$TEMP_XML" "$XML"
1391}
1392
Vladimir Olteande985fe2019-01-17 03:07:34 +02001393function get_hash() {
1394 local FILE="$1"
1395
1396 if [ "$(uname)" == "Darwin" ]; then
1397 shasum "${FILE}" | awk '{print $1}'
1398 else
1399 sha1sum "${FILE}" | awk '{print $1}'
1400 fi
1401}
1402
Vladimir Olteana7d20492019-01-17 03:05:52 +02001403function print_spec() {
1404 local SPEC_PRODUCT_PACKAGE="$1"
1405 local SPEC_SRC_FILE="$2"
1406 local SPEC_DST_FILE="$3"
1407 local SPEC_ARGS="$4"
1408 local SPEC_HASH="$5"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001409 local SPEC_FIXUP_HASH="$6"
Vladimir Olteana7d20492019-01-17 03:05:52 +02001410
1411 local PRODUCT_PACKAGE=""
1412 if [ ${SPEC_PRODUCT_PACKAGE} = true ]; then
1413 PRODUCT_PACKAGE="-"
1414 fi
1415 local SRC=""
1416 if [ ! -z "${SPEC_SRC_FILE}" ] && [ "${SPEC_SRC_FILE}" != "${SPEC_DST_FILE}" ]; then
1417 SRC="${SPEC_SRC_FILE}:"
1418 fi
1419 local DST=""
1420 if [ ! -z "${SPEC_DST_FILE}" ]; then
1421 DST="${SPEC_DST_FILE}"
1422 fi
1423 local ARGS=""
1424 if [ ! -z "${SPEC_ARGS}" ]; then
1425 ARGS=";${SPEC_ARGS}"
1426 fi
1427 local HASH=""
1428 if [ ! -z "${SPEC_HASH}" ] && [ "${SPEC_HASH}" != "x" ]; then
1429 HASH="|${SPEC_HASH}"
1430 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001431 local FIXUP_HASH=""
1432 if [ ! -z "${SPEC_FIXUP_HASH}" ] && [ "${SPEC_FIXUP_HASH}" != "x" ] && [ "${SPEC_FIXUP_HASH}" != "${SPEC_HASH}" ]; then
1433 FIXUP_HASH="|${SPEC_FIXUP_HASH}"
1434 fi
1435 printf '%s%s%s%s%s%s\n' "${PRODUCT_PACKAGE}" "${SRC}" "${DST}" "${ARGS}" "${HASH}" "${FIXUP_HASH}"
1436}
1437
1438# To be overridden by device-level extract-files.sh
1439# Parameters:
1440# $1: spec name of a blob. Can be used for filtering.
1441# If the spec is "src:dest", then $1 is "dest".
1442# If the spec is "src", then $1 is "src".
1443# $2: path to blob file. Can be used for fixups.
1444#
1445function blob_fixup() {
1446 :
Vladimir Olteana7d20492019-01-17 03:05:52 +02001447}
1448
Steve Kondik5bd66602016-07-15 10:39:58 -07001449#
1450# extract:
1451#
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001452# Positional parameters:
1453# $1: file containing the list of items to extract (aka proprietary-files.txt)
Dan Pasanen0cc05012017-03-21 09:06:11 -05001454# $2: path to extracted system folder, an ota zip file, or "adb" to extract from device
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001455# $3: section in list file to extract - optional. Setting section via $3 is deprecated.
1456#
1457# Non-positional parameters (coming after $2):
1458# --section: preferred way of selecting the portion to parse and extract from
1459# proprietary-files.txt
Vladimir Olteana7d20492019-01-17 03:05:52 +02001460# --kang: if present, this option will activate the printing of hashes for the
1461# extracted blobs. Useful with --section for subsequent pinning of
1462# blobs taken from other origins.
Steve Kondik5bd66602016-07-15 10:39:58 -07001463#
1464function extract() {
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001465 # Consume positional parameters
1466 local PROPRIETARY_FILES_TXT="$1"; shift
1467 local SRC="$1"; shift
1468 local SECTION=""
Vladimir Olteana7d20492019-01-17 03:05:52 +02001469 local KANG=false
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001470
1471 # Consume optional, non-positional parameters
1472 while [ "$#" -gt 0 ]; do
1473 case "$1" in
1474 -s|--section)
1475 SECTION="$2"; shift
1476 ;;
Vladimir Olteana7d20492019-01-17 03:05:52 +02001477 -k|--kang)
1478 KANG=true
1479 DISABLE_PINNING=1
1480 ;;
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001481 *)
1482 # Backwards-compatibility with the old behavior, where $3, if
1483 # present, denoted an optional positional ${SECTION} argument.
1484 # Users of ${SECTION} are encouraged to migrate from setting it as
1485 # positional $3, to non-positional --section ${SECTION}, the
1486 # reason being that it doesn't scale to have more than 1 optional
1487 # positional argument.
1488 SECTION="$1"
1489 ;;
1490 esac
1491 shift
1492 done
1493
Steve Kondik5bd66602016-07-15 10:39:58 -07001494 if [ -z "$OUTDIR" ]; then
1495 echo "Output dir not set!"
1496 exit 1
1497 fi
1498
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001499 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001500
1501 # Allow failing, so we can try $DEST and/or $FILE
1502 set +e
1503
1504 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1505 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
Vladimir Olteande985fe2019-01-17 03:07:34 +02001506 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
Vladimir Olteana7d20492019-01-17 03:05:52 +02001507 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
Steve Kondik5bd66602016-07-15 10:39:58 -07001508 local COUNT=${#FILELIST[@]}
theimpulson9a911af2019-08-14 03:25:12 +00001509 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
Steve Kondik5bd66602016-07-15 10:39:58 -07001510 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1511
1512 if [ "$SRC" = "adb" ]; then
1513 init_adb_connection
1514 fi
1515
Dan Pasanen0cc05012017-03-21 09:06:11 -05001516 if [ -f "$SRC" ] && [ "${SRC##*.}" == "zip" ]; then
conbold9baced42017-11-10 16:33:38 +01001517 DUMPDIR="$TMPDIR"/system_dump
Dan Pasanen0cc05012017-03-21 09:06:11 -05001518
1519 # Check if we're working with the same zip that was passed last time.
1520 # If so, let's just use what's already extracted.
1521 MD5=`md5sum "$SRC"| awk '{print $1}'`
1522 OLDMD5=`cat "$DUMPDIR"/zipmd5.txt`
1523
1524 if [ "$MD5" != "$OLDMD5" ]; then
1525 rm -rf "$DUMPDIR"
1526 mkdir "$DUMPDIR"
1527 unzip "$SRC" -d "$DUMPDIR"
1528 echo "$MD5" > "$DUMPDIR"/zipmd5.txt
1529
1530 # Stop if an A/B OTA zip is detected. We cannot extract these.
1531 if [ -a "$DUMPDIR"/payload.bin ]; then
1532 echo "A/B style OTA zip detected. This is not supported at this time. Stopping..."
1533 exit 1
Dan Pasanen0cc05012017-03-21 09:06:11 -05001534 fi
dianlujitao85ddca62020-04-21 23:03:20 +08001535
Luca Stefani776be462020-09-09 15:53:58 +02001536 for PARTITION in "system" "odm" "product" "system_ext" "vendor"
dianlujitao85ddca62020-04-21 23:03:20 +08001537 do
1538 # If OTA is block based, extract it.
dianlujitaoe2cbe262020-04-21 23:01:13 +08001539 if [ -a "$DUMPDIR"/"$PARTITION".new.dat.br ]; then
1540 echo "Converting "$PARTITION".new.dat.br to "$PARTITION".new.dat"
1541 brotli -d "$DUMPDIR"/"$PARTITION".new.dat.br
1542 rm "$DUMPDIR"/"$PARTITION".new.dat.br
1543 fi
dianlujitao85ddca62020-04-21 23:03:20 +08001544 if [ -a "$DUMPDIR"/"$PARTITION".new.dat ]; then
1545 echo "Converting "$PARTITION".new.dat to "$PARTITION".img"
1546 python "$OMNI_ROOT"/vendor/omni/build/tools/sdat2img.py "$DUMPDIR"/"$PARTITION".transfer.list "$DUMPDIR"/"$PARTITION".new.dat "$DUMPDIR"/"$PARTITION".img 2>&1
1547 rm -rf "$DUMPDIR"/"$PARTITION".new.dat "$DUMPDIR"/"$PARTITION"
1548 mkdir "$DUMPDIR"/"$PARTITION" "$DUMPDIR"/tmp
1549 echo "Requesting sudo access to mount the "$PARTITION".img"
1550 sudo mount -o loop "$DUMPDIR"/"$PARTITION".img "$DUMPDIR"/tmp
1551 cp -r "$DUMPDIR"/tmp/* "$DUMPDIR"/"$PARTITION"/
1552 sudo umount "$DUMPDIR"/tmp
1553 rm -rf "$DUMPDIR"/tmp "$DUMPDIR"/"$PARTITION".img
1554 fi
1555 done
Dan Pasanen0cc05012017-03-21 09:06:11 -05001556 fi
1557
1558 SRC="$DUMPDIR"
1559 fi
1560
Steve Kondik5bd66602016-07-15 10:39:58 -07001561 if [ "$VENDOR_STATE" -eq "0" ]; then
1562 echo "Cleaning output directory ($OUTPUT_ROOT).."
1563 rm -rf "${OUTPUT_TMP:?}"
1564 mkdir -p "${OUTPUT_TMP:?}"
Jake Whatley9843b322017-01-25 21:49:16 -05001565 if [ -d "$OUTPUT_ROOT" ]; then
1566 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1567 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001568 VENDOR_STATE=1
1569 fi
1570
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001571 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
Steve Kondik5bd66602016-07-15 10:39:58 -07001572
1573 for (( i=1; i<COUNT+1; i++ )); do
1574
Vladimir Oltean8e2de652018-06-24 20:41:30 +03001575 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
Vladimir Olteanb06f3aa2018-06-24 20:38:04 +03001576 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
Vladimir Olteand6391332018-06-24 20:42:01 +03001577 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001578 local OUTPUT_DIR=
1579 local TMP_DIR=
1580 local SRC_FILE=
1581 local DST_FILE=
Vladimir Olteana7d20492019-01-17 03:05:52 +02001582 local IS_PRODUCT_PACKAGE=false
1583
1584 # Note: this relies on the fact that the ${FILELIST[@]} array
1585 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1586 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1587 IS_PRODUCT_PACKAGE=true
1588 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001589
Vladimir Olteand6391332018-06-24 20:42:01 +03001590 if [ "${SPEC_ARGS}" = "rootfs" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001591 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1592 TMP_DIR="${OUTPUT_TMP}/rootfs"
1593 SRC_FILE="/${SPEC_SRC_FILE}"
1594 DST_FILE="/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001595 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001596 OUTPUT_DIR="${OUTPUT_ROOT}"
1597 TMP_DIR="${OUTPUT_TMP}"
1598 SRC_FILE="/system/${SPEC_SRC_FILE}"
1599 DST_FILE="/system/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001600 fi
1601
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001602 # Strip the file path in the vendor repo of "system", if present
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001603 local BLOB_DISPLAY_NAME="${DST_FILE#/system/}"
dianlujitao4ddcfb72020-04-06 12:43:16 +08001604 local VENDOR_REPO_FILE="$OUTPUT_DIR/${BLOB_DISPLAY_NAME}"
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001605 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001606
Gabriele M58270a32017-11-13 23:15:29 +01001607 # Check pinned files
Vladimir Olteane688cf92019-01-17 02:47:02 +02001608 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001609 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Gabriele M58270a32017-11-13 23:15:29 +01001610 local KEEP=""
Vladimir Olteande985fe2019-01-17 03:07:34 +02001611 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001612 if [ -f "${VENDOR_REPO_FILE}" ]; then
1613 local PINNED="${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001614 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001615 local PINNED="${TMP_DIR}${DST_FILE#/system}"
Gabriele M58270a32017-11-13 23:15:29 +01001616 fi
1617 if [ -f "$PINNED" ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001618 local TMP_HASH=$(get_hash "${PINNED}")
1619 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
Gabriele M58270a32017-11-13 23:15:29 +01001620 KEEP="1"
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001621 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1622 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001623 fi
1624 fi
1625 fi
1626 fi
1627
Vladimir Olteana7d20492019-01-17 03:05:52 +02001628 if [ "${KANG}" = false ]; then
1629 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1630 fi
1631
Gabriele M58270a32017-11-13 23:15:29 +01001632 if [ "$KEEP" = "1" ]; then
Vladimir Olteana7d20492019-01-17 03:05:52 +02001633 printf ' + keeping pinned file with hash %s\n' "${HASH}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001634 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001635 FOUND=false
1636 # Try Lineage target first.
1637 # Also try to search for files stripped of
1638 # the "/system" prefix, if we're actually extracting
1639 # from a system image.
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001640 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001641 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${SRC} && {
1642 FOUND=true
1643 break
1644 }
1645 done
1646
1647 if [ "${FOUND}" = false ]; then
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001648 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
Vladimir Oltean11329372018-10-18 00:44:02 +03001649 continue
Steve Kondik5bd66602016-07-15 10:39:58 -07001650 fi
1651 fi
1652
Vladimir Olteande985fe2019-01-17 03:07:34 +02001653 # Blob fixup pipeline has 2 parts: one that is fixed and
1654 # one that is user-configurable
1655 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1656 # Deodex apk|jar if that's the case
1657 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1658 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "$SRC"
1659 if [ -f "$TMPDIR/classes.dex" ]; then
dianlujitaoded7c1e2020-04-06 12:45:36 +08001660 touch -t 200901010000 "$TMPDIR/classes"*
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001661 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1662 rm "$TMPDIR/classes"*
Vladimir Olteande985fe2019-01-17 03:07:34 +02001663 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001664 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001665 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1666 fix_xml "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001667 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001668 # Now run user-supplied fixup function
1669 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1670 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
Steve Kondik5bd66602016-07-15 10:39:58 -07001671
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001672 if [ -f "${VENDOR_REPO_FILE}" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001673 local DIR=$(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001674 local TYPE="${DIR##*/}"
1675 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001676 chmod 755 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001677 else
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001678 chmod 644 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001679 fi
1680 fi
1681
Vladimir Olteana7d20492019-01-17 03:05:52 +02001682 if [ "${KANG}" = true ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001683 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1684 fi
1685
1686 # Check and print whether the fixup pipeline actually did anything.
1687 # This isn't done right after the fixup pipeline because we want this print
1688 # to come after print_spec above, when in kang mode.
1689 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1690 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1691 # Now sanity-check the spec for this blob.
1692 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1693 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1694 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1695 fi
Vladimir Olteana7d20492019-01-17 03:05:52 +02001696 fi
1697
Steve Kondik5bd66602016-07-15 10:39:58 -07001698 done
1699
1700 # Don't allow failing
1701 set -e
1702}
1703
1704#
Rashed Abdel-Tawab5b97a982019-09-29 01:19:57 -04001705# extract2:
1706#
1707# Positional parameters:
1708# $1: file containing the list of items to extract (aka proprietary-files.txt)
1709#
1710# Non-positional parameters (coming after $2):
1711# --section: selects the portion to parse and extracts from proprietary-files.txt
1712# --kang: if present, this option will activate the printing of hashes for the
1713# extracted blobs. Useful with --section for subsequent pinning of
1714# blobs taken from other origins.
1715#
1716function extract2() {
1717 # Consume positional parameters
1718 local PROPRIETARY_FILES_TXT="$1"; shift
1719 local SECTION=""
1720 local KANG=false
1721
1722 # Consume optional, non-positional parameters
1723 while [ "$#" -gt 0 ]; do
1724 case "$1" in
1725 --adb)
1726 ADB=true
1727 ;;
1728 --system)
1729 SYSTEM_SRC="$2"; shift
1730 ;;
1731 --vendor)
1732 VENDOR_SRC="$2"; shift
1733 ;;
1734 --odm)
1735 ODM_SRC="$2"; shift
1736 ;;
1737 --product)
1738 PRODUCT_SRC="$2"; shift
1739 ;;
1740 -s|--section)
1741 SECTION="$2"; shift
1742 ;;
1743 -k|--kang)
1744 KANG=true
1745 DISABLE_PINNING=1
1746 ;;
1747 esac
1748 shift
1749 done
1750
1751 if [ -z "$ADB" ] || [ -z "$SYSTEM_SRC" && -z "$VENDOR_SRC" && -z "$ODM_SRC" && -z "$PRODUCT_SRC" ]; then
1752 echo "No sources set! You must select --adb or pass paths to partition dumps."
1753 exit 1
1754 fi
1755
1756 if [ -z "$OUTDIR" ]; then
1757 echo "Output dir not set!"
1758 exit 1
1759 fi
1760
1761 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
1762
1763 # Allow failing, so we can try $DEST and/or $FILE
1764 set +e
1765
1766 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1767 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
1768 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
1769 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
1770 local COUNT=${#FILELIST[@]}
1771 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
1772 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1773
1774 if [ "$ADB" = true ]; then
1775 init_adb_connection
1776 fi
1777
1778 if [ "$VENDOR_STATE" -eq "0" ]; then
1779 echo "Cleaning output directory ($OUTPUT_ROOT).."
1780 rm -rf "${OUTPUT_TMP:?}"
1781 mkdir -p "${OUTPUT_TMP:?}"
1782 if [ -d "$OUTPUT_ROOT" ]; then
1783 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1784 fi
1785 VENDOR_STATE=1
1786 fi
1787
1788 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
1789
1790 for (( i=1; i<COUNT+1; i++ )); do
1791
1792 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
1793 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
1794 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
1795 local OUTPUT_DIR=
1796 local TMP_DIR=
1797 local SRC_FILE=
1798 local DST_FILE=
1799 local IS_PRODUCT_PACKAGE=false
1800
1801 # Note: this relies on the fact that the ${FILELIST[@]} array
1802 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1803 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1804 IS_PRODUCT_PACKAGE=true
1805 fi
1806
1807 if [ "${SPEC_ARGS}" = "rootfs" ]; then
1808 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1809 TMP_DIR="${OUTPUT_TMP}/rootfs"
1810 else
1811 OUTPUT_DIR="${OUTPUT_ROOT}"
1812 TMP_DIR="${OUTPUT_TMP}"
1813 fi
1814 SRC_FILE="${SPEC_SRC_FILE}"
1815 DST_FILE="${SPEC_DST_FILE}"
1816
1817 local VENDOR_REPO_FILE="$OUTPUT_DIR/${DST_FILE}"
1818 local BLOB_DISPLAY_NAME="${DST_FILE}"
1819 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
1820
1821 # Check pinned files
1822 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1823 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1824 local KEEP=""
1825 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
1826 if [ -f "${VENDOR_REPO_FILE}" ]; then
1827 local PINNED="${VENDOR_REPO_FILE}"
1828 else
1829 local PINNED="${TMP_DIR}${DST_FILE}"
1830 fi
1831 if [ -f "$PINNED" ]; then
1832 local TMP_HASH=$(get_hash "${PINNED}")
1833 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
1834 KEEP="1"
1835 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1836 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
1837 fi
1838 fi
1839 fi
1840 fi
1841
1842 if [ "${KANG}" = false ]; then
1843 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1844 fi
1845
1846 if [ "$KEEP" = "1" ]; then
1847 printf ' + keeping pinned file with hash %s\n' "${HASH}"
1848 else
1849 FOUND=false
1850 PARTITION_SOURCE_DIR=
1851 # Try Lineage target first.
1852 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
1853 PARTITION=$(echo "$CANDIDATE" | cut -d/ -f1)
1854 if [ "$PARTITION" = "system" ]; then
1855 PARTITION_SOURCE_DIR="$SYSTEM_SRC"
1856 elif [ "$PARTITION" = "vendor" ]; then
1857 PARTITION_SOURCE_DIR="$VENDOR_SRC"
1858 elif [ "$PARTITION" = "product" ]; then
1859 PARTITION_SOURCE_DIR="$PRODUCT_SRC"
1860 elif [ "$PARTITION" = "odm" ]; then
1861 PARTITION_SOURCE_DIR="$ODM_SRC"
1862 fi
1863 CANDIDATE_RELATIVE_NAME=$(echo "$CANDIDATE" | cut -d/ -f2-)
1864 get_file ${CANDIDATE_RELATIVE_NAME} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1865 FOUND=true
1866 break
1867 }
1868 # Search with the full system/ prefix if the file was not found on the system partition
1869 # because we may be searching in a mounted system-as-root system.img
1870 if [[ "${FOUND}" = false && "$PARTITION" = "system" ]]; then
1871 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1872 FOUND=true
1873 break
1874 }
1875 fi
1876 done
1877
1878 if [ -z "${PARTITION_SOURCE_DIR}" ]; then
1879 echo "$CANDIDATE has no preceeding partition path. Prepend system/, vendor/, product/, or odm/ to this entry."
1880 fi
1881
1882 if [ "${FOUND}" = false ]; then
1883 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
1884 continue
1885 fi
1886 fi
1887
1888 # Blob fixup pipeline has 2 parts: one that is fixed and
1889 # one that is user-configurable
1890 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1891 # Deodex apk|jar if that's the case
1892 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1893 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "${SYSTEM_SRC}"
1894 if [ -f "$TMPDIR/classes.dex" ]; then
1895 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1896 rm "$TMPDIR/classes"*
1897 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
1898 fi
1899 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1900 fix_xml "${VENDOR_REPO_FILE}"
1901 fi
1902 # Now run user-supplied fixup function
1903 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1904 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1905
1906 if [ -f "${VENDOR_REPO_FILE}" ]; then
1907 local DIR=$(dirname "${VENDOR_REPO_FILE}")
1908 local TYPE="${DIR##*/}"
1909 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
1910 chmod 755 "${VENDOR_REPO_FILE}"
1911 else
1912 chmod 644 "${VENDOR_REPO_FILE}"
1913 fi
1914 fi
1915
1916 if [ "${KANG}" = true ]; then
1917 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1918 fi
1919
1920 # Check and print whether the fixup pipeline actually did anything.
1921 # This isn't done right after the fixup pipeline because we want this print
1922 # to come after print_spec above, when in kang mode.
1923 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1924 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1925 # Now sanity-check the spec for this blob.
1926 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1927 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1928 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1929 fi
1930 fi
1931
1932 done
1933
1934 # Don't allow failing
1935 set -e
1936}
1937
1938#
Steve Kondik5bd66602016-07-15 10:39:58 -07001939# extract_firmware:
1940#
1941# $1: file containing the list of items to extract
1942# $2: path to extracted radio folder
1943#
1944function extract_firmware() {
1945 if [ -z "$OUTDIR" ]; then
1946 echo "Output dir not set!"
1947 exit 1
1948 fi
1949
1950 parse_file_list "$1"
1951
1952 # Don't allow failing
1953 set -e
1954
1955 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} )
1956 local COUNT=${#FILELIST[@]}
1957 local SRC="$2"
theimpulson9a911af2019-08-14 03:25:12 +00001958 local OUTPUT_DIR="$OMNI_ROOT"/"$OUTDIR"/radio
Steve Kondik5bd66602016-07-15 10:39:58 -07001959
1960 if [ "$VENDOR_RADIO_STATE" -eq "0" ]; then
1961 echo "Cleaning firmware output directory ($OUTPUT_DIR).."
1962 rm -rf "${OUTPUT_DIR:?}/"*
1963 VENDOR_RADIO_STATE=1
1964 fi
1965
1966 echo "Extracting $COUNT files in $1 from $SRC:"
1967
1968 for (( i=1; i<COUNT+1; i++ )); do
1969 local FILE="${FILELIST[$i-1]}"
1970 printf ' - %s \n' "/radio/$FILE"
1971
1972 if [ ! -d "$OUTPUT_DIR" ]; then
1973 mkdir -p "$OUTPUT_DIR"
1974 fi
1975 cp "$SRC/$FILE" "$OUTPUT_DIR/$FILE"
1976 chmod 644 "$OUTPUT_DIR/$FILE"
1977 done
1978}
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -07001979
1980function extract_img_data() {
1981 local image_file="$1"
1982 local out_dir="$2"
1983 local logFile="$TMPDIR/debugfs.log"
1984
1985 if [ ! -d "$out_dir" ]; then
1986 mkdir -p "$out_dir"
1987 fi
1988
1989 if [[ "$HOST_OS" == "Darwin" ]]; then
1990 debugfs -R "rdump / \"$out_dir\"" "$image_file" &> "$logFile" || {
1991 echo "[-] Failed to extract data from '$image_file'"
1992 abort 1
1993 }
1994 else
1995 debugfs -R 'ls -p' "$image_file" 2>/dev/null | cut -d '/' -f6 | while read -r entry
1996 do
1997 debugfs -R "rdump \"$entry\" \"$out_dir\"" "$image_file" >> "$logFile" 2>&1 || {
1998 echo "[-] Failed to extract data from '$image_file'"
1999 abort 1
2000 }
2001 done
2002 fi
2003
2004 local symlink_err="rdump: Attempt to read block from filesystem resulted in short read while reading symlink"
2005 if grep -Fq "$symlink_err" "$logFile"; then
2006 echo "[-] Symlinks have not been properly processed from $image_file"
2007 echo "[!] If you don't have a compatible debugfs version, modify 'execute-all.sh' to disable 'USE_DEBUGFS' flag"
2008 abort 1
2009 fi
2010}
2011
2012declare -ra VENDOR_SKIP_FILES=(
2013 "bin/toybox_vendor"
2014 "bin/toolbox"
2015 "bin/grep"
2016 "build.prop"
2017 "compatibility_matrix.xml"
2018 "default.prop"
2019 "etc/NOTICE.xml.gz"
2020 "etc/vintf/compatibility_matrix.xml"
2021 "etc/vintf/manifest.xml"
2022 "etc/wifi/wpa_supplicant.conf"
2023 "manifest.xml"
2024 "overlay/DisplayCutoutEmulationCorner/DisplayCutoutEmulationCornerOverlay.apk"
2025 "overlay/DisplayCutoutEmulationDouble/DisplayCutoutEmulationDoubleOverlay.apk"
2026 "overlay/DisplayCutoutEmulationTall/DisplayCutoutEmulationTallOverlay.apk"
2027 "overlay/DisplayCutoutNoCutout/NoCutoutOverlay.apk"
2028 "overlay/framework-res__auto_generated_rro.apk"
2029 "overlay/SysuiDarkTheme/SysuiDarkThemeOverlay.apk"
2030)
2031
2032function array_contains() {
2033 local element
2034 for element in "${@:2}"; do [[ "$element" == "$1" ]] && return 0; done
2035 return 1
2036}
2037
2038function generate_prop_list_from_image() {
2039 local image_file="$1"
2040 local image_dir="$TMPDIR/image-temp"
2041 local output_list="$2"
2042 local output_list_tmp="$TMPDIR/_proprietary-blobs.txt"
2043 local -n skipped_vendor_files="$3"
2044
2045 extract_img_data "$image_file" "$image_dir"
2046
2047 find "$image_dir" -not -type d | sed "s#^$image_dir/##" | while read -r FILE
2048 do
2049 # Skip VENDOR_SKIP_FILES since it will be re-generated at build time
2050 if array_contains "$FILE" "${VENDOR_SKIP_FILES[@]}"; then
2051 continue
2052 fi
2053 # Skip device defined skipped files since they will be re-generated at build time
2054 if array_contains "$FILE" "${skipped_vendor_files[@]}"; then
2055 continue
2056 fi
2057 if suffix_match_file ".apk" "$FILE" ; then
2058 echo "-vendor/$FILE" >> "$output_list_tmp"
2059 else
2060 echo "vendor/$FILE" >> "$output_list_tmp"
2061 fi
2062 done
2063
2064 # Sort merged file with all lists
2065 sort -u "$output_list_tmp" > "$output_list"
2066
2067 # Clean-up
2068 rm -f "$output_list_tmp"
2069}