blob: d70600bf1fac0d67ff0552ab30c9e84b8bfafbd5 [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"
286 elif prefix_match_file "odm/" $TARGET ; then
287 local OUTTARGET=$(truncate_file $TARGET)
288 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
289 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab06688fc2019-10-05 00:09:41 -0400290 elif prefix_match_file "vendor/odm/" $TARGET ; then
291 local OUTTARGET=$(truncate_file $TARGET)
292 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_ODM)/%s%s\n' \
293 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
294 elif prefix_match_file "system/vendor/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"
298 elif prefix_match_file "vendor/" $TARGET ; then
299 local OUTTARGET=$(truncate_file $TARGET)
300 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
301 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
302 elif prefix_match_file "system/vendor/" $TARGET ; then
303 local OUTTARGET=$(truncate_file $TARGET)
304 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_VENDOR)/%s%s\n' \
305 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400306 elif prefix_match_file "system/" $TARGET ; then
307 local OUTTARGET=$(truncate_file $TARGET)
308 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
309 "$OUTDIR" "$TARGET" "$OUTTARGET" "$LINEEND" >> "$PRODUCTMK"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400310 else
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400311 printf ' %s/proprietary/%s:$(TARGET_COPY_OUT_SYSTEM)/%s%s\n' \
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -0400312 "$OUTDIR" "$TARGET" "$TARGET" "$LINEEND" >> "$PRODUCTMK"
313 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700314 done
315 return 0
316}
317
318#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700319# write_blueprint_packages:
Steve Kondik5bd66602016-07-15 10:39:58 -0700320#
321# $1: The LOCAL_MODULE_CLASS for the given module list
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400322# $2: /system, /odm, /product, or /vendor partition
Steve Kondik5bd66602016-07-15 10:39:58 -0700323# $3: type-specific extra flags
324# $4: Name of the array holding the target list
325#
326# Internal function which writes out the BUILD_PREBUILT stanzas
327# for all modules in the list. This is called by write_product_packages
328# after the modules are categorized.
329#
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700330function write_blueprint_packages() {
331
332 local CLASS="$1"
333 local PARTITION="$2"
334 local EXTRA="$3"
335
336 # Yes, this is a horrible hack - we create a new array using indirection
337 local ARR_NAME="$4[@]"
338 local FILELIST=("${!ARR_NAME}")
339
340 local FILE=
341 local ARGS=
342 local BASENAME=
343 local EXTENSION=
344 local PKGNAME=
345 local SRC=
346
347 for P in "${FILELIST[@]}"; do
348 FILE=$(target_file "$P")
349 ARGS=$(target_args "$P")
350
351 BASENAME=$(basename "$FILE")
352 DIRNAME=$(dirname "$FILE")
353 EXTENSION=${BASENAME##*.}
354 PKGNAME=${BASENAME%.*}
355
356 # Add to final package list
357 PACKAGE_LIST+=("$PKGNAME")
358
359 SRC="proprietary"
360 if [ "$PARTITION" = "system" ]; then
361 SRC+="/system"
362 elif [ "$PARTITION" = "vendor" ]; then
363 SRC+="/vendor"
364 elif [ "$PARTITION" = "product" ]; then
365 SRC+="/product"
366 elif [ "$PARTITION" = "odm" ]; then
367 SRC+="/odm"
368 fi
369
370 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
371 printf 'cc_prebuilt_library_shared {\n'
372 printf '\tname: "%s",\n' "$PKGNAME"
373 printf '\towner: "%s",\n' "$VENDOR"
374 printf '\tstrip: {\n'
375 printf '\t\tnone: true,\n'
376 printf '\t},\n'
377 printf '\ttarget: {\n'
378 if [ "$EXTRA" = "both" ]; then
379 printf '\t\tandroid_arm: {\n'
380 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
381 printf '\t\t},\n'
382 printf '\t\tandroid_arm64: {\n'
383 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
384 printf '\t\t},\n'
385 elif [ "$EXTRA" = "64" ]; then
386 printf '\t\tandroid_arm64: {\n'
387 printf '\t\t\tsrcs: ["%s/lib64/%s"],\n' "$SRC" "$FILE"
388 printf '\t\t},\n'
389 else
390 printf '\t\tandroid_arm: {\n'
391 printf '\t\t\tsrcs: ["%s/lib/%s"],\n' "$SRC" "$FILE"
392 printf '\t\t},\n'
393 fi
394 printf '\t},\n'
395 if [ "$EXTRA" != "none" ]; then
396 printf '\tcompile_multilib: "%s",\n' "$EXTRA"
397 fi
dianlujitao848101c2020-09-12 00:15:13 +0800398 printf '\tcheck_elf_files: false,\n'
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700399 elif [ "$CLASS" = "APPS" ]; then
400 printf 'android_app_import {\n'
401 printf '\tname: "%s",\n' "$PKGNAME"
402 printf '\towner: "%s",\n' "$VENDOR"
403 if [ "$EXTRA" = "priv-app" ]; then
404 SRC="$SRC/priv-app"
405 else
406 SRC="$SRC/app"
407 fi
408 printf '\tapk: "%s/%s",\n' "$SRC" "$FILE"
409 if [ "$ARGS" = "PRESIGNED" ]; then
410 printf '\tpresigned: true,\n'
411 elif [ ! -z "$ARGS" ]; then
412 printf '\tcertificate: "%s",\n' "$ARGS"
413 else
414 printf '\tcertificate: "platform",\n'
415 fi
416 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
417 printf 'dex_import {\n'
418 printf '\tname: "%s",\n' "$PKGNAME"
419 printf '\towner: "%s",\n' "$VENDOR"
420 printf '\tjars: ["%s/framework/%s"],\n' "$SRC" "$FILE"
421 elif [ "$CLASS" = "ETC" ]; then
422 if [ "$EXTENSION" = "xml" ]; then
423 printf 'prebuilt_etc_xml {\n'
424 else
425 printf 'prebuilt_etc {\n'
426 fi
427 printf '\tname: "%s",\n' "$PKGNAME"
428 printf '\towner: "%s",\n' "$VENDOR"
429 printf '\tsrc: "%s/etc/%s",\n' "$SRC" "$FILE"
430 elif [ "$CLASS" = "EXECUTABLES" ]; then
431 if [ "$EXTENSION" = "sh" ]; then
432 printf 'sh_binary {\n'
433 else
434 printf 'cc_prebuilt_binary {\n'
435 fi
436 printf '\tname: "%s",\n' "$PKGNAME"
437 printf '\towner: "%s",\n' "$VENDOR"
438 if [ "$ARGS" = "rootfs" ]; then
439 SRC="$SRC/rootfs"
440 if [ "$EXTRA" = "sbin" ]; then
441 SRC="$SRC/sbin"
442 printf '\tdist {\n'
443 printf '\t\tdest: "%s",\n' "root/sbin"
444 printf '\t},'
445 fi
446 else
447 SRC="$SRC/bin"
448 fi
449 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
450 unset EXTENSION
451 else
452 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
453 fi
454 if [ "$CLASS" = "APPS" ]; then
455 printf '\tdex_preopt: {\n'
456 printf '\t\tenabled: false,\n'
457 printf '\t},\n'
458 fi
459 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] || [ "$CLASS" = "ETC" ] ; then
460 if [ "$DIRNAME" != "." ]; then
461 printf '\tsub_dir: "%s",\n' "$DIRNAME"
462 fi
463 fi
464 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
465 printf '\tprefer: true,\n'
466 fi
467 if [ "$EXTRA" = "priv-app" ]; then
468 printf '\tprivileged: true,\n'
469 fi
470 if [ "$PARTITION" = "vendor" ]; then
471 printf '\tsoc_specific: true,\n'
472 elif [ "$PARTITION" = "product" ]; then
473 printf '\tproduct_specific: true,\n'
474 elif [ "$PARTITION" = "odm" ]; then
475 printf '\tdevice_specific: true,\n'
476 fi
477 printf '}\n\n'
478 done
479}
480
481#
482# write_makefile_packages:
483#
484# $1: The LOCAL_MODULE_CLASS for the given module list
485# $2: /odm, /product, or /vendor partition
486# $3: type-specific extra flags
487# $4: Name of the array holding the target list
488#
489# Internal function which writes out the BUILD_PREBUILT stanzas
490# for all modules in the list. This is called by write_product_packages
491# after the modules are categorized.
492#
493function write_makefile_packages() {
Steve Kondik5bd66602016-07-15 10:39:58 -0700494
495 local CLASS="$1"
razorlovesa0d296b2019-07-29 02:21:34 -0500496 local PARTITION="$2"
Steve Kondik5bd66602016-07-15 10:39:58 -0700497 local EXTRA="$3"
498
499 # Yes, this is a horrible hack - we create a new array using indirection
500 local ARR_NAME="$4[@]"
501 local FILELIST=("${!ARR_NAME}")
502
503 local FILE=
504 local ARGS=
505 local BASENAME=
506 local EXTENSION=
507 local PKGNAME=
508 local SRC=
509
510 for P in "${FILELIST[@]}"; do
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300511 FILE=$(target_file "$P")
Steve Kondik5bd66602016-07-15 10:39:58 -0700512 ARGS=$(target_args "$P")
513
514 BASENAME=$(basename "$FILE")
M1cha3e8c5bf2017-01-04 09:00:11 +0100515 DIRNAME=$(dirname "$FILE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700516 EXTENSION=${BASENAME##*.}
Mohd Farazcb0f4872019-10-08 16:13:50 +0530517 EXTENSION="."$EXTENSION
518 if [ "$EXTENSION" = ".jar" ]; then
519 EXTENSION="\$(COMMON_JAVA_PACKAGE_SUFFIX)"
520 elif [ "$EXTENSION" = ".apk" ]; then
521 EXTENSION="\$(COMMON_ANDROID_PACKAGE_SUFFIX)"
522 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700523 PKGNAME=${BASENAME%.*}
524
525 # Add to final package list
526 PACKAGE_LIST+=("$PKGNAME")
527
528 SRC="proprietary"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400529 if [ "$PARTITION" = "system" ]; then
530 SRC+="/system"
531 elif [ "$PARTITION" = "vendor" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -0700532 SRC+="/vendor"
razorlovesa0d296b2019-07-29 02:21:34 -0500533 elif [ "$PARTITION" = "product" ]; then
534 SRC+="/product"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700535 elif [ "$PARTITION" = "odm" ]; then
536 SRC+="/odm"
Steve Kondik5bd66602016-07-15 10:39:58 -0700537 fi
538
539 printf 'include $(CLEAR_VARS)\n'
540 printf 'LOCAL_MODULE := %s\n' "$PKGNAME"
541 printf 'LOCAL_MODULE_OWNER := %s\n' "$VENDOR"
542 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
543 if [ "$EXTRA" = "both" ]; then
544 printf 'LOCAL_SRC_FILES_64 := %s/lib64/%s\n' "$SRC" "$FILE"
545 printf 'LOCAL_SRC_FILES_32 := %s/lib/%s\n' "$SRC" "$FILE"
546 #if [ "$VENDOR_PKG" = "true" ]; then
547 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
548 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
549 #else
550 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_SHARED_LIBRARIES)"
551 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_SHARED_LIBRARIES)"
552 #fi
553 elif [ "$EXTRA" = "64" ]; then
554 printf 'LOCAL_SRC_FILES := %s/lib64/%s\n' "$SRC" "$FILE"
555 else
556 printf 'LOCAL_SRC_FILES := %s/lib/%s\n' "$SRC" "$FILE"
557 fi
558 if [ "$EXTRA" != "none" ]; then
559 printf 'LOCAL_MULTILIB := %s\n' "$EXTRA"
560 fi
561 elif [ "$CLASS" = "APPS" ]; then
Michael Bestas9c6f2eb2018-01-25 21:05:36 +0200562 if [ "$EXTRA" = "priv-app" ]; then
563 SRC="$SRC/priv-app"
564 else
565 SRC="$SRC/app"
Steve Kondik5bd66602016-07-15 10:39:58 -0700566 fi
567 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
568 local CERT=platform
569 if [ ! -z "$ARGS" ]; then
570 CERT="$ARGS"
571 fi
572 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
573 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
574 printf 'LOCAL_SRC_FILES := %s/framework/%s\n' "$SRC" "$FILE"
Elektroschmockdd792302016-10-04 21:11:43 +0200575 local CERT=platform
576 if [ ! -z "$ARGS" ]; then
577 CERT="$ARGS"
578 fi
579 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
Steve Kondik5bd66602016-07-15 10:39:58 -0700580 elif [ "$CLASS" = "ETC" ]; then
581 printf 'LOCAL_SRC_FILES := %s/etc/%s\n' "$SRC" "$FILE"
582 elif [ "$CLASS" = "EXECUTABLES" ]; then
583 if [ "$ARGS" = "rootfs" ]; then
584 SRC="$SRC/rootfs"
585 if [ "$EXTRA" = "sbin" ]; then
586 SRC="$SRC/sbin"
587 printf '%s\n' "LOCAL_MODULE_PATH := \$(TARGET_ROOT_OUT_SBIN)"
588 printf '%s\n' "LOCAL_UNSTRIPPED_PATH := \$(TARGET_ROOT_OUT_SBIN_UNSTRIPPED)"
589 fi
590 else
591 SRC="$SRC/bin"
592 fi
593 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
594 unset EXTENSION
595 else
596 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
597 fi
598 printf 'LOCAL_MODULE_TAGS := optional\n'
599 printf 'LOCAL_MODULE_CLASS := %s\n' "$CLASS"
Hashbang173575f3bb2016-08-28 20:38:45 -0400600 if [ "$CLASS" = "APPS" ]; then
601 printf 'LOCAL_DEX_PREOPT := false\n'
602 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700603 if [ ! -z "$EXTENSION" ]; then
Mohd Farazcb0f4872019-10-08 16:13:50 +0530604 printf 'LOCAL_MODULE_SUFFIX := %s\n' "$EXTENSION"
Steve Kondik5bd66602016-07-15 10:39:58 -0700605 fi
M1cha3e8c5bf2017-01-04 09:00:11 +0100606 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ]; then
607 if [ "$DIRNAME" != "." ]; then
608 printf 'LOCAL_MODULE_RELATIVE_PATH := %s\n' "$DIRNAME"
609 fi
610 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700611 if [ "$EXTRA" = "priv-app" ]; then
612 printf 'LOCAL_PRIVILEGED_MODULE := true\n'
613 fi
razorlovesa0d296b2019-07-29 02:21:34 -0500614 if [ "$PARTITION" = "vendor" ]; then
Ethan Chen4f738f52018-02-17 20:03:54 -0800615 printf 'LOCAL_VENDOR_MODULE := true\n'
razorlovesa0d296b2019-07-29 02:21:34 -0500616 elif [ "$PARTITION" = "product" ]; then
617 printf 'LOCAL_PRODUCT_MODULE := true\n'
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700618 elif [ "$PARTITION" = "odm" ]; then
619 printf 'LOCAL_ODM_MODULE := true\n'
Steve Kondik5bd66602016-07-15 10:39:58 -0700620 fi
621 printf 'include $(BUILD_PREBUILT)\n\n'
622 done
623}
624
625#
626# write_product_packages:
627#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700628# This function will create prebuilt entries in the
629# Android.bp and associated PRODUCT_PACKAGES list in the
Steve Kondik5bd66602016-07-15 10:39:58 -0700630# product makefile for all files in the blob list which
631# start with a single dash (-) character.
632#
633function write_product_packages() {
634 PACKAGE_LIST=()
635
636 local COUNT=${#PRODUCT_PACKAGES_LIST[@]}
637
638 if [ "$COUNT" = "0" ]; then
639 return 0
640 fi
641
642 # Figure out what's 32-bit, what's 64-bit, and what's multilib
643 # I really should not be doing this in bash due to shitty array passing :(
644 local T_LIB32=( $(prefix_match "lib/") )
645 local T_LIB64=( $(prefix_match "lib64/") )
646 local MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${T_LIB64[@]}")) )
647 local LIB32=( $(comm -23 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
648 local LIB64=( $(comm -23 <(printf '%s\n' "${T_LIB64[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
649
650 if [ "${#MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700651 write_blueprint_packages "SHARED_LIBRARIES" "" "both" "MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700652 fi
653 if [ "${#LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700654 write_blueprint_packages "SHARED_LIBRARIES" "" "32" "LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700655 fi
656 if [ "${#LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700657 write_blueprint_packages "SHARED_LIBRARIES" "" "64" "LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700658 fi
659
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400660 local T_S_LIB32=( $(prefix_match "system/lib/") )
661 local T_S_LIB64=( $(prefix_match "system/lib64/") )
662 local S_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${T_S_LIB64[@]}")) )
663 local S_LIB32=( $(comm -23 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
664 local S_LIB64=( $(comm -23 <(printf '%s\n' "${T_S_LIB64[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
665
666 if [ "${#S_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700667 write_blueprint_packages "SHARED_LIBRARIES" "system" "both" "S_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400668 fi
669 if [ "${#S_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700670 write_blueprint_packages "SHARED_LIBRARIES" "system" "32" "S_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400671 fi
672 if [ "${#S_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700673 write_blueprint_packages "SHARED_LIBRARIES" "system" "64" "S_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400674 fi
675
Steve Kondik5bd66602016-07-15 10:39:58 -0700676 local T_V_LIB32=( $(prefix_match "vendor/lib/") )
677 local T_V_LIB64=( $(prefix_match "vendor/lib64/") )
678 local V_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${T_V_LIB64[@]}")) )
679 local V_LIB32=( $(comm -23 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
680 local V_LIB64=( $(comm -23 <(printf '%s\n' "${T_V_LIB64[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
681
682 if [ "${#V_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700683 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "both" "V_MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700684 fi
685 if [ "${#V_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700686 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "32" "V_LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700687 fi
688 if [ "${#V_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700689 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "64" "V_LIB64" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500690 fi
691
692 local T_P_LIB32=( $(prefix_match "product/lib/") )
693 local T_P_LIB64=( $(prefix_match "product/lib64/") )
694 local P_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${T_P_LIB64[@]}")) )
695 local P_LIB32=( $(comm -23 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
696 local P_LIB64=( $(comm -23 <(printf '%s\n' "${T_P_LIB64[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
697
698 if [ "${#P_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700699 write_blueprint_packages "SHARED_LIBRARIES" "product" "both" "P_MULTILIBS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500700 fi
701 if [ "${#P_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700702 write_blueprint_packages "SHARED_LIBRARIES" "product" "32" "P_LIB32" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500703 fi
704 if [ "${#P_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700705 write_blueprint_packages "SHARED_LIBRARIES" "product" "64" "P_LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700706 fi
707
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700708 local T_O_LIB32=( $(prefix_match "odm/lib/") )
709 local T_O_LIB64=( $(prefix_match "odm/lib64/") )
710 local O_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${T_O_LIB64[@]}")) )
711 local O_LIB32=( $(comm -23 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
712 local O_LIB64=( $(comm -23 <(printf '%s\n' "${T_O_LIB64[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
713
714 if [ "${#O_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700715 write_blueprint_packages "SHARED_LIBRARIES" "odm" "both" "O_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700716 fi
717 if [ "${#O_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700718 write_blueprint_packages "SHARED_LIBRARIES" "odm" "32" "O_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700719 fi
720 if [ "${#O_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700721 write_blueprint_packages "SHARED_LIBRARIES" "odm" "64" "O_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700722 fi
723
Steve Kondik5bd66602016-07-15 10:39:58 -0700724 # Apps
725 local APPS=( $(prefix_match "app/") )
726 if [ "${#APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100727 write_blueprint_packages "APPS" "" "" "APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700728 fi
729 local PRIV_APPS=( $(prefix_match "priv-app/") )
730 if [ "${#PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100731 write_blueprint_packages "APPS" "" "priv-app" "PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700732 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400733 local S_APPS=( $(prefix_match "system/app/") )
734 if [ "${#S_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100735 write_blueprint_packages "APPS" "system" "" "S_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400736 fi
737 local S_PRIV_APPS=( $(prefix_match "system/priv-app/") )
738 if [ "${#S_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100739 write_blueprint_packages "APPS" "system" "priv-app" "S_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400740 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700741 local V_APPS=( $(prefix_match "vendor/app/") )
742 if [ "${#V_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100743 write_blueprint_packages "APPS" "vendor" "" "V_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700744 fi
745 local V_PRIV_APPS=( $(prefix_match "vendor/priv-app/") )
746 if [ "${#V_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100747 write_blueprint_packages "APPS" "vendor" "priv-app" "V_PRIV_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500748 fi
749 local P_APPS=( $(prefix_match "product/app/") )
750 if [ "${#P_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100751 write_blueprint_packages "APPS" "product" "" "P_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500752 fi
753 local P_PRIV_APPS=( $(prefix_match "product/priv-app/") )
754 if [ "${#P_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100755 write_blueprint_packages "APPS" "product" "priv-app" "P_PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700756 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700757 local O_APPS=( $(prefix_match "odm/app/") )
758 if [ "${#O_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100759 write_blueprint_packages "APPS" "odm" "" "O_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700760 fi
761 local O_PRIV_APPS=( $(prefix_match "odm/priv-app/") )
762 if [ "${#O_PRIV_APPS[@]}" -gt "0" ]; then
mickael saibi64b0b752019-11-17 18:35:05 +0100763 write_blueprint_packages "APPS" "odm" "priv-app" "O_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700764 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700765
766 # Framework
767 local FRAMEWORK=( $(prefix_match "framework/") )
768 if [ "${#FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700769 write_blueprint_packages "JAVA_LIBRARIES" "" "" "FRAMEWORK" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700770 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400771 local S_FRAMEWORK=( $(prefix_match "system/framework/") )
772 if [ "${#S_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700773 write_blueprint_packages "JAVA_LIBRARIES" "system" "" "S_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400774 fi
Christian Oder974b5902017-10-08 23:15:52 +0200775 local V_FRAMEWORK=( $(prefix_match "vendor/framework/") )
Michael Bestas26eb01e2018-02-27 22:31:55 +0200776 if [ "${#V_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700777 write_blueprint_packages "JAVA_LIBRARIES" "vendor" "" "V_FRAMEWORK" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500778 fi
779 local P_FRAMEWORK=( $(prefix_match "product/framework/") )
780 if [ "${#P_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700781 write_blueprint_packages "JAVA_LIBRARIES" "product" "" "P_FRAMEWORK" >> "$ANDROIDBP"
Christian Oder974b5902017-10-08 23:15:52 +0200782 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700783 local O_FRAMEWORK=( $(prefix_match "odm/framework/") )
784 if [ "${#O_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700785 write_blueprint_packages "JAVA_LIBRARIES" "odm" "" "O_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700786 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700787
788 # Etc
789 local ETC=( $(prefix_match "etc/") )
790 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700791 write_blueprint_packages "ETC" "" "" "ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700792 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400793 local S_ETC=( $(prefix_match "system/etc/") )
794 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700795 write_blueprint_packages "ETC" "system" "" "S_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400796 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700797 local V_ETC=( $(prefix_match "vendor/etc/") )
798 if [ "${#V_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700799 write_blueprint_packages "ETC" "vendor" "" "V_ETC" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500800 fi
801 local P_ETC=( $(prefix_match "product/etc/") )
802 if [ "${#P_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700803 write_blueprint_packages "ETC" "product" "" "P_ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700804 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700805 local O_ETC=( $(prefix_match "odm/etc/") )
806 if [ "${#O_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700807 write_blueprint_packages "ETC" "odm" "" "O_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700808 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700809
810 # Executables
811 local BIN=( $(prefix_match "bin/") )
812 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700813 write_blueprint_packages "EXECUTABLES" "" "" "BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700814 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400815 local S_BIN=( $(prefix_match "system/bin/") )
816 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700817 write_blueprint_packages "EXECUTABLES" "system" "" "S_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400818 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700819 local V_BIN=( $(prefix_match "vendor/bin/") )
820 if [ "${#V_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700821 write_blueprint_packages "EXECUTABLES" "vendor" "" "V_BIN" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500822 fi
823 local P_BIN=( $(prefix_match "product/bin/") )
824 if [ "${#P_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700825 write_blueprint_packages "EXECUTABLES" "product" "" "P_BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700826 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700827 local O_BIN=( $(prefix_match "odm/bin/") )
828 if [ "${#O_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700829 write_blueprint_packages "EXECUTABLES" "odm" "" "O_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700830 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700831 local SBIN=( $(prefix_match "sbin/") )
832 if [ "${#SBIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700833 write_makefile_packages "EXECUTABLES" "" "sbin" "SBIN" >> "$ANDROIDMK"
Steve Kondik5bd66602016-07-15 10:39:58 -0700834 fi
835
836
837 # Actually write out the final PRODUCT_PACKAGES list
838 local PACKAGE_COUNT=${#PACKAGE_LIST[@]}
839
840 if [ "$PACKAGE_COUNT" -eq "0" ]; then
841 return 0
842 fi
843
844 printf '\n%s\n' "PRODUCT_PACKAGES += \\" >> "$PRODUCTMK"
845 for (( i=1; i<PACKAGE_COUNT+1; i++ )); do
846 local LINEEND=" \\"
847 if [ "$i" -eq "$PACKAGE_COUNT" ]; then
848 LINEEND=""
849 fi
850 printf ' %s%s\n' "${PACKAGE_LIST[$i-1]}" "$LINEEND" >> "$PRODUCTMK"
851 done
852}
853
854#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700855# write_blueprint_header:
Steve Kondik5bd66602016-07-15 10:39:58 -0700856#
857# $1: file which will be written to
858#
859# writes out the copyright header with the current year.
860# note that this is not an append operation, and should
861# be executed first!
862#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700863function write_blueprint_header() {
864 if [ -f $1 ]; then
865 rm $1
866 fi
867
868 YEAR=$(date +"%Y")
869
870 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
871
872 printf "/**\n" > $1
873 NUM_REGEX='^[0-9]+$'
874 if [[ ! $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] || [ $INITIAL_COPYRIGHT_YEAR -lt 2019 ]; then
875 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=2019
876 else
877 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=$INITIAL_COPYRIGHT_YEAR
878 fi
879
880 if [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
881 printf " * Copyright (C) $YEAR The LineageOS Project\n" >> $1
882 elif [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -le 2019 ]; then
883 printf " * Copyright (C) 2019-$YEAR The LineageOS Project\n" >> $1
884 else
885 printf " * Copyright (C) $BLUEPRINT_INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
886 fi
887
888 cat << EOF >> $1
889 *
890 * Licensed under the Apache License, Version 2.0 (the "License");
891 * you may not use this file except in compliance with the License.
892 * You may obtain a copy of the License at
893 *
894 * http://www.apache.org/licenses/LICENSE-2.0
895 *
896 * Unless required by applicable law or agreed to in writing, software
897 * distributed under the License is distributed on an "AS IS" BASIS,
898 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
899 * See the License for the specific language governing permissions and
900 * limitations under the License.
901 *
902 * This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
903 */
904
905EOF
906}
907
908#
909# write_makefile_header:
910#
911# $1: file which will be written to
912#
913# writes out the copyright header with the current year.
914# note that this is not an append operation, and should
915# be executed first!
916#
917function write_makefile_header() {
Jake Whatley9843b322017-01-25 21:49:16 -0500918 if [ -f $1 ]; then
919 rm $1
920 fi
921
Steve Kondik5bd66602016-07-15 10:39:58 -0700922 YEAR=$(date +"%Y")
923
924 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
925
Jake Whatley9843b322017-01-25 21:49:16 -0500926 NUM_REGEX='^[0-9]+$'
927 if [[ $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] && [ $INITIAL_COPYRIGHT_YEAR -le $YEAR ]; then
928 if [ $INITIAL_COPYRIGHT_YEAR -lt 2016 ]; then
929 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-2016 The CyanogenMod Project\n" > $1
930 elif [ $INITIAL_COPYRIGHT_YEAR -eq 2016 ]; then
931 printf "# Copyright (C) 2016 The CyanogenMod Project\n" > $1
932 fi
933 if [ $YEAR -eq 2017 ]; then
934 printf "# Copyright (C) 2017 The LineageOS Project\n" >> $1
935 elif [ $INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
936 printf "# Copyright (C) $YEAR The LineageOS Project\n" >> $1
937 elif [ $INITIAL_COPYRIGHT_YEAR -le 2017 ]; then
938 printf "# Copyright (C) 2017-$YEAR The LineageOS Project\n" >> $1
939 else
940 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
941 fi
942 else
943 printf "# Copyright (C) $YEAR The LineageOS Project\n" > $1
944 fi
945
946 cat << EOF >> $1
Steve Kondik5bd66602016-07-15 10:39:58 -0700947#
948# Licensed under the Apache License, Version 2.0 (the "License");
949# you may not use this file except in compliance with the License.
950# You may obtain a copy of the License at
951#
952# http://www.apache.org/licenses/LICENSE-2.0
953#
954# Unless required by applicable law or agreed to in writing, software
955# distributed under the License is distributed on an "AS IS" BASIS,
956# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
957# See the License for the specific language governing permissions and
958# limitations under the License.
959
960# This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
961
962EOF
963}
964
965#
966# write_headers:
967#
968# $1: devices falling under common to be added to guard - optional
Jake Whatley9843b322017-01-25 21:49:16 -0500969# $2: custom guard - optional
Steve Kondik5bd66602016-07-15 10:39:58 -0700970#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700971# Calls write_makefile_header for each of the makefiles and
972# write_blueprint_header for Android.bp and creates the initial
973# path declaration and device guard for the Android.mk
Steve Kondik5bd66602016-07-15 10:39:58 -0700974#
975function write_headers() {
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700976 write_makefile_header "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500977
978 GUARD="$2"
979 if [ -z "$GUARD" ]; then
980 GUARD="TARGET_DEVICE"
981 fi
982
Steve Kondik5bd66602016-07-15 10:39:58 -0700983 cat << EOF >> "$ANDROIDMK"
984LOCAL_PATH := \$(call my-dir)
985
986EOF
987 if [ "$COMMON" -ne 1 ]; then
988 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500989ifeq (\$($GUARD),$DEVICE)
Steve Kondik5bd66602016-07-15 10:39:58 -0700990
991EOF
992 else
993 if [ -z "$1" ]; then
994 echo "Argument with devices to be added to guard must be set!"
995 exit 1
996 fi
997 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500998ifneq (\$(filter $1,\$($GUARD)),)
Steve Kondik5bd66602016-07-15 10:39:58 -0700999
1000EOF
1001 fi
1002
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001003 write_makefile_header "$BOARDMK"
1004 write_makefile_header "$PRODUCTMK"
1005 write_blueprint_header "$ANDROIDBP"
1006
1007 cat << EOF >> "$ANDROIDBP"
1008soong_namespace {
1009}
1010
1011EOF
1012
1013 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
1014 cat << EOF >> "$PRODUCTMK"
1015PRODUCT_SOONG_NAMESPACES += \\
1016 vendor/$VENDOR/$DEVICE
1017
1018EOF
Steve Kondik5bd66602016-07-15 10:39:58 -07001019}
1020
1021#
1022# write_footers:
1023#
1024# Closes the inital guard and any other finalization tasks. Must
1025# be called as the final step.
1026#
1027function write_footers() {
1028 cat << EOF >> "$ANDROIDMK"
1029endif
1030EOF
1031}
1032
1033# Return success if adb is up and not in recovery
1034function _adb_connected {
1035 {
Jake Whatley9843b322017-01-25 21:49:16 -05001036 if [[ "$(adb get-state)" == device ]]
Steve Kondik5bd66602016-07-15 10:39:58 -07001037 then
1038 return 0
1039 fi
1040 } 2>/dev/null
1041
1042 return 1
1043};
1044
1045#
1046# parse_file_list:
1047#
1048# $1: input file
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001049# $2: blob section in file - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001050#
1051# Sets PRODUCT_PACKAGES and PRODUCT_COPY_FILES while parsing the input file
1052#
1053function parse_file_list() {
1054 if [ -z "$1" ]; then
1055 echo "An input file is expected!"
1056 exit 1
1057 elif [ ! -f "$1" ]; then
1058 echo "Input file "$1" does not exist!"
1059 exit 1
1060 fi
1061
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001062 if [ -n "$2" ]; then
1063 echo "Using section \"$2\""
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001064 LIST=$TMPDIR/files.txt
Vladimir Olteanfa79f212019-01-19 00:44:07 +02001065 # Match all lines starting with first line found to start* with '#'
1066 # comment and contain** $2, and ending with first line to be empty*.
1067 # *whitespaces (tabs, spaces) at the beginning of lines are discarded
1068 # **the $2 match is case-insensitive
1069 cat $1 | sed -n '/^[[:space:]]*#.*'"$2"'/I,/^[[:space:]]*$/ p' > $LIST
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001070 else
1071 LIST=$1
1072 fi
1073
1074
Steve Kondik5bd66602016-07-15 10:39:58 -07001075 PRODUCT_PACKAGES_LIST=()
1076 PRODUCT_PACKAGES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001077 PRODUCT_PACKAGES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001078 PRODUCT_COPY_FILES_LIST=()
1079 PRODUCT_COPY_FILES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001080 PRODUCT_COPY_FILES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001081
1082 while read -r line; do
1083 if [ -z "$line" ]; then continue; fi
1084
1085 # If the line has a pipe delimiter, a sha1 hash should follow.
1086 # This indicates the file should be pinned and not overwritten
1087 # when extracting files.
1088 local SPLIT=(${line//\|/ })
1089 local COUNT=${#SPLIT[@]}
1090 local SPEC=${SPLIT[0]}
1091 local HASH="x"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001092 local FIXUP_HASH="x"
Steve Kondik5bd66602016-07-15 10:39:58 -07001093 if [ "$COUNT" -gt "1" ]; then
1094 HASH=${SPLIT[1]}
1095 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001096 if [ "$COUNT" -gt "2" ]; then
1097 FIXUP_HASH=${SPLIT[2]}
1098 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001099
1100 # if line starts with a dash, it needs to be packaged
1101 if [[ "$SPEC" =~ ^- ]]; then
1102 PRODUCT_PACKAGES_LIST+=("${SPEC#-}")
1103 PRODUCT_PACKAGES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001104 PRODUCT_PACKAGES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001105 else
1106 PRODUCT_COPY_FILES_LIST+=("$SPEC")
1107 PRODUCT_COPY_FILES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001108 PRODUCT_COPY_FILES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001109 fi
1110
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001111 done < <(egrep -v '(^#|^[[:space:]]*$)' "$LIST" | LC_ALL=C sort | uniq)
Steve Kondik5bd66602016-07-15 10:39:58 -07001112}
1113
1114#
1115# write_makefiles:
1116#
1117# $1: file containing the list of items to extract
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001118# $2: make treble compatible makefile - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001119#
1120# Calls write_product_copy_files and write_product_packages on
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001121# the given file and appends to the Android.bp as well as
Steve Kondik5bd66602016-07-15 10:39:58 -07001122# the product makefile.
1123#
1124function write_makefiles() {
1125 parse_file_list "$1"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001126 write_product_copy_files "$2"
Steve Kondik5bd66602016-07-15 10:39:58 -07001127 write_product_packages
1128}
1129
1130#
1131# append_firmware_calls_to_makefiles:
1132#
1133# Appends to Android.mk the calls to all images present in radio folder
1134# (filesmap file used by releasetools to map firmware images should be kept in the device tree)
1135#
1136function append_firmware_calls_to_makefiles() {
1137 cat << EOF >> "$ANDROIDMK"
1138ifeq (\$(LOCAL_PATH)/radio, \$(wildcard \$(LOCAL_PATH)/radio))
1139
1140RADIO_FILES := \$(wildcard \$(LOCAL_PATH)/radio/*)
1141\$(foreach f, \$(notdir \$(RADIO_FILES)), \\
1142 \$(call add-radio-file,radio/\$(f)))
1143\$(call add-radio-file,../../../device/$VENDOR/$DEVICE/radio/filesmap)
1144
1145endif
1146
1147EOF
1148}
1149
1150#
1151# get_file:
1152#
1153# $1: input file
1154# $2: target file/folder
1155# $3: source of the file (can be "adb" or a local folder)
1156#
1157# Silently extracts the input file to defined target
1158# Returns success if file can be pulled from the device or found locally
1159#
1160function get_file() {
1161 local SRC="$3"
1162
1163 if [ "$SRC" = "adb" ]; then
1164 # try to pull
1165 adb pull "$1" "$2" >/dev/null 2>&1 && return 0
1166
1167 return 1
1168 else
1169 # try to copy
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001170 cp -r "$SRC/$1" "$2" 2>/dev/null && return 0
1171 cp -r "$SRC/${1#/system}" "$2" 2>/dev/null && return 0
Vladimir Oltean6780da32019-01-06 19:38:31 +02001172 cp -r "$SRC/system/$1" "$2" 2>/dev/null && return 0
Steve Kondik5bd66602016-07-15 10:39:58 -07001173
1174 return 1
1175 fi
1176};
1177
1178#
1179# oat2dex:
1180#
1181# $1: extracted apk|jar (to check if deodex is required)
1182# $2: odexed apk|jar to deodex
1183# $3: source of the odexed apk|jar
1184#
1185# Convert apk|jar .odex in the corresposing classes.dex
1186#
1187function oat2dex() {
theimpulson9a911af2019-08-14 03:25:12 +00001188 local OMNI_TARGET="$1"
Steve Kondik5bd66602016-07-15 10:39:58 -07001189 local OEM_TARGET="$2"
1190 local SRC="$3"
1191 local TARGET=
Joe Maplesfb3941c2018-01-05 14:51:33 -05001192 local OAT=
XiNGRZd7793bc2019-12-24 10:37:13 +08001193 local HOST="$(uname | tr '[:upper:]' '[:lower:]')"
Steve Kondik5bd66602016-07-15 10:39:58 -07001194
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001195 if [ -z "$BAKSMALIJAR" ] || [ -z "$SMALIJAR" ]; then
1196 export BAKSMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/baksmali.jar
1197 export SMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/smali.jar
Steve Kondik5bd66602016-07-15 10:39:58 -07001198 fi
1199
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001200 if [ -z "$VDEXEXTRACTOR" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001201 export VDEXEXTRACTOR="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/vdexExtractor
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001202 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001203
codeworkx85eda752018-09-23 12:36:57 +02001204 if [ -z "$CDEXCONVERTER" ]; then
Han Wang7a0b0bd2020-03-10 09:40:47 +02001205 export CDEXCONVERTER="$OMNI_ROOT"/vendor/omni/build/tools/${HOST}/compact_dex_converter
codeworkx85eda752018-09-23 12:36:57 +02001206 fi
1207
Steve Kondik5bd66602016-07-15 10:39:58 -07001208 # Extract existing boot.oats to the temp folder
1209 if [ -z "$ARCHES" ]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001210 echo "Checking if system is odexed and locating boot.oats..."
Steve Kondik5bd66602016-07-15 10:39:58 -07001211 for ARCH in "arm64" "arm" "x86_64" "x86"; do
Jake Whatley9843b322017-01-25 21:49:16 -05001212 mkdir -p "$TMPDIR/system/framework/$ARCH"
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001213 if get_file "/system/framework/$ARCH" "$TMPDIR/system/framework/" "$SRC"; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001214 ARCHES+="$ARCH "
Jake Whatley9843b322017-01-25 21:49:16 -05001215 else
1216 rmdir "$TMPDIR/system/framework/$ARCH"
Steve Kondik5bd66602016-07-15 10:39:58 -07001217 fi
1218 done
1219 fi
1220
1221 if [ -z "$ARCHES" ]; then
1222 FULLY_DEODEXED=1 && return 0 # system is fully deodexed, return
1223 fi
1224
theimpulson9a911af2019-08-14 03:25:12 +00001225 if [ ! -f "$OMNI_TARGET" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001226 return;
1227 fi
1228
theimpulson9a911af2019-08-14 03:25:12 +00001229 if grep "classes.dex" "$OMNI_TARGET" >/dev/null; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001230 return 0 # target apk|jar is already odexed, return
1231 fi
1232
1233 for ARCH in $ARCHES; do
Jake Whatley9843b322017-01-25 21:49:16 -05001234 BOOTOAT="$TMPDIR/system/framework/$ARCH/boot.oat"
Steve Kondik5bd66602016-07-15 10:39:58 -07001235
Joe Maplesfb3941c2018-01-05 14:51:33 -05001236 local OAT="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").odex"
1237 local VDEX="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").vdex"
Steve Kondik5bd66602016-07-15 10:39:58 -07001238
Joe Maplesfb3941c2018-01-05 14:51:33 -05001239 if get_file "$OAT" "$TMPDIR" "$SRC"; then
1240 if get_file "$VDEX" "$TMPDIR" "$SRC"; then
1241 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$VDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001242 CLASSES=$(ls "$TMPDIR/$(basename "${OEM_TARGET%.*}")_classes"*)
1243 for CLASS in $CLASSES; do
1244 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1245 # Check if we have to deal with CompactDex
1246 if [[ "$CLASS" == *.cdex ]]; then
1247 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1248 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1249 else
1250 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1251 fi
1252 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001253 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001254 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$TMPDIR/$(basename "$OAT")"
1255 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001256 fi
theimpulson9a911af2019-08-14 03:25:12 +00001257 elif [[ "$OMNI_TARGET" =~ .jar$ ]]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001258 JAROAT="$TMPDIR/system/framework/$ARCH/boot-$(basename ${OEM_TARGET%.*}).oat"
Luca Stefani082f1e82018-10-07 12:44:53 +02001259 JARVDEX="/system/framework/boot-$(basename ${OEM_TARGET%.*}).vdex"
Jake Whatley9843b322017-01-25 21:49:16 -05001260 if [ ! -f "$JAROAT" ]; then
Luca Stefani082f1e82018-10-07 12:44:53 +02001261 JAROAT=$BOOTOAT
Jake Whatley9843b322017-01-25 21:49:16 -05001262 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001263 # try to extract classes.dex from boot.vdex for frameworks jars
1264 # fallback to boot.oat if vdex is not available
Luca Stefani082f1e82018-10-07 12:44:53 +02001265 if get_file "$JARVDEX" "$TMPDIR" "$SRC"; then
Luca Stefani6f92e6b2018-10-31 19:16:05 +01001266 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$JARVDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001267 CLASSES=$(ls "$TMPDIR/$(basename "${JARVDEX%.*}")_classes"*)
1268 for CLASS in $CLASSES; do
1269 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1270 # Check if we have to deal with CompactDex
1271 if [[ "$CLASS" == *.cdex ]]; then
1272 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1273 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1274 else
1275 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1276 fi
1277 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001278 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001279 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$JAROAT/$OEM_TARGET"
1280 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001281 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001282 else
1283 continue
1284 fi
1285
Steve Kondik5bd66602016-07-15 10:39:58 -07001286 done
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001287
1288 rm -rf "$TMPDIR/dexout"
Steve Kondik5bd66602016-07-15 10:39:58 -07001289}
1290
1291#
1292# init_adb_connection:
1293#
1294# Starts adb server and waits for the device
1295#
1296function init_adb_connection() {
1297 adb start-server # Prevent unexpected starting server message from adb get-state in the next line
1298 if ! _adb_connected; then
1299 echo "No device is online. Waiting for one..."
1300 echo "Please connect USB and/or enable USB debugging"
1301 until _adb_connected; do
1302 sleep 1
1303 done
1304 echo "Device Found."
1305 fi
1306
1307 # Retrieve IP and PORT info if we're using a TCP connection
1308 TCPIPPORT=$(adb devices | egrep '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+[^0-9]+' \
1309 | head -1 | awk '{print $1}')
1310 adb root &> /dev/null
1311 sleep 0.3
1312 if [ -n "$TCPIPPORT" ]; then
1313 # adb root just killed our connection
1314 # so reconnect...
1315 adb connect "$TCPIPPORT"
1316 fi
1317 adb wait-for-device &> /dev/null
1318 sleep 0.3
1319}
1320
1321#
1322# fix_xml:
1323#
1324# $1: xml file to fix
1325#
1326function fix_xml() {
1327 local XML="$1"
1328 local TEMP_XML="$TMPDIR/`basename "$XML"`.temp"
1329
Dobroslaw Kijowski3af2a8d2017-05-18 12:35:02 +02001330 grep -a '^<?xml version' "$XML" > "$TEMP_XML"
1331 grep -av '^<?xml version' "$XML" >> "$TEMP_XML"
Steve Kondik5bd66602016-07-15 10:39:58 -07001332
1333 mv "$TEMP_XML" "$XML"
1334}
1335
Vladimir Olteande985fe2019-01-17 03:07:34 +02001336function get_hash() {
1337 local FILE="$1"
1338
1339 if [ "$(uname)" == "Darwin" ]; then
1340 shasum "${FILE}" | awk '{print $1}'
1341 else
1342 sha1sum "${FILE}" | awk '{print $1}'
1343 fi
1344}
1345
Vladimir Olteana7d20492019-01-17 03:05:52 +02001346function print_spec() {
1347 local SPEC_PRODUCT_PACKAGE="$1"
1348 local SPEC_SRC_FILE="$2"
1349 local SPEC_DST_FILE="$3"
1350 local SPEC_ARGS="$4"
1351 local SPEC_HASH="$5"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001352 local SPEC_FIXUP_HASH="$6"
Vladimir Olteana7d20492019-01-17 03:05:52 +02001353
1354 local PRODUCT_PACKAGE=""
1355 if [ ${SPEC_PRODUCT_PACKAGE} = true ]; then
1356 PRODUCT_PACKAGE="-"
1357 fi
1358 local SRC=""
1359 if [ ! -z "${SPEC_SRC_FILE}" ] && [ "${SPEC_SRC_FILE}" != "${SPEC_DST_FILE}" ]; then
1360 SRC="${SPEC_SRC_FILE}:"
1361 fi
1362 local DST=""
1363 if [ ! -z "${SPEC_DST_FILE}" ]; then
1364 DST="${SPEC_DST_FILE}"
1365 fi
1366 local ARGS=""
1367 if [ ! -z "${SPEC_ARGS}" ]; then
1368 ARGS=";${SPEC_ARGS}"
1369 fi
1370 local HASH=""
1371 if [ ! -z "${SPEC_HASH}" ] && [ "${SPEC_HASH}" != "x" ]; then
1372 HASH="|${SPEC_HASH}"
1373 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001374 local FIXUP_HASH=""
1375 if [ ! -z "${SPEC_FIXUP_HASH}" ] && [ "${SPEC_FIXUP_HASH}" != "x" ] && [ "${SPEC_FIXUP_HASH}" != "${SPEC_HASH}" ]; then
1376 FIXUP_HASH="|${SPEC_FIXUP_HASH}"
1377 fi
1378 printf '%s%s%s%s%s%s\n' "${PRODUCT_PACKAGE}" "${SRC}" "${DST}" "${ARGS}" "${HASH}" "${FIXUP_HASH}"
1379}
1380
1381# To be overridden by device-level extract-files.sh
1382# Parameters:
1383# $1: spec name of a blob. Can be used for filtering.
1384# If the spec is "src:dest", then $1 is "dest".
1385# If the spec is "src", then $1 is "src".
1386# $2: path to blob file. Can be used for fixups.
1387#
1388function blob_fixup() {
1389 :
Vladimir Olteana7d20492019-01-17 03:05:52 +02001390}
1391
Steve Kondik5bd66602016-07-15 10:39:58 -07001392#
1393# extract:
1394#
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001395# Positional parameters:
1396# $1: file containing the list of items to extract (aka proprietary-files.txt)
Dan Pasanen0cc05012017-03-21 09:06:11 -05001397# $2: path to extracted system folder, an ota zip file, or "adb" to extract from device
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001398# $3: section in list file to extract - optional. Setting section via $3 is deprecated.
1399#
1400# Non-positional parameters (coming after $2):
1401# --section: preferred way of selecting the portion to parse and extract from
1402# proprietary-files.txt
Vladimir Olteana7d20492019-01-17 03:05:52 +02001403# --kang: if present, this option will activate the printing of hashes for the
1404# extracted blobs. Useful with --section for subsequent pinning of
1405# blobs taken from other origins.
Steve Kondik5bd66602016-07-15 10:39:58 -07001406#
1407function extract() {
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001408 # Consume positional parameters
1409 local PROPRIETARY_FILES_TXT="$1"; shift
1410 local SRC="$1"; shift
1411 local SECTION=""
Vladimir Olteana7d20492019-01-17 03:05:52 +02001412 local KANG=false
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001413
1414 # Consume optional, non-positional parameters
1415 while [ "$#" -gt 0 ]; do
1416 case "$1" in
1417 -s|--section)
1418 SECTION="$2"; shift
1419 ;;
Vladimir Olteana7d20492019-01-17 03:05:52 +02001420 -k|--kang)
1421 KANG=true
1422 DISABLE_PINNING=1
1423 ;;
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001424 *)
1425 # Backwards-compatibility with the old behavior, where $3, if
1426 # present, denoted an optional positional ${SECTION} argument.
1427 # Users of ${SECTION} are encouraged to migrate from setting it as
1428 # positional $3, to non-positional --section ${SECTION}, the
1429 # reason being that it doesn't scale to have more than 1 optional
1430 # positional argument.
1431 SECTION="$1"
1432 ;;
1433 esac
1434 shift
1435 done
1436
Steve Kondik5bd66602016-07-15 10:39:58 -07001437 if [ -z "$OUTDIR" ]; then
1438 echo "Output dir not set!"
1439 exit 1
1440 fi
1441
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001442 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001443
1444 # Allow failing, so we can try $DEST and/or $FILE
1445 set +e
1446
1447 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1448 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
Vladimir Olteande985fe2019-01-17 03:07:34 +02001449 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
Vladimir Olteana7d20492019-01-17 03:05:52 +02001450 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
Steve Kondik5bd66602016-07-15 10:39:58 -07001451 local COUNT=${#FILELIST[@]}
theimpulson9a911af2019-08-14 03:25:12 +00001452 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
Steve Kondik5bd66602016-07-15 10:39:58 -07001453 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1454
1455 if [ "$SRC" = "adb" ]; then
1456 init_adb_connection
1457 fi
1458
Dan Pasanen0cc05012017-03-21 09:06:11 -05001459 if [ -f "$SRC" ] && [ "${SRC##*.}" == "zip" ]; then
conbold9baced42017-11-10 16:33:38 +01001460 DUMPDIR="$TMPDIR"/system_dump
Dan Pasanen0cc05012017-03-21 09:06:11 -05001461
1462 # Check if we're working with the same zip that was passed last time.
1463 # If so, let's just use what's already extracted.
1464 MD5=`md5sum "$SRC"| awk '{print $1}'`
1465 OLDMD5=`cat "$DUMPDIR"/zipmd5.txt`
1466
1467 if [ "$MD5" != "$OLDMD5" ]; then
1468 rm -rf "$DUMPDIR"
1469 mkdir "$DUMPDIR"
1470 unzip "$SRC" -d "$DUMPDIR"
1471 echo "$MD5" > "$DUMPDIR"/zipmd5.txt
1472
1473 # Stop if an A/B OTA zip is detected. We cannot extract these.
1474 if [ -a "$DUMPDIR"/payload.bin ]; then
1475 echo "A/B style OTA zip detected. This is not supported at this time. Stopping..."
1476 exit 1
1477 # If OTA is block based, extract it.
1478 elif [ -a "$DUMPDIR"/system.new.dat ]; then
1479 echo "Converting system.new.dat to system.img"
theimpulson9a911af2019-08-14 03:25:12 +00001480 python "$OMNI_ROOT"/vendor/omni/build/tools/sdat2img.py "$DUMPDIR"/system.transfer.list "$DUMPDIR"/system.new.dat "$DUMPDIR"/system.img 2>&1
Dan Pasanen0cc05012017-03-21 09:06:11 -05001481 rm -rf "$DUMPDIR"/system.new.dat "$DUMPDIR"/system
1482 mkdir "$DUMPDIR"/system "$DUMPDIR"/tmp
1483 echo "Requesting sudo access to mount the system.img"
1484 sudo mount -o loop "$DUMPDIR"/system.img "$DUMPDIR"/tmp
1485 cp -r "$DUMPDIR"/tmp/* "$DUMPDIR"/system/
1486 sudo umount "$DUMPDIR"/tmp
1487 rm -rf "$DUMPDIR"/tmp "$DUMPDIR"/system.img
1488 fi
1489 fi
1490
1491 SRC="$DUMPDIR"
1492 fi
1493
Steve Kondik5bd66602016-07-15 10:39:58 -07001494 if [ "$VENDOR_STATE" -eq "0" ]; then
1495 echo "Cleaning output directory ($OUTPUT_ROOT).."
1496 rm -rf "${OUTPUT_TMP:?}"
1497 mkdir -p "${OUTPUT_TMP:?}"
Jake Whatley9843b322017-01-25 21:49:16 -05001498 if [ -d "$OUTPUT_ROOT" ]; then
1499 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1500 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001501 VENDOR_STATE=1
1502 fi
1503
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001504 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
Steve Kondik5bd66602016-07-15 10:39:58 -07001505
1506 for (( i=1; i<COUNT+1; i++ )); do
1507
Vladimir Oltean8e2de652018-06-24 20:41:30 +03001508 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
Vladimir Olteanb06f3aa2018-06-24 20:38:04 +03001509 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
Vladimir Olteand6391332018-06-24 20:42:01 +03001510 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001511 local OUTPUT_DIR=
1512 local TMP_DIR=
1513 local SRC_FILE=
1514 local DST_FILE=
Vladimir Olteana7d20492019-01-17 03:05:52 +02001515 local IS_PRODUCT_PACKAGE=false
1516
1517 # Note: this relies on the fact that the ${FILELIST[@]} array
1518 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1519 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1520 IS_PRODUCT_PACKAGE=true
1521 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001522
Vladimir Olteand6391332018-06-24 20:42:01 +03001523 if [ "${SPEC_ARGS}" = "rootfs" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001524 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1525 TMP_DIR="${OUTPUT_TMP}/rootfs"
1526 SRC_FILE="/${SPEC_SRC_FILE}"
1527 DST_FILE="/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001528 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001529 OUTPUT_DIR="${OUTPUT_ROOT}"
1530 TMP_DIR="${OUTPUT_TMP}"
1531 SRC_FILE="/system/${SPEC_SRC_FILE}"
1532 DST_FILE="/system/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001533 fi
1534
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001535 # Strip the file path in the vendor repo of "system", if present
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001536 local BLOB_DISPLAY_NAME="${DST_FILE#/system/}"
dianlujitao4ddcfb72020-04-06 12:43:16 +08001537 local VENDOR_REPO_FILE="$OUTPUT_DIR/${BLOB_DISPLAY_NAME}"
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001538 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001539
Gabriele M58270a32017-11-13 23:15:29 +01001540 # Check pinned files
Vladimir Olteane688cf92019-01-17 02:47:02 +02001541 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001542 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Gabriele M58270a32017-11-13 23:15:29 +01001543 local KEEP=""
Vladimir Olteande985fe2019-01-17 03:07:34 +02001544 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001545 if [ -f "${VENDOR_REPO_FILE}" ]; then
1546 local PINNED="${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001547 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001548 local PINNED="${TMP_DIR}${DST_FILE#/system}"
Gabriele M58270a32017-11-13 23:15:29 +01001549 fi
1550 if [ -f "$PINNED" ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001551 local TMP_HASH=$(get_hash "${PINNED}")
1552 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
Gabriele M58270a32017-11-13 23:15:29 +01001553 KEEP="1"
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001554 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1555 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001556 fi
1557 fi
1558 fi
1559 fi
1560
Vladimir Olteana7d20492019-01-17 03:05:52 +02001561 if [ "${KANG}" = false ]; then
1562 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1563 fi
1564
Gabriele M58270a32017-11-13 23:15:29 +01001565 if [ "$KEEP" = "1" ]; then
Vladimir Olteana7d20492019-01-17 03:05:52 +02001566 printf ' + keeping pinned file with hash %s\n' "${HASH}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001567 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001568 FOUND=false
1569 # Try Lineage target first.
1570 # Also try to search for files stripped of
1571 # the "/system" prefix, if we're actually extracting
1572 # from a system image.
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001573 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001574 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${SRC} && {
1575 FOUND=true
1576 break
1577 }
1578 done
1579
1580 if [ "${FOUND}" = false ]; then
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001581 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
Vladimir Oltean11329372018-10-18 00:44:02 +03001582 continue
Steve Kondik5bd66602016-07-15 10:39:58 -07001583 fi
1584 fi
1585
Vladimir Olteande985fe2019-01-17 03:07:34 +02001586 # Blob fixup pipeline has 2 parts: one that is fixed and
1587 # one that is user-configurable
1588 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1589 # Deodex apk|jar if that's the case
1590 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1591 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "$SRC"
1592 if [ -f "$TMPDIR/classes.dex" ]; then
dianlujitaoded7c1e2020-04-06 12:45:36 +08001593 touch -t 200901010000 "$TMPDIR/classes"*
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001594 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1595 rm "$TMPDIR/classes"*
Vladimir Olteande985fe2019-01-17 03:07:34 +02001596 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001597 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001598 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1599 fix_xml "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001600 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001601 # Now run user-supplied fixup function
1602 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1603 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
Steve Kondik5bd66602016-07-15 10:39:58 -07001604
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001605 if [ -f "${VENDOR_REPO_FILE}" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001606 local DIR=$(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001607 local TYPE="${DIR##*/}"
1608 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001609 chmod 755 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001610 else
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001611 chmod 644 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001612 fi
1613 fi
1614
Vladimir Olteana7d20492019-01-17 03:05:52 +02001615 if [ "${KANG}" = true ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001616 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1617 fi
1618
1619 # Check and print whether the fixup pipeline actually did anything.
1620 # This isn't done right after the fixup pipeline because we want this print
1621 # to come after print_spec above, when in kang mode.
1622 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1623 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1624 # Now sanity-check the spec for this blob.
1625 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1626 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1627 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1628 fi
Vladimir Olteana7d20492019-01-17 03:05:52 +02001629 fi
1630
Steve Kondik5bd66602016-07-15 10:39:58 -07001631 done
1632
1633 # Don't allow failing
1634 set -e
1635}
1636
1637#
Rashed Abdel-Tawab5b97a982019-09-29 01:19:57 -04001638# extract2:
1639#
1640# Positional parameters:
1641# $1: file containing the list of items to extract (aka proprietary-files.txt)
1642#
1643# Non-positional parameters (coming after $2):
1644# --section: selects the portion to parse and extracts from proprietary-files.txt
1645# --kang: if present, this option will activate the printing of hashes for the
1646# extracted blobs. Useful with --section for subsequent pinning of
1647# blobs taken from other origins.
1648#
1649function extract2() {
1650 # Consume positional parameters
1651 local PROPRIETARY_FILES_TXT="$1"; shift
1652 local SECTION=""
1653 local KANG=false
1654
1655 # Consume optional, non-positional parameters
1656 while [ "$#" -gt 0 ]; do
1657 case "$1" in
1658 --adb)
1659 ADB=true
1660 ;;
1661 --system)
1662 SYSTEM_SRC="$2"; shift
1663 ;;
1664 --vendor)
1665 VENDOR_SRC="$2"; shift
1666 ;;
1667 --odm)
1668 ODM_SRC="$2"; shift
1669 ;;
1670 --product)
1671 PRODUCT_SRC="$2"; shift
1672 ;;
1673 -s|--section)
1674 SECTION="$2"; shift
1675 ;;
1676 -k|--kang)
1677 KANG=true
1678 DISABLE_PINNING=1
1679 ;;
1680 esac
1681 shift
1682 done
1683
1684 if [ -z "$ADB" ] || [ -z "$SYSTEM_SRC" && -z "$VENDOR_SRC" && -z "$ODM_SRC" && -z "$PRODUCT_SRC" ]; then
1685 echo "No sources set! You must select --adb or pass paths to partition dumps."
1686 exit 1
1687 fi
1688
1689 if [ -z "$OUTDIR" ]; then
1690 echo "Output dir not set!"
1691 exit 1
1692 fi
1693
1694 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
1695
1696 # Allow failing, so we can try $DEST and/or $FILE
1697 set +e
1698
1699 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1700 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
1701 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
1702 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
1703 local COUNT=${#FILELIST[@]}
1704 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
1705 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1706
1707 if [ "$ADB" = true ]; then
1708 init_adb_connection
1709 fi
1710
1711 if [ "$VENDOR_STATE" -eq "0" ]; then
1712 echo "Cleaning output directory ($OUTPUT_ROOT).."
1713 rm -rf "${OUTPUT_TMP:?}"
1714 mkdir -p "${OUTPUT_TMP:?}"
1715 if [ -d "$OUTPUT_ROOT" ]; then
1716 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1717 fi
1718 VENDOR_STATE=1
1719 fi
1720
1721 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
1722
1723 for (( i=1; i<COUNT+1; i++ )); do
1724
1725 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
1726 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
1727 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
1728 local OUTPUT_DIR=
1729 local TMP_DIR=
1730 local SRC_FILE=
1731 local DST_FILE=
1732 local IS_PRODUCT_PACKAGE=false
1733
1734 # Note: this relies on the fact that the ${FILELIST[@]} array
1735 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1736 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1737 IS_PRODUCT_PACKAGE=true
1738 fi
1739
1740 if [ "${SPEC_ARGS}" = "rootfs" ]; then
1741 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1742 TMP_DIR="${OUTPUT_TMP}/rootfs"
1743 else
1744 OUTPUT_DIR="${OUTPUT_ROOT}"
1745 TMP_DIR="${OUTPUT_TMP}"
1746 fi
1747 SRC_FILE="${SPEC_SRC_FILE}"
1748 DST_FILE="${SPEC_DST_FILE}"
1749
1750 local VENDOR_REPO_FILE="$OUTPUT_DIR/${DST_FILE}"
1751 local BLOB_DISPLAY_NAME="${DST_FILE}"
1752 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
1753
1754 # Check pinned files
1755 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1756 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1757 local KEEP=""
1758 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
1759 if [ -f "${VENDOR_REPO_FILE}" ]; then
1760 local PINNED="${VENDOR_REPO_FILE}"
1761 else
1762 local PINNED="${TMP_DIR}${DST_FILE}"
1763 fi
1764 if [ -f "$PINNED" ]; then
1765 local TMP_HASH=$(get_hash "${PINNED}")
1766 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
1767 KEEP="1"
1768 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1769 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
1770 fi
1771 fi
1772 fi
1773 fi
1774
1775 if [ "${KANG}" = false ]; then
1776 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1777 fi
1778
1779 if [ "$KEEP" = "1" ]; then
1780 printf ' + keeping pinned file with hash %s\n' "${HASH}"
1781 else
1782 FOUND=false
1783 PARTITION_SOURCE_DIR=
1784 # Try Lineage target first.
1785 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
1786 PARTITION=$(echo "$CANDIDATE" | cut -d/ -f1)
1787 if [ "$PARTITION" = "system" ]; then
1788 PARTITION_SOURCE_DIR="$SYSTEM_SRC"
1789 elif [ "$PARTITION" = "vendor" ]; then
1790 PARTITION_SOURCE_DIR="$VENDOR_SRC"
1791 elif [ "$PARTITION" = "product" ]; then
1792 PARTITION_SOURCE_DIR="$PRODUCT_SRC"
1793 elif [ "$PARTITION" = "odm" ]; then
1794 PARTITION_SOURCE_DIR="$ODM_SRC"
1795 fi
1796 CANDIDATE_RELATIVE_NAME=$(echo "$CANDIDATE" | cut -d/ -f2-)
1797 get_file ${CANDIDATE_RELATIVE_NAME} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1798 FOUND=true
1799 break
1800 }
1801 # Search with the full system/ prefix if the file was not found on the system partition
1802 # because we may be searching in a mounted system-as-root system.img
1803 if [[ "${FOUND}" = false && "$PARTITION" = "system" ]]; then
1804 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1805 FOUND=true
1806 break
1807 }
1808 fi
1809 done
1810
1811 if [ -z "${PARTITION_SOURCE_DIR}" ]; then
1812 echo "$CANDIDATE has no preceeding partition path. Prepend system/, vendor/, product/, or odm/ to this entry."
1813 fi
1814
1815 if [ "${FOUND}" = false ]; then
1816 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
1817 continue
1818 fi
1819 fi
1820
1821 # Blob fixup pipeline has 2 parts: one that is fixed and
1822 # one that is user-configurable
1823 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1824 # Deodex apk|jar if that's the case
1825 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1826 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "${SYSTEM_SRC}"
1827 if [ -f "$TMPDIR/classes.dex" ]; then
1828 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1829 rm "$TMPDIR/classes"*
1830 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
1831 fi
1832 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1833 fix_xml "${VENDOR_REPO_FILE}"
1834 fi
1835 # Now run user-supplied fixup function
1836 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1837 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1838
1839 if [ -f "${VENDOR_REPO_FILE}" ]; then
1840 local DIR=$(dirname "${VENDOR_REPO_FILE}")
1841 local TYPE="${DIR##*/}"
1842 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
1843 chmod 755 "${VENDOR_REPO_FILE}"
1844 else
1845 chmod 644 "${VENDOR_REPO_FILE}"
1846 fi
1847 fi
1848
1849 if [ "${KANG}" = true ]; then
1850 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1851 fi
1852
1853 # Check and print whether the fixup pipeline actually did anything.
1854 # This isn't done right after the fixup pipeline because we want this print
1855 # to come after print_spec above, when in kang mode.
1856 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1857 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1858 # Now sanity-check the spec for this blob.
1859 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1860 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1861 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1862 fi
1863 fi
1864
1865 done
1866
1867 # Don't allow failing
1868 set -e
1869}
1870
1871#
Steve Kondik5bd66602016-07-15 10:39:58 -07001872# extract_firmware:
1873#
1874# $1: file containing the list of items to extract
1875# $2: path to extracted radio folder
1876#
1877function extract_firmware() {
1878 if [ -z "$OUTDIR" ]; then
1879 echo "Output dir not set!"
1880 exit 1
1881 fi
1882
1883 parse_file_list "$1"
1884
1885 # Don't allow failing
1886 set -e
1887
1888 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} )
1889 local COUNT=${#FILELIST[@]}
1890 local SRC="$2"
theimpulson9a911af2019-08-14 03:25:12 +00001891 local OUTPUT_DIR="$OMNI_ROOT"/"$OUTDIR"/radio
Steve Kondik5bd66602016-07-15 10:39:58 -07001892
1893 if [ "$VENDOR_RADIO_STATE" -eq "0" ]; then
1894 echo "Cleaning firmware output directory ($OUTPUT_DIR).."
1895 rm -rf "${OUTPUT_DIR:?}/"*
1896 VENDOR_RADIO_STATE=1
1897 fi
1898
1899 echo "Extracting $COUNT files in $1 from $SRC:"
1900
1901 for (( i=1; i<COUNT+1; i++ )); do
1902 local FILE="${FILELIST[$i-1]}"
1903 printf ' - %s \n' "/radio/$FILE"
1904
1905 if [ ! -d "$OUTPUT_DIR" ]; then
1906 mkdir -p "$OUTPUT_DIR"
1907 fi
1908 cp "$SRC/$FILE" "$OUTPUT_DIR/$FILE"
1909 chmod 644 "$OUTPUT_DIR/$FILE"
1910 done
1911}
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -07001912
1913function extract_img_data() {
1914 local image_file="$1"
1915 local out_dir="$2"
1916 local logFile="$TMPDIR/debugfs.log"
1917
1918 if [ ! -d "$out_dir" ]; then
1919 mkdir -p "$out_dir"
1920 fi
1921
1922 if [[ "$HOST_OS" == "Darwin" ]]; then
1923 debugfs -R "rdump / \"$out_dir\"" "$image_file" &> "$logFile" || {
1924 echo "[-] Failed to extract data from '$image_file'"
1925 abort 1
1926 }
1927 else
1928 debugfs -R 'ls -p' "$image_file" 2>/dev/null | cut -d '/' -f6 | while read -r entry
1929 do
1930 debugfs -R "rdump \"$entry\" \"$out_dir\"" "$image_file" >> "$logFile" 2>&1 || {
1931 echo "[-] Failed to extract data from '$image_file'"
1932 abort 1
1933 }
1934 done
1935 fi
1936
1937 local symlink_err="rdump: Attempt to read block from filesystem resulted in short read while reading symlink"
1938 if grep -Fq "$symlink_err" "$logFile"; then
1939 echo "[-] Symlinks have not been properly processed from $image_file"
1940 echo "[!] If you don't have a compatible debugfs version, modify 'execute-all.sh' to disable 'USE_DEBUGFS' flag"
1941 abort 1
1942 fi
1943}
1944
1945declare -ra VENDOR_SKIP_FILES=(
1946 "bin/toybox_vendor"
1947 "bin/toolbox"
1948 "bin/grep"
1949 "build.prop"
1950 "compatibility_matrix.xml"
1951 "default.prop"
1952 "etc/NOTICE.xml.gz"
1953 "etc/vintf/compatibility_matrix.xml"
1954 "etc/vintf/manifest.xml"
1955 "etc/wifi/wpa_supplicant.conf"
1956 "manifest.xml"
1957 "overlay/DisplayCutoutEmulationCorner/DisplayCutoutEmulationCornerOverlay.apk"
1958 "overlay/DisplayCutoutEmulationDouble/DisplayCutoutEmulationDoubleOverlay.apk"
1959 "overlay/DisplayCutoutEmulationTall/DisplayCutoutEmulationTallOverlay.apk"
1960 "overlay/DisplayCutoutNoCutout/NoCutoutOverlay.apk"
1961 "overlay/framework-res__auto_generated_rro.apk"
1962 "overlay/SysuiDarkTheme/SysuiDarkThemeOverlay.apk"
1963)
1964
1965function array_contains() {
1966 local element
1967 for element in "${@:2}"; do [[ "$element" == "$1" ]] && return 0; done
1968 return 1
1969}
1970
1971function generate_prop_list_from_image() {
1972 local image_file="$1"
1973 local image_dir="$TMPDIR/image-temp"
1974 local output_list="$2"
1975 local output_list_tmp="$TMPDIR/_proprietary-blobs.txt"
1976 local -n skipped_vendor_files="$3"
1977
1978 extract_img_data "$image_file" "$image_dir"
1979
1980 find "$image_dir" -not -type d | sed "s#^$image_dir/##" | while read -r FILE
1981 do
1982 # Skip VENDOR_SKIP_FILES since it will be re-generated at build time
1983 if array_contains "$FILE" "${VENDOR_SKIP_FILES[@]}"; then
1984 continue
1985 fi
1986 # Skip device defined skipped files since they will be re-generated at build time
1987 if array_contains "$FILE" "${skipped_vendor_files[@]}"; then
1988 continue
1989 fi
1990 if suffix_match_file ".apk" "$FILE" ; then
1991 echo "-vendor/$FILE" >> "$output_list_tmp"
1992 else
1993 echo "vendor/$FILE" >> "$output_list_tmp"
1994 fi
1995 done
1996
1997 # Sort merged file with all lists
1998 sort -u "$output_list_tmp" > "$output_list"
1999
2000 # Clean-up
2001 rm -f "$output_list_tmp"
2002}