blob: 0c3a1561dc9cc8d36b68bd3ffc0c11d0ba62c20d [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() {
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300132 local SPEC="$1"
133 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
398 elif [ "$CLASS" = "APPS" ]; then
399 printf 'android_app_import {\n'
400 printf '\tname: "%s",\n' "$PKGNAME"
401 printf '\towner: "%s",\n' "$VENDOR"
402 if [ "$EXTRA" = "priv-app" ]; then
403 SRC="$SRC/priv-app"
404 else
405 SRC="$SRC/app"
406 fi
407 printf '\tapk: "%s/%s",\n' "$SRC" "$FILE"
408 if [ "$ARGS" = "PRESIGNED" ]; then
409 printf '\tpresigned: true,\n'
410 elif [ ! -z "$ARGS" ]; then
411 printf '\tcertificate: "%s",\n' "$ARGS"
412 else
413 printf '\tcertificate: "platform",\n'
414 fi
415 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
416 printf 'dex_import {\n'
417 printf '\tname: "%s",\n' "$PKGNAME"
418 printf '\towner: "%s",\n' "$VENDOR"
419 printf '\tjars: ["%s/framework/%s"],\n' "$SRC" "$FILE"
420 elif [ "$CLASS" = "ETC" ]; then
421 if [ "$EXTENSION" = "xml" ]; then
422 printf 'prebuilt_etc_xml {\n'
423 else
424 printf 'prebuilt_etc {\n'
425 fi
426 printf '\tname: "%s",\n' "$PKGNAME"
427 printf '\towner: "%s",\n' "$VENDOR"
428 printf '\tsrc: "%s/etc/%s",\n' "$SRC" "$FILE"
429 elif [ "$CLASS" = "EXECUTABLES" ]; then
430 if [ "$EXTENSION" = "sh" ]; then
431 printf 'sh_binary {\n'
432 else
433 printf 'cc_prebuilt_binary {\n'
434 fi
435 printf '\tname: "%s",\n' "$PKGNAME"
436 printf '\towner: "%s",\n' "$VENDOR"
437 if [ "$ARGS" = "rootfs" ]; then
438 SRC="$SRC/rootfs"
439 if [ "$EXTRA" = "sbin" ]; then
440 SRC="$SRC/sbin"
441 printf '\tdist {\n'
442 printf '\t\tdest: "%s",\n' "root/sbin"
443 printf '\t},'
444 fi
445 else
446 SRC="$SRC/bin"
447 fi
448 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
449 unset EXTENSION
450 else
451 printf '\tsrcs: ["%s/%s"],\n' "$SRC" "$FILE"
452 fi
453 if [ "$CLASS" = "APPS" ]; then
454 printf '\tdex_preopt: {\n'
455 printf '\t\tenabled: false,\n'
456 printf '\t},\n'
457 fi
458 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] || [ "$CLASS" = "ETC" ] ; then
459 if [ "$DIRNAME" != "." ]; then
460 printf '\tsub_dir: "%s",\n' "$DIRNAME"
461 fi
462 fi
463 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ] ; then
464 printf '\tprefer: true,\n'
465 fi
466 if [ "$EXTRA" = "priv-app" ]; then
467 printf '\tprivileged: true,\n'
468 fi
469 if [ "$PARTITION" = "vendor" ]; then
470 printf '\tsoc_specific: true,\n'
471 elif [ "$PARTITION" = "product" ]; then
472 printf '\tproduct_specific: true,\n'
473 elif [ "$PARTITION" = "odm" ]; then
474 printf '\tdevice_specific: true,\n'
475 fi
476 printf '}\n\n'
477 done
478}
479
480#
481# write_makefile_packages:
482#
483# $1: The LOCAL_MODULE_CLASS for the given module list
484# $2: /odm, /product, or /vendor partition
485# $3: type-specific extra flags
486# $4: Name of the array holding the target list
487#
488# Internal function which writes out the BUILD_PREBUILT stanzas
489# for all modules in the list. This is called by write_product_packages
490# after the modules are categorized.
491#
492function write_makefile_packages() {
Steve Kondik5bd66602016-07-15 10:39:58 -0700493
494 local CLASS="$1"
razorlovesa0d296b2019-07-29 02:21:34 -0500495 local PARTITION="$2"
Steve Kondik5bd66602016-07-15 10:39:58 -0700496 local EXTRA="$3"
497
498 # Yes, this is a horrible hack - we create a new array using indirection
499 local ARR_NAME="$4[@]"
500 local FILELIST=("${!ARR_NAME}")
501
502 local FILE=
503 local ARGS=
504 local BASENAME=
505 local EXTENSION=
506 local PKGNAME=
507 local SRC=
508
509 for P in "${FILELIST[@]}"; do
Vladimir Olteanc70bc122018-06-24 20:09:55 +0300510 FILE=$(target_file "$P")
Steve Kondik5bd66602016-07-15 10:39:58 -0700511 ARGS=$(target_args "$P")
512
513 BASENAME=$(basename "$FILE")
M1cha3e8c5bf2017-01-04 09:00:11 +0100514 DIRNAME=$(dirname "$FILE")
Steve Kondik5bd66602016-07-15 10:39:58 -0700515 EXTENSION=${BASENAME##*.}
Mohd Farazcb0f4872019-10-08 16:13:50 +0530516 EXTENSION="."$EXTENSION
517 if [ "$EXTENSION" = ".jar" ]; then
518 EXTENSION="\$(COMMON_JAVA_PACKAGE_SUFFIX)"
519 elif [ "$EXTENSION" = ".apk" ]; then
520 EXTENSION="\$(COMMON_ANDROID_PACKAGE_SUFFIX)"
521 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700522 PKGNAME=${BASENAME%.*}
523
524 # Add to final package list
525 PACKAGE_LIST+=("$PKGNAME")
526
527 SRC="proprietary"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400528 if [ "$PARTITION" = "system" ]; then
529 SRC+="/system"
530 elif [ "$PARTITION" = "vendor" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -0700531 SRC+="/vendor"
razorlovesa0d296b2019-07-29 02:21:34 -0500532 elif [ "$PARTITION" = "product" ]; then
533 SRC+="/product"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700534 elif [ "$PARTITION" = "odm" ]; then
535 SRC+="/odm"
Steve Kondik5bd66602016-07-15 10:39:58 -0700536 fi
537
538 printf 'include $(CLEAR_VARS)\n'
539 printf 'LOCAL_MODULE := %s\n' "$PKGNAME"
540 printf 'LOCAL_MODULE_OWNER := %s\n' "$VENDOR"
541 if [ "$CLASS" = "SHARED_LIBRARIES" ]; then
542 if [ "$EXTRA" = "both" ]; then
543 printf 'LOCAL_SRC_FILES_64 := %s/lib64/%s\n' "$SRC" "$FILE"
544 printf 'LOCAL_SRC_FILES_32 := %s/lib/%s\n' "$SRC" "$FILE"
545 #if [ "$VENDOR_PKG" = "true" ]; then
546 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
547 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_VENDOR_SHARED_LIBRARIES)"
548 #else
549 # echo "LOCAL_MODULE_PATH_64 := \$(TARGET_OUT_SHARED_LIBRARIES)"
550 # echo "LOCAL_MODULE_PATH_32 := \$(2ND_TARGET_OUT_SHARED_LIBRARIES)"
551 #fi
552 elif [ "$EXTRA" = "64" ]; then
553 printf 'LOCAL_SRC_FILES := %s/lib64/%s\n' "$SRC" "$FILE"
554 else
555 printf 'LOCAL_SRC_FILES := %s/lib/%s\n' "$SRC" "$FILE"
556 fi
557 if [ "$EXTRA" != "none" ]; then
558 printf 'LOCAL_MULTILIB := %s\n' "$EXTRA"
559 fi
560 elif [ "$CLASS" = "APPS" ]; then
Michael Bestas9c6f2eb2018-01-25 21:05:36 +0200561 if [ "$EXTRA" = "priv-app" ]; then
562 SRC="$SRC/priv-app"
563 else
564 SRC="$SRC/app"
Steve Kondik5bd66602016-07-15 10:39:58 -0700565 fi
566 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
567 local CERT=platform
568 if [ ! -z "$ARGS" ]; then
569 CERT="$ARGS"
570 fi
571 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
572 elif [ "$CLASS" = "JAVA_LIBRARIES" ]; then
573 printf 'LOCAL_SRC_FILES := %s/framework/%s\n' "$SRC" "$FILE"
Elektroschmockdd792302016-10-04 21:11:43 +0200574 local CERT=platform
575 if [ ! -z "$ARGS" ]; then
576 CERT="$ARGS"
577 fi
578 printf 'LOCAL_CERTIFICATE := %s\n' "$CERT"
Steve Kondik5bd66602016-07-15 10:39:58 -0700579 elif [ "$CLASS" = "ETC" ]; then
580 printf 'LOCAL_SRC_FILES := %s/etc/%s\n' "$SRC" "$FILE"
581 elif [ "$CLASS" = "EXECUTABLES" ]; then
582 if [ "$ARGS" = "rootfs" ]; then
583 SRC="$SRC/rootfs"
584 if [ "$EXTRA" = "sbin" ]; then
585 SRC="$SRC/sbin"
586 printf '%s\n' "LOCAL_MODULE_PATH := \$(TARGET_ROOT_OUT_SBIN)"
587 printf '%s\n' "LOCAL_UNSTRIPPED_PATH := \$(TARGET_ROOT_OUT_SBIN_UNSTRIPPED)"
588 fi
589 else
590 SRC="$SRC/bin"
591 fi
592 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
593 unset EXTENSION
594 else
595 printf 'LOCAL_SRC_FILES := %s/%s\n' "$SRC" "$FILE"
596 fi
597 printf 'LOCAL_MODULE_TAGS := optional\n'
598 printf 'LOCAL_MODULE_CLASS := %s\n' "$CLASS"
Hashbang173575f3bb2016-08-28 20:38:45 -0400599 if [ "$CLASS" = "APPS" ]; then
600 printf 'LOCAL_DEX_PREOPT := false\n'
601 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700602 if [ ! -z "$EXTENSION" ]; then
Mohd Farazcb0f4872019-10-08 16:13:50 +0530603 printf 'LOCAL_MODULE_SUFFIX := %s\n' "$EXTENSION"
Steve Kondik5bd66602016-07-15 10:39:58 -0700604 fi
M1cha3e8c5bf2017-01-04 09:00:11 +0100605 if [ "$CLASS" = "SHARED_LIBRARIES" ] || [ "$CLASS" = "EXECUTABLES" ]; then
606 if [ "$DIRNAME" != "." ]; then
607 printf 'LOCAL_MODULE_RELATIVE_PATH := %s\n' "$DIRNAME"
608 fi
609 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700610 if [ "$EXTRA" = "priv-app" ]; then
611 printf 'LOCAL_PRIVILEGED_MODULE := true\n'
612 fi
razorlovesa0d296b2019-07-29 02:21:34 -0500613 if [ "$PARTITION" = "vendor" ]; then
Ethan Chen4f738f52018-02-17 20:03:54 -0800614 printf 'LOCAL_VENDOR_MODULE := true\n'
razorlovesa0d296b2019-07-29 02:21:34 -0500615 elif [ "$PARTITION" = "product" ]; then
616 printf 'LOCAL_PRODUCT_MODULE := true\n'
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700617 elif [ "$PARTITION" = "odm" ]; then
618 printf 'LOCAL_ODM_MODULE := true\n'
Steve Kondik5bd66602016-07-15 10:39:58 -0700619 fi
620 printf 'include $(BUILD_PREBUILT)\n\n'
621 done
622}
623
624#
625# write_product_packages:
626#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700627# This function will create prebuilt entries in the
628# Android.bp and associated PRODUCT_PACKAGES list in the
Steve Kondik5bd66602016-07-15 10:39:58 -0700629# product makefile for all files in the blob list which
630# start with a single dash (-) character.
631#
632function write_product_packages() {
633 PACKAGE_LIST=()
634
635 local COUNT=${#PRODUCT_PACKAGES_LIST[@]}
636
637 if [ "$COUNT" = "0" ]; then
638 return 0
639 fi
640
641 # Figure out what's 32-bit, what's 64-bit, and what's multilib
642 # I really should not be doing this in bash due to shitty array passing :(
643 local T_LIB32=( $(prefix_match "lib/") )
644 local T_LIB64=( $(prefix_match "lib64/") )
645 local MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${T_LIB64[@]}")) )
646 local LIB32=( $(comm -23 <(printf '%s\n' "${T_LIB32[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
647 local LIB64=( $(comm -23 <(printf '%s\n' "${T_LIB64[@]}") <(printf '%s\n' "${MULTILIBS[@]}")) )
648
649 if [ "${#MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700650 write_blueprint_packages "SHARED_LIBRARIES" "" "both" "MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700651 fi
652 if [ "${#LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700653 write_blueprint_packages "SHARED_LIBRARIES" "" "32" "LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700654 fi
655 if [ "${#LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700656 write_blueprint_packages "SHARED_LIBRARIES" "" "64" "LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700657 fi
658
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400659 local T_S_LIB32=( $(prefix_match "system/lib/") )
660 local T_S_LIB64=( $(prefix_match "system/lib64/") )
661 local S_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${T_S_LIB64[@]}")) )
662 local S_LIB32=( $(comm -23 <(printf '%s\n' "${T_S_LIB32[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
663 local S_LIB64=( $(comm -23 <(printf '%s\n' "${T_S_LIB64[@]}") <(printf '%s\n' "${S_MULTILIBS[@]}")) )
664
665 if [ "${#S_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700666 write_blueprint_packages "SHARED_LIBRARIES" "system" "both" "S_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400667 fi
668 if [ "${#S_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700669 write_blueprint_packages "SHARED_LIBRARIES" "system" "32" "S_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400670 fi
671 if [ "${#S_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700672 write_blueprint_packages "SHARED_LIBRARIES" "system" "64" "S_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400673 fi
674
Steve Kondik5bd66602016-07-15 10:39:58 -0700675 local T_V_LIB32=( $(prefix_match "vendor/lib/") )
676 local T_V_LIB64=( $(prefix_match "vendor/lib64/") )
677 local V_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${T_V_LIB64[@]}")) )
678 local V_LIB32=( $(comm -23 <(printf '%s\n' "${T_V_LIB32[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
679 local V_LIB64=( $(comm -23 <(printf '%s\n' "${T_V_LIB64[@]}") <(printf '%s\n' "${V_MULTILIBS[@]}")) )
680
681 if [ "${#V_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700682 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "both" "V_MULTILIBS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700683 fi
684 if [ "${#V_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700685 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "32" "V_LIB32" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700686 fi
687 if [ "${#V_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700688 write_blueprint_packages "SHARED_LIBRARIES" "vendor" "64" "V_LIB64" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500689 fi
690
691 local T_P_LIB32=( $(prefix_match "product/lib/") )
692 local T_P_LIB64=( $(prefix_match "product/lib64/") )
693 local P_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${T_P_LIB64[@]}")) )
694 local P_LIB32=( $(comm -23 <(printf '%s\n' "${T_P_LIB32[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
695 local P_LIB64=( $(comm -23 <(printf '%s\n' "${T_P_LIB64[@]}") <(printf '%s\n' "${P_MULTILIBS[@]}")) )
696
697 if [ "${#P_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700698 write_blueprint_packages "SHARED_LIBRARIES" "product" "both" "P_MULTILIBS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500699 fi
700 if [ "${#P_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700701 write_blueprint_packages "SHARED_LIBRARIES" "product" "32" "P_LIB32" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500702 fi
703 if [ "${#P_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700704 write_blueprint_packages "SHARED_LIBRARIES" "product" "64" "P_LIB64" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700705 fi
706
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700707 local T_O_LIB32=( $(prefix_match "odm/lib/") )
708 local T_O_LIB64=( $(prefix_match "odm/lib64/") )
709 local O_MULTILIBS=( $(comm -12 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${T_O_LIB64[@]}")) )
710 local O_LIB32=( $(comm -23 <(printf '%s\n' "${T_O_LIB32[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
711 local O_LIB64=( $(comm -23 <(printf '%s\n' "${T_O_LIB64[@]}") <(printf '%s\n' "${O_MULTILIBS[@]}")) )
712
713 if [ "${#O_MULTILIBS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700714 write_blueprint_packages "SHARED_LIBRARIES" "odm" "both" "O_MULTILIBS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700715 fi
716 if [ "${#O_LIB32[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700717 write_blueprint_packages "SHARED_LIBRARIES" "odm" "32" "O_LIB32" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700718 fi
719 if [ "${#O_LIB64[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700720 write_blueprint_packages "SHARED_LIBRARIES" "odm" "64" "O_LIB64" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700721 fi
722
Steve Kondik5bd66602016-07-15 10:39:58 -0700723 # Apps
724 local APPS=( $(prefix_match "app/") )
725 if [ "${#APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700726 write_blueprint_packages "APPS" "" "" "APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700727 fi
728 local PRIV_APPS=( $(prefix_match "priv-app/") )
729 if [ "${#PRIV_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700730 write_blueprint_packages "APPS" "" "priv-app" "PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700731 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400732 local S_APPS=( $(prefix_match "system/app/") )
733 if [ "${#S_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700734 write_blueprint_packages "APPS" "system" "" "S_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400735 fi
736 local S_PRIV_APPS=( $(prefix_match "system/priv-app/") )
737 if [ "${#S_PRIV_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700738 write_blueprint_packages "APPS" "system" "priv-app" "S_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400739 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700740 local V_APPS=( $(prefix_match "vendor/app/") )
741 if [ "${#V_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700742 write_blueprint_packages "APPS" "vendor" "" "V_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700743 fi
744 local V_PRIV_APPS=( $(prefix_match "vendor/priv-app/") )
745 if [ "${#V_PRIV_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700746 write_blueprint_packages "APPS" "vendor" "priv-app" "V_PRIV_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500747 fi
748 local P_APPS=( $(prefix_match "product/app/") )
749 if [ "${#P_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700750 write_blueprint_packages "APPS" "product" "" "P_APPS" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500751 fi
752 local P_PRIV_APPS=( $(prefix_match "product/priv-app/") )
753 if [ "${#P_PRIV_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700754 write_blueprint_packages "APPS" "product" "priv-app" "P_PRIV_APPS" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700755 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700756 local O_APPS=( $(prefix_match "odm/app/") )
757 if [ "${#O_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700758 write_blueprint_packages "APPS" "odm" "" "O_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700759 fi
760 local O_PRIV_APPS=( $(prefix_match "odm/priv-app/") )
761 if [ "${#O_PRIV_APPS[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700762 write_blueprint_packages "APPS" "odm" "priv-app" "O_PRIV_APPS" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700763 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700764
765 # Framework
766 local FRAMEWORK=( $(prefix_match "framework/") )
767 if [ "${#FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700768 write_blueprint_packages "JAVA_LIBRARIES" "" "" "FRAMEWORK" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700769 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400770 local S_FRAMEWORK=( $(prefix_match "system/framework/") )
771 if [ "${#S_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700772 write_blueprint_packages "JAVA_LIBRARIES" "system" "" "S_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400773 fi
Christian Oder974b5902017-10-08 23:15:52 +0200774 local V_FRAMEWORK=( $(prefix_match "vendor/framework/") )
Michael Bestas26eb01e2018-02-27 22:31:55 +0200775 if [ "${#V_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700776 write_blueprint_packages "JAVA_LIBRARIES" "vendor" "" "V_FRAMEWORK" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500777 fi
778 local P_FRAMEWORK=( $(prefix_match "product/framework/") )
779 if [ "${#P_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700780 write_blueprint_packages "JAVA_LIBRARIES" "product" "" "P_FRAMEWORK" >> "$ANDROIDBP"
Christian Oder974b5902017-10-08 23:15:52 +0200781 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700782 local O_FRAMEWORK=( $(prefix_match "odm/framework/") )
783 if [ "${#O_FRAMEWORK[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700784 write_blueprint_packages "JAVA_LIBRARIES" "odm" "" "O_FRAMEWORK" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700785 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700786
787 # Etc
788 local ETC=( $(prefix_match "etc/") )
789 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700790 write_blueprint_packages "ETC" "" "" "ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700791 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400792 local S_ETC=( $(prefix_match "system/etc/") )
793 if [ "${#ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700794 write_blueprint_packages "ETC" "system" "" "S_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400795 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700796 local V_ETC=( $(prefix_match "vendor/etc/") )
797 if [ "${#V_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700798 write_blueprint_packages "ETC" "vendor" "" "V_ETC" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500799 fi
800 local P_ETC=( $(prefix_match "product/etc/") )
801 if [ "${#P_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700802 write_blueprint_packages "ETC" "product" "" "P_ETC" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700803 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700804 local O_ETC=( $(prefix_match "odm/etc/") )
805 if [ "${#O_ETC[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700806 write_blueprint_packages "ETC" "odm" "" "O_ETC" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700807 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700808
809 # Executables
810 local BIN=( $(prefix_match "bin/") )
811 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700812 write_blueprint_packages "EXECUTABLES" "" "" "BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700813 fi
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400814 local S_BIN=( $(prefix_match "system/bin/") )
815 if [ "${#BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700816 write_blueprint_packages "EXECUTABLES" "system" "" "S_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba6373e52019-09-28 23:37:36 -0400817 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700818 local V_BIN=( $(prefix_match "vendor/bin/") )
819 if [ "${#V_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700820 write_blueprint_packages "EXECUTABLES" "vendor" "" "V_BIN" >> "$ANDROIDBP"
razorlovesa0d296b2019-07-29 02:21:34 -0500821 fi
822 local P_BIN=( $(prefix_match "product/bin/") )
823 if [ "${#P_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700824 write_blueprint_packages "EXECUTABLES" "product" "" "P_BIN" >> "$ANDROIDBP"
Steve Kondik5bd66602016-07-15 10:39:58 -0700825 fi
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700826 local O_BIN=( $(prefix_match "odm/bin/") )
827 if [ "${#O_BIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700828 write_blueprint_packages "EXECUTABLES" "odm" "" "O_BIN" >> "$ANDROIDBP"
Rashed Abdel-Tawaba94af582019-09-20 07:32:39 -0700829 fi
Steve Kondik5bd66602016-07-15 10:39:58 -0700830 local SBIN=( $(prefix_match "sbin/") )
831 if [ "${#SBIN[@]}" -gt "0" ]; then
Rashed Abdel-Tawabb91adc02019-09-20 10:30:38 -0700832 write_makefile_packages "EXECUTABLES" "" "sbin" "SBIN" >> "$ANDROIDMK"
Steve Kondik5bd66602016-07-15 10:39:58 -0700833 fi
834
835
836 # Actually write out the final PRODUCT_PACKAGES list
837 local PACKAGE_COUNT=${#PACKAGE_LIST[@]}
838
839 if [ "$PACKAGE_COUNT" -eq "0" ]; then
840 return 0
841 fi
842
843 printf '\n%s\n' "PRODUCT_PACKAGES += \\" >> "$PRODUCTMK"
844 for (( i=1; i<PACKAGE_COUNT+1; i++ )); do
845 local LINEEND=" \\"
846 if [ "$i" -eq "$PACKAGE_COUNT" ]; then
847 LINEEND=""
848 fi
849 printf ' %s%s\n' "${PACKAGE_LIST[$i-1]}" "$LINEEND" >> "$PRODUCTMK"
850 done
851}
852
853#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700854# write_blueprint_header:
Steve Kondik5bd66602016-07-15 10:39:58 -0700855#
856# $1: file which will be written to
857#
858# writes out the copyright header with the current year.
859# note that this is not an append operation, and should
860# be executed first!
861#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700862function write_blueprint_header() {
863 if [ -f $1 ]; then
864 rm $1
865 fi
866
867 YEAR=$(date +"%Y")
868
869 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
870
871 printf "/**\n" > $1
872 NUM_REGEX='^[0-9]+$'
873 if [[ ! $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] || [ $INITIAL_COPYRIGHT_YEAR -lt 2019 ]; then
874 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=2019
875 else
876 BLUEPRINT_INITIAL_COPYRIGHT_YEAR=$INITIAL_COPYRIGHT_YEAR
877 fi
878
879 if [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
880 printf " * Copyright (C) $YEAR The LineageOS Project\n" >> $1
881 elif [ $BLUEPRINT_INITIAL_COPYRIGHT_YEAR -le 2019 ]; then
882 printf " * Copyright (C) 2019-$YEAR The LineageOS Project\n" >> $1
883 else
884 printf " * Copyright (C) $BLUEPRINT_INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
885 fi
886
887 cat << EOF >> $1
888 *
889 * Licensed under the Apache License, Version 2.0 (the "License");
890 * you may not use this file except in compliance with the License.
891 * You may obtain a copy of the License at
892 *
893 * http://www.apache.org/licenses/LICENSE-2.0
894 *
895 * Unless required by applicable law or agreed to in writing, software
896 * distributed under the License is distributed on an "AS IS" BASIS,
897 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
898 * See the License for the specific language governing permissions and
899 * limitations under the License.
900 *
901 * This file is generated by device/$VENDOR/$DEVICE/setup-makefiles.sh
902 */
903
904EOF
905}
906
907#
908# write_makefile_header:
909#
910# $1: file which will be written to
911#
912# writes out the copyright header with the current year.
913# note that this is not an append operation, and should
914# be executed first!
915#
916function write_makefile_header() {
Jake Whatley9843b322017-01-25 21:49:16 -0500917 if [ -f $1 ]; then
918 rm $1
919 fi
920
Steve Kondik5bd66602016-07-15 10:39:58 -0700921 YEAR=$(date +"%Y")
922
923 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
924
Jake Whatley9843b322017-01-25 21:49:16 -0500925 NUM_REGEX='^[0-9]+$'
926 if [[ $INITIAL_COPYRIGHT_YEAR =~ $NUM_REGEX ]] && [ $INITIAL_COPYRIGHT_YEAR -le $YEAR ]; then
927 if [ $INITIAL_COPYRIGHT_YEAR -lt 2016 ]; then
928 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-2016 The CyanogenMod Project\n" > $1
929 elif [ $INITIAL_COPYRIGHT_YEAR -eq 2016 ]; then
930 printf "# Copyright (C) 2016 The CyanogenMod Project\n" > $1
931 fi
932 if [ $YEAR -eq 2017 ]; then
933 printf "# Copyright (C) 2017 The LineageOS Project\n" >> $1
934 elif [ $INITIAL_COPYRIGHT_YEAR -eq $YEAR ]; then
935 printf "# Copyright (C) $YEAR The LineageOS Project\n" >> $1
936 elif [ $INITIAL_COPYRIGHT_YEAR -le 2017 ]; then
937 printf "# Copyright (C) 2017-$YEAR The LineageOS Project\n" >> $1
938 else
939 printf "# Copyright (C) $INITIAL_COPYRIGHT_YEAR-$YEAR The LineageOS Project\n" >> $1
940 fi
941 else
942 printf "# Copyright (C) $YEAR The LineageOS Project\n" > $1
943 fi
944
945 cat << EOF >> $1
Steve Kondik5bd66602016-07-15 10:39:58 -0700946#
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
961EOF
962}
963
964#
965# write_headers:
966#
967# $1: devices falling under common to be added to guard - optional
Jake Whatley9843b322017-01-25 21:49:16 -0500968# $2: custom guard - optional
Steve Kondik5bd66602016-07-15 10:39:58 -0700969#
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700970# Calls write_makefile_header for each of the makefiles and
971# write_blueprint_header for Android.bp and creates the initial
972# path declaration and device guard for the Android.mk
Steve Kondik5bd66602016-07-15 10:39:58 -0700973#
974function write_headers() {
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -0700975 write_makefile_header "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500976
977 GUARD="$2"
978 if [ -z "$GUARD" ]; then
979 GUARD="TARGET_DEVICE"
980 fi
981
Steve Kondik5bd66602016-07-15 10:39:58 -0700982 cat << EOF >> "$ANDROIDMK"
983LOCAL_PATH := \$(call my-dir)
984
985EOF
986 if [ "$COMMON" -ne 1 ]; then
987 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500988ifeq (\$($GUARD),$DEVICE)
Steve Kondik5bd66602016-07-15 10:39:58 -0700989
990EOF
991 else
992 if [ -z "$1" ]; then
993 echo "Argument with devices to be added to guard must be set!"
994 exit 1
995 fi
996 cat << EOF >> "$ANDROIDMK"
Jake Whatley9843b322017-01-25 21:49:16 -0500997ifneq (\$(filter $1,\$($GUARD)),)
Steve Kondik5bd66602016-07-15 10:39:58 -0700998
999EOF
1000 fi
1001
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001002 write_makefile_header "$BOARDMK"
1003 write_makefile_header "$PRODUCTMK"
1004 write_blueprint_header "$ANDROIDBP"
1005
1006 cat << EOF >> "$ANDROIDBP"
1007soong_namespace {
1008}
1009
1010EOF
1011
1012 [ "$COMMON" -eq 1 ] && local DEVICE="$DEVICE_COMMON"
1013 cat << EOF >> "$PRODUCTMK"
1014PRODUCT_SOONG_NAMESPACES += \\
1015 vendor/$VENDOR/$DEVICE
1016
1017EOF
Steve Kondik5bd66602016-07-15 10:39:58 -07001018}
1019
1020#
1021# write_footers:
1022#
1023# Closes the inital guard and any other finalization tasks. Must
1024# be called as the final step.
1025#
1026function write_footers() {
1027 cat << EOF >> "$ANDROIDMK"
1028endif
1029EOF
1030}
1031
1032# Return success if adb is up and not in recovery
1033function _adb_connected {
1034 {
Jake Whatley9843b322017-01-25 21:49:16 -05001035 if [[ "$(adb get-state)" == device ]]
Steve Kondik5bd66602016-07-15 10:39:58 -07001036 then
1037 return 0
1038 fi
1039 } 2>/dev/null
1040
1041 return 1
1042};
1043
1044#
1045# parse_file_list:
1046#
1047# $1: input file
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001048# $2: blob section in file - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001049#
1050# Sets PRODUCT_PACKAGES and PRODUCT_COPY_FILES while parsing the input file
1051#
1052function parse_file_list() {
1053 if [ -z "$1" ]; then
1054 echo "An input file is expected!"
1055 exit 1
1056 elif [ ! -f "$1" ]; then
1057 echo "Input file "$1" does not exist!"
1058 exit 1
1059 fi
1060
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001061 if [ -n "$2" ]; then
1062 echo "Using section \"$2\""
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001063 LIST=$TMPDIR/files.txt
Vladimir Olteanfa79f212019-01-19 00:44:07 +02001064 # Match all lines starting with first line found to start* with '#'
1065 # comment and contain** $2, and ending with first line to be empty*.
1066 # *whitespaces (tabs, spaces) at the beginning of lines are discarded
1067 # **the $2 match is case-insensitive
1068 cat $1 | sed -n '/^[[:space:]]*#.*'"$2"'/I,/^[[:space:]]*$/ p' > $LIST
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001069 else
1070 LIST=$1
1071 fi
1072
1073
Steve Kondik5bd66602016-07-15 10:39:58 -07001074 PRODUCT_PACKAGES_LIST=()
1075 PRODUCT_PACKAGES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001076 PRODUCT_PACKAGES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001077 PRODUCT_COPY_FILES_LIST=()
1078 PRODUCT_COPY_FILES_HASHES=()
Vladimir Olteande985fe2019-01-17 03:07:34 +02001079 PRODUCT_COPY_FILES_FIXUP_HASHES=()
Steve Kondik5bd66602016-07-15 10:39:58 -07001080
1081 while read -r line; do
1082 if [ -z "$line" ]; then continue; fi
1083
1084 # If the line has a pipe delimiter, a sha1 hash should follow.
1085 # This indicates the file should be pinned and not overwritten
1086 # when extracting files.
1087 local SPLIT=(${line//\|/ })
1088 local COUNT=${#SPLIT[@]}
1089 local SPEC=${SPLIT[0]}
1090 local HASH="x"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001091 local FIXUP_HASH="x"
Steve Kondik5bd66602016-07-15 10:39:58 -07001092 if [ "$COUNT" -gt "1" ]; then
1093 HASH=${SPLIT[1]}
1094 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001095 if [ "$COUNT" -gt "2" ]; then
1096 FIXUP_HASH=${SPLIT[2]}
1097 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001098
1099 # if line starts with a dash, it needs to be packaged
1100 if [[ "$SPEC" =~ ^- ]]; then
1101 PRODUCT_PACKAGES_LIST+=("${SPEC#-}")
1102 PRODUCT_PACKAGES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001103 PRODUCT_PACKAGES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001104 else
1105 PRODUCT_COPY_FILES_LIST+=("$SPEC")
1106 PRODUCT_COPY_FILES_HASHES+=("$HASH")
Vladimir Olteande985fe2019-01-17 03:07:34 +02001107 PRODUCT_COPY_FILES_FIXUP_HASHES+=("$FIXUP_HASH")
Steve Kondik5bd66602016-07-15 10:39:58 -07001108 fi
1109
Rashed Abdel-Tawabb0d08e82017-04-04 02:48:18 -04001110 done < <(egrep -v '(^#|^[[:space:]]*$)' "$LIST" | LC_ALL=C sort | uniq)
Steve Kondik5bd66602016-07-15 10:39:58 -07001111}
1112
1113#
1114# write_makefiles:
1115#
1116# $1: file containing the list of items to extract
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001117# $2: make treble compatible makefile - optional
Steve Kondik5bd66602016-07-15 10:39:58 -07001118#
1119# Calls write_product_copy_files and write_product_packages on
Rashed Abdel-Tawabe2047042019-09-20 07:06:09 -07001120# the given file and appends to the Android.bp as well as
Steve Kondik5bd66602016-07-15 10:39:58 -07001121# the product makefile.
1122#
1123function write_makefiles() {
1124 parse_file_list "$1"
Rashed Abdel-Tawab7fd3ccb2017-10-07 14:18:39 -04001125 write_product_copy_files "$2"
Steve Kondik5bd66602016-07-15 10:39:58 -07001126 write_product_packages
1127}
1128
1129#
1130# append_firmware_calls_to_makefiles:
1131#
1132# Appends to Android.mk the calls to all images present in radio folder
1133# (filesmap file used by releasetools to map firmware images should be kept in the device tree)
1134#
1135function append_firmware_calls_to_makefiles() {
1136 cat << EOF >> "$ANDROIDMK"
1137ifeq (\$(LOCAL_PATH)/radio, \$(wildcard \$(LOCAL_PATH)/radio))
1138
1139RADIO_FILES := \$(wildcard \$(LOCAL_PATH)/radio/*)
1140\$(foreach f, \$(notdir \$(RADIO_FILES)), \\
1141 \$(call add-radio-file,radio/\$(f)))
1142\$(call add-radio-file,../../../device/$VENDOR/$DEVICE/radio/filesmap)
1143
1144endif
1145
1146EOF
1147}
1148
1149#
1150# get_file:
1151#
1152# $1: input file
1153# $2: target file/folder
1154# $3: source of the file (can be "adb" or a local folder)
1155#
1156# Silently extracts the input file to defined target
1157# Returns success if file can be pulled from the device or found locally
1158#
1159function get_file() {
1160 local SRC="$3"
1161
1162 if [ "$SRC" = "adb" ]; then
1163 # try to pull
1164 adb pull "$1" "$2" >/dev/null 2>&1 && return 0
1165
1166 return 1
1167 else
1168 # try to copy
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001169 cp -r "$SRC/$1" "$2" 2>/dev/null && return 0
1170 cp -r "$SRC/${1#/system}" "$2" 2>/dev/null && return 0
Vladimir Oltean6780da32019-01-06 19:38:31 +02001171 cp -r "$SRC/system/$1" "$2" 2>/dev/null && return 0
Steve Kondik5bd66602016-07-15 10:39:58 -07001172
1173 return 1
1174 fi
1175};
1176
1177#
1178# oat2dex:
1179#
1180# $1: extracted apk|jar (to check if deodex is required)
1181# $2: odexed apk|jar to deodex
1182# $3: source of the odexed apk|jar
1183#
1184# Convert apk|jar .odex in the corresposing classes.dex
1185#
1186function oat2dex() {
theimpulson9a911af2019-08-14 03:25:12 +00001187 local OMNI_TARGET="$1"
Steve Kondik5bd66602016-07-15 10:39:58 -07001188 local OEM_TARGET="$2"
1189 local SRC="$3"
1190 local TARGET=
Joe Maplesfb3941c2018-01-05 14:51:33 -05001191 local OAT=
1192 local HOST="$(uname)"
Steve Kondik5bd66602016-07-15 10:39:58 -07001193
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001194 if [ -z "$BAKSMALIJAR" ] || [ -z "$SMALIJAR" ]; then
1195 export BAKSMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/baksmali.jar
1196 export SMALIJAR="$OMNI_ROOT"/vendor/omni/build/tools/smali/smali.jar
Steve Kondik5bd66602016-07-15 10:39:58 -07001197 fi
1198
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001199 if [ -z "$VDEXEXTRACTOR" ]; then
theimpulson9a911af2019-08-14 03:25:12 +00001200 export VDEXEXTRACTOR="$OMNI_ROOT"/vendor/omni/build/tools/"$HOST"/vdexExtractor
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001201 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001202
codeworkx85eda752018-09-23 12:36:57 +02001203 if [ -z "$CDEXCONVERTER" ]; then
theimpulson9a911af2019-08-14 03:25:12 +00001204 export CDEXCONVERTER="$OMNI_ROOT"/vendor/omni/build/tools/"$HOST"/compact_dex_converter
codeworkx85eda752018-09-23 12:36:57 +02001205 fi
1206
Steve Kondik5bd66602016-07-15 10:39:58 -07001207 # Extract existing boot.oats to the temp folder
1208 if [ -z "$ARCHES" ]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001209 echo "Checking if system is odexed and locating boot.oats..."
Steve Kondik5bd66602016-07-15 10:39:58 -07001210 for ARCH in "arm64" "arm" "x86_64" "x86"; do
Jake Whatley9843b322017-01-25 21:49:16 -05001211 mkdir -p "$TMPDIR/system/framework/$ARCH"
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001212 if get_file "/system/framework/$ARCH" "$TMPDIR/system/framework/" "$SRC"; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001213 ARCHES+="$ARCH "
Jake Whatley9843b322017-01-25 21:49:16 -05001214 else
1215 rmdir "$TMPDIR/system/framework/$ARCH"
Steve Kondik5bd66602016-07-15 10:39:58 -07001216 fi
1217 done
1218 fi
1219
1220 if [ -z "$ARCHES" ]; then
1221 FULLY_DEODEXED=1 && return 0 # system is fully deodexed, return
1222 fi
1223
theimpulson9a911af2019-08-14 03:25:12 +00001224 if [ ! -f "$OMNI_TARGET" ]; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001225 return;
1226 fi
1227
theimpulson9a911af2019-08-14 03:25:12 +00001228 if grep "classes.dex" "$OMNI_TARGET" >/dev/null; then
Steve Kondik5bd66602016-07-15 10:39:58 -07001229 return 0 # target apk|jar is already odexed, return
1230 fi
1231
1232 for ARCH in $ARCHES; do
Jake Whatley9843b322017-01-25 21:49:16 -05001233 BOOTOAT="$TMPDIR/system/framework/$ARCH/boot.oat"
Steve Kondik5bd66602016-07-15 10:39:58 -07001234
Joe Maplesfb3941c2018-01-05 14:51:33 -05001235 local OAT="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").odex"
1236 local VDEX="$(dirname "$OEM_TARGET")/oat/$ARCH/$(basename "$OEM_TARGET" ."${OEM_TARGET##*.}").vdex"
Steve Kondik5bd66602016-07-15 10:39:58 -07001237
Joe Maplesfb3941c2018-01-05 14:51:33 -05001238 if get_file "$OAT" "$TMPDIR" "$SRC"; then
1239 if get_file "$VDEX" "$TMPDIR" "$SRC"; then
1240 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$VDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001241 CLASSES=$(ls "$TMPDIR/$(basename "${OEM_TARGET%.*}")_classes"*)
1242 for CLASS in $CLASSES; do
1243 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1244 # Check if we have to deal with CompactDex
1245 if [[ "$CLASS" == *.cdex ]]; then
1246 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1247 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1248 else
1249 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1250 fi
1251 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001252 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001253 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$TMPDIR/$(basename "$OAT")"
1254 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001255 fi
theimpulson9a911af2019-08-14 03:25:12 +00001256 elif [[ "$OMNI_TARGET" =~ .jar$ ]]; then
Jake Whatley9843b322017-01-25 21:49:16 -05001257 JAROAT="$TMPDIR/system/framework/$ARCH/boot-$(basename ${OEM_TARGET%.*}).oat"
Luca Stefani082f1e82018-10-07 12:44:53 +02001258 JARVDEX="/system/framework/boot-$(basename ${OEM_TARGET%.*}).vdex"
Jake Whatley9843b322017-01-25 21:49:16 -05001259 if [ ! -f "$JAROAT" ]; then
Luca Stefani082f1e82018-10-07 12:44:53 +02001260 JAROAT=$BOOTOAT
Jake Whatley9843b322017-01-25 21:49:16 -05001261 fi
Joe Maplesfb3941c2018-01-05 14:51:33 -05001262 # try to extract classes.dex from boot.vdex for frameworks jars
1263 # fallback to boot.oat if vdex is not available
Luca Stefani082f1e82018-10-07 12:44:53 +02001264 if get_file "$JARVDEX" "$TMPDIR" "$SRC"; then
Luca Stefani6f92e6b2018-10-31 19:16:05 +01001265 "$VDEXEXTRACTOR" -o "$TMPDIR/" -i "$TMPDIR/$(basename "$JARVDEX")" > /dev/null
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001266 CLASSES=$(ls "$TMPDIR/$(basename "${JARVDEX%.*}")_classes"*)
1267 for CLASS in $CLASSES; do
1268 NEWCLASS=$(echo "$CLASS" | sed 's/.*_//;s/cdex/dex/')
1269 # Check if we have to deal with CompactDex
1270 if [[ "$CLASS" == *.cdex ]]; then
1271 "$CDEXCONVERTER" "$CLASS" &>/dev/null
1272 mv "$CLASS.new" "$TMPDIR/$NEWCLASS"
1273 else
1274 mv "$CLASS" "$TMPDIR/$NEWCLASS"
1275 fi
1276 done
Joe Maplesfb3941c2018-01-05 14:51:33 -05001277 else
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001278 java -jar "$BAKSMALIJAR" deodex -o "$TMPDIR/dexout" -b "$BOOTOAT" -d "$TMPDIR" "$JAROAT/$OEM_TARGET"
1279 java -jar "$SMALIJAR" assemble "$TMPDIR/dexout" -o "$TMPDIR/classes.dex"
Joe Maplesfb3941c2018-01-05 14:51:33 -05001280 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001281 else
1282 continue
1283 fi
1284
Steve Kondik5bd66602016-07-15 10:39:58 -07001285 done
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001286
1287 rm -rf "$TMPDIR/dexout"
Steve Kondik5bd66602016-07-15 10:39:58 -07001288}
1289
1290#
1291# init_adb_connection:
1292#
1293# Starts adb server and waits for the device
1294#
1295function init_adb_connection() {
1296 adb start-server # Prevent unexpected starting server message from adb get-state in the next line
1297 if ! _adb_connected; then
1298 echo "No device is online. Waiting for one..."
1299 echo "Please connect USB and/or enable USB debugging"
1300 until _adb_connected; do
1301 sleep 1
1302 done
1303 echo "Device Found."
1304 fi
1305
1306 # Retrieve IP and PORT info if we're using a TCP connection
1307 TCPIPPORT=$(adb devices | egrep '^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+:[0-9]+[^0-9]+' \
1308 | head -1 | awk '{print $1}')
1309 adb root &> /dev/null
1310 sleep 0.3
1311 if [ -n "$TCPIPPORT" ]; then
1312 # adb root just killed our connection
1313 # so reconnect...
1314 adb connect "$TCPIPPORT"
1315 fi
1316 adb wait-for-device &> /dev/null
1317 sleep 0.3
1318}
1319
1320#
1321# fix_xml:
1322#
1323# $1: xml file to fix
1324#
1325function fix_xml() {
1326 local XML="$1"
1327 local TEMP_XML="$TMPDIR/`basename "$XML"`.temp"
1328
Dobroslaw Kijowski3af2a8d2017-05-18 12:35:02 +02001329 grep -a '^<?xml version' "$XML" > "$TEMP_XML"
1330 grep -av '^<?xml version' "$XML" >> "$TEMP_XML"
Steve Kondik5bd66602016-07-15 10:39:58 -07001331
1332 mv "$TEMP_XML" "$XML"
1333}
1334
Vladimir Olteande985fe2019-01-17 03:07:34 +02001335function get_hash() {
1336 local FILE="$1"
1337
1338 if [ "$(uname)" == "Darwin" ]; then
1339 shasum "${FILE}" | awk '{print $1}'
1340 else
1341 sha1sum "${FILE}" | awk '{print $1}'
1342 fi
1343}
1344
Vladimir Olteana7d20492019-01-17 03:05:52 +02001345function print_spec() {
1346 local SPEC_PRODUCT_PACKAGE="$1"
1347 local SPEC_SRC_FILE="$2"
1348 local SPEC_DST_FILE="$3"
1349 local SPEC_ARGS="$4"
1350 local SPEC_HASH="$5"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001351 local SPEC_FIXUP_HASH="$6"
Vladimir Olteana7d20492019-01-17 03:05:52 +02001352
1353 local PRODUCT_PACKAGE=""
1354 if [ ${SPEC_PRODUCT_PACKAGE} = true ]; then
1355 PRODUCT_PACKAGE="-"
1356 fi
1357 local SRC=""
1358 if [ ! -z "${SPEC_SRC_FILE}" ] && [ "${SPEC_SRC_FILE}" != "${SPEC_DST_FILE}" ]; then
1359 SRC="${SPEC_SRC_FILE}:"
1360 fi
1361 local DST=""
1362 if [ ! -z "${SPEC_DST_FILE}" ]; then
1363 DST="${SPEC_DST_FILE}"
1364 fi
1365 local ARGS=""
1366 if [ ! -z "${SPEC_ARGS}" ]; then
1367 ARGS=";${SPEC_ARGS}"
1368 fi
1369 local HASH=""
1370 if [ ! -z "${SPEC_HASH}" ] && [ "${SPEC_HASH}" != "x" ]; then
1371 HASH="|${SPEC_HASH}"
1372 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001373 local FIXUP_HASH=""
1374 if [ ! -z "${SPEC_FIXUP_HASH}" ] && [ "${SPEC_FIXUP_HASH}" != "x" ] && [ "${SPEC_FIXUP_HASH}" != "${SPEC_HASH}" ]; then
1375 FIXUP_HASH="|${SPEC_FIXUP_HASH}"
1376 fi
1377 printf '%s%s%s%s%s%s\n' "${PRODUCT_PACKAGE}" "${SRC}" "${DST}" "${ARGS}" "${HASH}" "${FIXUP_HASH}"
1378}
1379
1380# To be overridden by device-level extract-files.sh
1381# Parameters:
1382# $1: spec name of a blob. Can be used for filtering.
1383# If the spec is "src:dest", then $1 is "dest".
1384# If the spec is "src", then $1 is "src".
1385# $2: path to blob file. Can be used for fixups.
1386#
1387function blob_fixup() {
1388 :
Vladimir Olteana7d20492019-01-17 03:05:52 +02001389}
1390
Steve Kondik5bd66602016-07-15 10:39:58 -07001391#
1392# extract:
1393#
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001394# Positional parameters:
1395# $1: file containing the list of items to extract (aka proprietary-files.txt)
Dan Pasanen0cc05012017-03-21 09:06:11 -05001396# $2: path to extracted system folder, an ota zip file, or "adb" to extract from device
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001397# $3: section in list file to extract - optional. Setting section via $3 is deprecated.
1398#
1399# Non-positional parameters (coming after $2):
1400# --section: preferred way of selecting the portion to parse and extract from
1401# proprietary-files.txt
Vladimir Olteana7d20492019-01-17 03:05:52 +02001402# --kang: if present, this option will activate the printing of hashes for the
1403# extracted blobs. Useful with --section for subsequent pinning of
1404# blobs taken from other origins.
Steve Kondik5bd66602016-07-15 10:39:58 -07001405#
1406function extract() {
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001407 # Consume positional parameters
1408 local PROPRIETARY_FILES_TXT="$1"; shift
1409 local SRC="$1"; shift
1410 local SECTION=""
Vladimir Olteana7d20492019-01-17 03:05:52 +02001411 local KANG=false
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001412
1413 # Consume optional, non-positional parameters
1414 while [ "$#" -gt 0 ]; do
1415 case "$1" in
1416 -s|--section)
1417 SECTION="$2"; shift
1418 ;;
Vladimir Olteana7d20492019-01-17 03:05:52 +02001419 -k|--kang)
1420 KANG=true
1421 DISABLE_PINNING=1
1422 ;;
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001423 *)
1424 # Backwards-compatibility with the old behavior, where $3, if
1425 # present, denoted an optional positional ${SECTION} argument.
1426 # Users of ${SECTION} are encouraged to migrate from setting it as
1427 # positional $3, to non-positional --section ${SECTION}, the
1428 # reason being that it doesn't scale to have more than 1 optional
1429 # positional argument.
1430 SECTION="$1"
1431 ;;
1432 esac
1433 shift
1434 done
1435
Steve Kondik5bd66602016-07-15 10:39:58 -07001436 if [ -z "$OUTDIR" ]; then
1437 echo "Output dir not set!"
1438 exit 1
1439 fi
1440
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001441 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001442
1443 # Allow failing, so we can try $DEST and/or $FILE
1444 set +e
1445
1446 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1447 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
Vladimir Olteande985fe2019-01-17 03:07:34 +02001448 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
Vladimir Olteana7d20492019-01-17 03:05:52 +02001449 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
Steve Kondik5bd66602016-07-15 10:39:58 -07001450 local COUNT=${#FILELIST[@]}
theimpulson9a911af2019-08-14 03:25:12 +00001451 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
Steve Kondik5bd66602016-07-15 10:39:58 -07001452 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1453
1454 if [ "$SRC" = "adb" ]; then
1455 init_adb_connection
1456 fi
1457
Dan Pasanen0cc05012017-03-21 09:06:11 -05001458 if [ -f "$SRC" ] && [ "${SRC##*.}" == "zip" ]; then
conbold9baced42017-11-10 16:33:38 +01001459 DUMPDIR="$TMPDIR"/system_dump
Dan Pasanen0cc05012017-03-21 09:06:11 -05001460
1461 # Check if we're working with the same zip that was passed last time.
1462 # If so, let's just use what's already extracted.
1463 MD5=`md5sum "$SRC"| awk '{print $1}'`
1464 OLDMD5=`cat "$DUMPDIR"/zipmd5.txt`
1465
1466 if [ "$MD5" != "$OLDMD5" ]; then
1467 rm -rf "$DUMPDIR"
1468 mkdir "$DUMPDIR"
1469 unzip "$SRC" -d "$DUMPDIR"
1470 echo "$MD5" > "$DUMPDIR"/zipmd5.txt
1471
1472 # Stop if an A/B OTA zip is detected. We cannot extract these.
1473 if [ -a "$DUMPDIR"/payload.bin ]; then
1474 echo "A/B style OTA zip detected. This is not supported at this time. Stopping..."
1475 exit 1
1476 # If OTA is block based, extract it.
1477 elif [ -a "$DUMPDIR"/system.new.dat ]; then
1478 echo "Converting system.new.dat to system.img"
theimpulson9a911af2019-08-14 03:25:12 +00001479 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 -05001480 rm -rf "$DUMPDIR"/system.new.dat "$DUMPDIR"/system
1481 mkdir "$DUMPDIR"/system "$DUMPDIR"/tmp
1482 echo "Requesting sudo access to mount the system.img"
1483 sudo mount -o loop "$DUMPDIR"/system.img "$DUMPDIR"/tmp
1484 cp -r "$DUMPDIR"/tmp/* "$DUMPDIR"/system/
1485 sudo umount "$DUMPDIR"/tmp
1486 rm -rf "$DUMPDIR"/tmp "$DUMPDIR"/system.img
1487 fi
1488 fi
1489
1490 SRC="$DUMPDIR"
1491 fi
1492
Steve Kondik5bd66602016-07-15 10:39:58 -07001493 if [ "$VENDOR_STATE" -eq "0" ]; then
1494 echo "Cleaning output directory ($OUTPUT_ROOT).."
1495 rm -rf "${OUTPUT_TMP:?}"
1496 mkdir -p "${OUTPUT_TMP:?}"
Jake Whatley9843b322017-01-25 21:49:16 -05001497 if [ -d "$OUTPUT_ROOT" ]; then
1498 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1499 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001500 VENDOR_STATE=1
1501 fi
1502
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001503 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
Steve Kondik5bd66602016-07-15 10:39:58 -07001504
1505 for (( i=1; i<COUNT+1; i++ )); do
1506
Vladimir Oltean8e2de652018-06-24 20:41:30 +03001507 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
Vladimir Olteanb06f3aa2018-06-24 20:38:04 +03001508 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
Vladimir Olteand6391332018-06-24 20:42:01 +03001509 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001510 local OUTPUT_DIR=
1511 local TMP_DIR=
1512 local SRC_FILE=
1513 local DST_FILE=
Vladimir Olteana7d20492019-01-17 03:05:52 +02001514 local IS_PRODUCT_PACKAGE=false
1515
1516 # Note: this relies on the fact that the ${FILELIST[@]} array
1517 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1518 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1519 IS_PRODUCT_PACKAGE=true
1520 fi
Steve Kondik5bd66602016-07-15 10:39:58 -07001521
Vladimir Olteand6391332018-06-24 20:42:01 +03001522 if [ "${SPEC_ARGS}" = "rootfs" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001523 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1524 TMP_DIR="${OUTPUT_TMP}/rootfs"
1525 SRC_FILE="/${SPEC_SRC_FILE}"
1526 DST_FILE="/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001527 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001528 OUTPUT_DIR="${OUTPUT_ROOT}"
1529 TMP_DIR="${OUTPUT_TMP}"
1530 SRC_FILE="/system/${SPEC_SRC_FILE}"
1531 DST_FILE="/system/${SPEC_DST_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001532 fi
1533
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001534 # Strip the file path in the vendor repo of "system", if present
1535 local VENDOR_REPO_FILE="$OUTPUT_DIR/${DST_FILE#/system}"
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001536 local BLOB_DISPLAY_NAME="${DST_FILE#/system/}"
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001537 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001538
Gabriele M58270a32017-11-13 23:15:29 +01001539 # Check pinned files
Vladimir Olteane688cf92019-01-17 02:47:02 +02001540 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Vladimir Olteande985fe2019-01-17 03:07:34 +02001541 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
Gabriele M58270a32017-11-13 23:15:29 +01001542 local KEEP=""
Vladimir Olteande985fe2019-01-17 03:07:34 +02001543 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001544 if [ -f "${VENDOR_REPO_FILE}" ]; then
1545 local PINNED="${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001546 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001547 local PINNED="${TMP_DIR}${DST_FILE#/system}"
Gabriele M58270a32017-11-13 23:15:29 +01001548 fi
1549 if [ -f "$PINNED" ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001550 local TMP_HASH=$(get_hash "${PINNED}")
1551 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
Gabriele M58270a32017-11-13 23:15:29 +01001552 KEEP="1"
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001553 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1554 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
Gabriele M58270a32017-11-13 23:15:29 +01001555 fi
1556 fi
1557 fi
1558 fi
1559
Vladimir Olteana7d20492019-01-17 03:05:52 +02001560 if [ "${KANG}" = false ]; then
1561 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1562 fi
1563
Gabriele M58270a32017-11-13 23:15:29 +01001564 if [ "$KEEP" = "1" ]; then
Vladimir Olteana7d20492019-01-17 03:05:52 +02001565 printf ' + keeping pinned file with hash %s\n' "${HASH}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001566 else
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001567 FOUND=false
1568 # Try Lineage target first.
1569 # Also try to search for files stripped of
1570 # the "/system" prefix, if we're actually extracting
1571 # from a system image.
Vladimir Olteanfe49eae2018-06-25 00:05:56 +03001572 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001573 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${SRC} && {
1574 FOUND=true
1575 break
1576 }
1577 done
1578
1579 if [ "${FOUND}" = false ]; then
Vladimir Oltean724a7bc2019-01-17 03:04:16 +02001580 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
Vladimir Oltean11329372018-10-18 00:44:02 +03001581 continue
Steve Kondik5bd66602016-07-15 10:39:58 -07001582 fi
1583 fi
1584
Vladimir Olteande985fe2019-01-17 03:07:34 +02001585 # Blob fixup pipeline has 2 parts: one that is fixed and
1586 # one that is user-configurable
1587 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1588 # Deodex apk|jar if that's the case
1589 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1590 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "$SRC"
1591 if [ -f "$TMPDIR/classes.dex" ]; then
Rashed Abdel-Tawabd7124972018-03-15 12:55:22 -07001592 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1593 rm "$TMPDIR/classes"*
Vladimir Olteande985fe2019-01-17 03:07:34 +02001594 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001595 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001596 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1597 fix_xml "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001598 fi
Vladimir Olteande985fe2019-01-17 03:07:34 +02001599 # Now run user-supplied fixup function
1600 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1601 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
Steve Kondik5bd66602016-07-15 10:39:58 -07001602
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001603 if [ -f "${VENDOR_REPO_FILE}" ]; then
Vladimir Olteanb5500d72018-06-24 21:06:12 +03001604 local DIR=$(dirname "${VENDOR_REPO_FILE}")
Steve Kondik5bd66602016-07-15 10:39:58 -07001605 local TYPE="${DIR##*/}"
1606 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001607 chmod 755 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001608 else
Vladimir Oltean4daf5592018-06-24 20:46:42 +03001609 chmod 644 "${VENDOR_REPO_FILE}"
Steve Kondik5bd66602016-07-15 10:39:58 -07001610 fi
1611 fi
1612
Vladimir Olteana7d20492019-01-17 03:05:52 +02001613 if [ "${KANG}" = true ]; then
Vladimir Olteande985fe2019-01-17 03:07:34 +02001614 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1615 fi
1616
1617 # Check and print whether the fixup pipeline actually did anything.
1618 # This isn't done right after the fixup pipeline because we want this print
1619 # to come after print_spec above, when in kang mode.
1620 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1621 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1622 # Now sanity-check the spec for this blob.
1623 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1624 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1625 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1626 fi
Vladimir Olteana7d20492019-01-17 03:05:52 +02001627 fi
1628
Steve Kondik5bd66602016-07-15 10:39:58 -07001629 done
1630
1631 # Don't allow failing
1632 set -e
1633}
1634
1635#
Rashed Abdel-Tawab5b97a982019-09-29 01:19:57 -04001636# extract2:
1637#
1638# Positional parameters:
1639# $1: file containing the list of items to extract (aka proprietary-files.txt)
1640#
1641# Non-positional parameters (coming after $2):
1642# --section: selects the portion to parse and extracts from proprietary-files.txt
1643# --kang: if present, this option will activate the printing of hashes for the
1644# extracted blobs. Useful with --section for subsequent pinning of
1645# blobs taken from other origins.
1646#
1647function extract2() {
1648 # Consume positional parameters
1649 local PROPRIETARY_FILES_TXT="$1"; shift
1650 local SECTION=""
1651 local KANG=false
1652
1653 # Consume optional, non-positional parameters
1654 while [ "$#" -gt 0 ]; do
1655 case "$1" in
1656 --adb)
1657 ADB=true
1658 ;;
1659 --system)
1660 SYSTEM_SRC="$2"; shift
1661 ;;
1662 --vendor)
1663 VENDOR_SRC="$2"; shift
1664 ;;
1665 --odm)
1666 ODM_SRC="$2"; shift
1667 ;;
1668 --product)
1669 PRODUCT_SRC="$2"; shift
1670 ;;
1671 -s|--section)
1672 SECTION="$2"; shift
1673 ;;
1674 -k|--kang)
1675 KANG=true
1676 DISABLE_PINNING=1
1677 ;;
1678 esac
1679 shift
1680 done
1681
1682 if [ -z "$ADB" ] || [ -z "$SYSTEM_SRC" && -z "$VENDOR_SRC" && -z "$ODM_SRC" && -z "$PRODUCT_SRC" ]; then
1683 echo "No sources set! You must select --adb or pass paths to partition dumps."
1684 exit 1
1685 fi
1686
1687 if [ -z "$OUTDIR" ]; then
1688 echo "Output dir not set!"
1689 exit 1
1690 fi
1691
1692 parse_file_list "${PROPRIETARY_FILES_TXT}" "${SECTION}"
1693
1694 # Allow failing, so we can try $DEST and/or $FILE
1695 set +e
1696
1697 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} ${PRODUCT_PACKAGES_LIST[@]} )
1698 local HASHLIST=( ${PRODUCT_COPY_FILES_HASHES[@]} ${PRODUCT_PACKAGES_HASHES[@]} )
1699 local FIXUP_HASHLIST=( ${PRODUCT_COPY_FILES_FIXUP_HASHES[@]} ${PRODUCT_PACKAGES_FIXUP_HASHES[@]} )
1700 local PRODUCT_COPY_FILES_COUNT=${#PRODUCT_COPY_FILES_LIST[@]}
1701 local COUNT=${#FILELIST[@]}
1702 local OUTPUT_ROOT="$OMNI_ROOT"/"$OUTDIR"/proprietary
1703 local OUTPUT_TMP="$TMPDIR"/"$OUTDIR"/proprietary
1704
1705 if [ "$ADB" = true ]; then
1706 init_adb_connection
1707 fi
1708
1709 if [ "$VENDOR_STATE" -eq "0" ]; then
1710 echo "Cleaning output directory ($OUTPUT_ROOT).."
1711 rm -rf "${OUTPUT_TMP:?}"
1712 mkdir -p "${OUTPUT_TMP:?}"
1713 if [ -d "$OUTPUT_ROOT" ]; then
1714 mv "${OUTPUT_ROOT:?}/"* "${OUTPUT_TMP:?}/"
1715 fi
1716 VENDOR_STATE=1
1717 fi
1718
1719 echo "Extracting ${COUNT} files in ${PROPRIETARY_FILES_TXT} from ${SRC}:"
1720
1721 for (( i=1; i<COUNT+1; i++ )); do
1722
1723 local SPEC_SRC_FILE=$(src_file "${FILELIST[$i-1]}")
1724 local SPEC_DST_FILE=$(target_file "${FILELIST[$i-1]}")
1725 local SPEC_ARGS=$(target_args "${FILELIST[$i-1]}")
1726 local OUTPUT_DIR=
1727 local TMP_DIR=
1728 local SRC_FILE=
1729 local DST_FILE=
1730 local IS_PRODUCT_PACKAGE=false
1731
1732 # Note: this relies on the fact that the ${FILELIST[@]} array
1733 # contains first ${PRODUCT_COPY_FILES_LIST[@]}, then ${PRODUCT_PACKAGES_LIST[@]}.
1734 if [ "${i}" -gt "${PRODUCT_COPY_FILES_COUNT}" ]; then
1735 IS_PRODUCT_PACKAGE=true
1736 fi
1737
1738 if [ "${SPEC_ARGS}" = "rootfs" ]; then
1739 OUTPUT_DIR="${OUTPUT_ROOT}/rootfs"
1740 TMP_DIR="${OUTPUT_TMP}/rootfs"
1741 else
1742 OUTPUT_DIR="${OUTPUT_ROOT}"
1743 TMP_DIR="${OUTPUT_TMP}"
1744 fi
1745 SRC_FILE="${SPEC_SRC_FILE}"
1746 DST_FILE="${SPEC_DST_FILE}"
1747
1748 local VENDOR_REPO_FILE="$OUTPUT_DIR/${DST_FILE}"
1749 local BLOB_DISPLAY_NAME="${DST_FILE}"
1750 mkdir -p $(dirname "${VENDOR_REPO_FILE}")
1751
1752 # Check pinned files
1753 local HASH="$(echo ${HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1754 local FIXUP_HASH="$(echo ${FIXUP_HASHLIST[$i-1]} | awk '{ print tolower($0); }')"
1755 local KEEP=""
1756 if [ "$DISABLE_PINNING" != "1" ] && [ "$HASH" != "x" ]; then
1757 if [ -f "${VENDOR_REPO_FILE}" ]; then
1758 local PINNED="${VENDOR_REPO_FILE}"
1759 else
1760 local PINNED="${TMP_DIR}${DST_FILE}"
1761 fi
1762 if [ -f "$PINNED" ]; then
1763 local TMP_HASH=$(get_hash "${PINNED}")
1764 if [ "${TMP_HASH}" = "${HASH}" ] || [ "${TMP_HASH}" = "${FIXUP_HASH}" ]; then
1765 KEEP="1"
1766 if [ ! -f "${VENDOR_REPO_FILE}" ]; then
1767 cp -p "$PINNED" "${VENDOR_REPO_FILE}"
1768 fi
1769 fi
1770 fi
1771 fi
1772
1773 if [ "${KANG}" = false ]; then
1774 printf ' - %s\n' "${BLOB_DISPLAY_NAME}"
1775 fi
1776
1777 if [ "$KEEP" = "1" ]; then
1778 printf ' + keeping pinned file with hash %s\n' "${HASH}"
1779 else
1780 FOUND=false
1781 PARTITION_SOURCE_DIR=
1782 # Try Lineage target first.
1783 for CANDIDATE in "${DST_FILE}" "${SRC_FILE}"; do
1784 PARTITION=$(echo "$CANDIDATE" | cut -d/ -f1)
1785 if [ "$PARTITION" = "system" ]; then
1786 PARTITION_SOURCE_DIR="$SYSTEM_SRC"
1787 elif [ "$PARTITION" = "vendor" ]; then
1788 PARTITION_SOURCE_DIR="$VENDOR_SRC"
1789 elif [ "$PARTITION" = "product" ]; then
1790 PARTITION_SOURCE_DIR="$PRODUCT_SRC"
1791 elif [ "$PARTITION" = "odm" ]; then
1792 PARTITION_SOURCE_DIR="$ODM_SRC"
1793 fi
1794 CANDIDATE_RELATIVE_NAME=$(echo "$CANDIDATE" | cut -d/ -f2-)
1795 get_file ${CANDIDATE_RELATIVE_NAME} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1796 FOUND=true
1797 break
1798 }
1799 # Search with the full system/ prefix if the file was not found on the system partition
1800 # because we may be searching in a mounted system-as-root system.img
1801 if [[ "${FOUND}" = false && "$PARTITION" = "system" ]]; then
1802 get_file ${CANDIDATE} ${VENDOR_REPO_FILE} ${PARTITION_SOURCE_DIR} && {
1803 FOUND=true
1804 break
1805 }
1806 fi
1807 done
1808
1809 if [ -z "${PARTITION_SOURCE_DIR}" ]; then
1810 echo "$CANDIDATE has no preceeding partition path. Prepend system/, vendor/, product/, or odm/ to this entry."
1811 fi
1812
1813 if [ "${FOUND}" = false ]; then
1814 printf ' !! %s: file not found in source\n' "${BLOB_DISPLAY_NAME}"
1815 continue
1816 fi
1817 fi
1818
1819 # Blob fixup pipeline has 2 parts: one that is fixed and
1820 # one that is user-configurable
1821 local PRE_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1822 # Deodex apk|jar if that's the case
1823 if [[ "$FULLY_DEODEXED" -ne "1" && "${VENDOR_REPO_FILE}" =~ .(apk|jar)$ ]]; then
1824 oat2dex "${VENDOR_REPO_FILE}" "${SRC_FILE}" "${SYSTEM_SRC}"
1825 if [ -f "$TMPDIR/classes.dex" ]; then
1826 zip -gjq "${VENDOR_REPO_FILE}" "$TMPDIR/classes"*
1827 rm "$TMPDIR/classes"*
1828 printf ' (updated %s from odex files)\n' "${SRC_FILE}"
1829 fi
1830 elif [[ "${VENDOR_REPO_FILE}" =~ .xml$ ]]; then
1831 fix_xml "${VENDOR_REPO_FILE}"
1832 fi
1833 # Now run user-supplied fixup function
1834 blob_fixup "${BLOB_DISPLAY_NAME}" "${VENDOR_REPO_FILE}"
1835 local POST_FIXUP_HASH=$(get_hash ${VENDOR_REPO_FILE})
1836
1837 if [ -f "${VENDOR_REPO_FILE}" ]; then
1838 local DIR=$(dirname "${VENDOR_REPO_FILE}")
1839 local TYPE="${DIR##*/}"
1840 if [ "$TYPE" = "bin" -o "$TYPE" = "sbin" ]; then
1841 chmod 755 "${VENDOR_REPO_FILE}"
1842 else
1843 chmod 644 "${VENDOR_REPO_FILE}"
1844 fi
1845 fi
1846
1847 if [ "${KANG}" = true ]; then
1848 print_spec "${IS_PRODUCT_PACKAGE}" "${SPEC_SRC_FILE}" "${SPEC_DST_FILE}" "${SPEC_ARGS}" "${PRE_FIXUP_HASH}" "${POST_FIXUP_HASH}"
1849 fi
1850
1851 # Check and print whether the fixup pipeline actually did anything.
1852 # This isn't done right after the fixup pipeline because we want this print
1853 # to come after print_spec above, when in kang mode.
1854 if [ "${PRE_FIXUP_HASH}" != "${POST_FIXUP_HASH}" ]; then
1855 printf " + Fixed up %s\n" "${BLOB_DISPLAY_NAME}"
1856 # Now sanity-check the spec for this blob.
1857 if [ "${KANG}" = false ] && [ "${FIXUP_HASH}" = "x" ] && [ "${HASH}" != "x" ]; then
1858 printf "WARNING: The %s file was fixed up, but it is pinned.\n" ${BLOB_DISPLAY_NAME}
1859 printf "This is a mistake and you want to either remove the hash completely, or add an extra one.\n"
1860 fi
1861 fi
1862
1863 done
1864
1865 # Don't allow failing
1866 set -e
1867}
1868
1869#
Steve Kondik5bd66602016-07-15 10:39:58 -07001870# extract_firmware:
1871#
1872# $1: file containing the list of items to extract
1873# $2: path to extracted radio folder
1874#
1875function extract_firmware() {
1876 if [ -z "$OUTDIR" ]; then
1877 echo "Output dir not set!"
1878 exit 1
1879 fi
1880
1881 parse_file_list "$1"
1882
1883 # Don't allow failing
1884 set -e
1885
1886 local FILELIST=( ${PRODUCT_COPY_FILES_LIST[@]} )
1887 local COUNT=${#FILELIST[@]}
1888 local SRC="$2"
theimpulson9a911af2019-08-14 03:25:12 +00001889 local OUTPUT_DIR="$OMNI_ROOT"/"$OUTDIR"/radio
Steve Kondik5bd66602016-07-15 10:39:58 -07001890
1891 if [ "$VENDOR_RADIO_STATE" -eq "0" ]; then
1892 echo "Cleaning firmware output directory ($OUTPUT_DIR).."
1893 rm -rf "${OUTPUT_DIR:?}/"*
1894 VENDOR_RADIO_STATE=1
1895 fi
1896
1897 echo "Extracting $COUNT files in $1 from $SRC:"
1898
1899 for (( i=1; i<COUNT+1; i++ )); do
1900 local FILE="${FILELIST[$i-1]}"
1901 printf ' - %s \n' "/radio/$FILE"
1902
1903 if [ ! -d "$OUTPUT_DIR" ]; then
1904 mkdir -p "$OUTPUT_DIR"
1905 fi
1906 cp "$SRC/$FILE" "$OUTPUT_DIR/$FILE"
1907 chmod 644 "$OUTPUT_DIR/$FILE"
1908 done
1909}
Rashed Abdel-Tawab841c6e82019-03-29 20:07:25 -07001910
1911function extract_img_data() {
1912 local image_file="$1"
1913 local out_dir="$2"
1914 local logFile="$TMPDIR/debugfs.log"
1915
1916 if [ ! -d "$out_dir" ]; then
1917 mkdir -p "$out_dir"
1918 fi
1919
1920 if [[ "$HOST_OS" == "Darwin" ]]; then
1921 debugfs -R "rdump / \"$out_dir\"" "$image_file" &> "$logFile" || {
1922 echo "[-] Failed to extract data from '$image_file'"
1923 abort 1
1924 }
1925 else
1926 debugfs -R 'ls -p' "$image_file" 2>/dev/null | cut -d '/' -f6 | while read -r entry
1927 do
1928 debugfs -R "rdump \"$entry\" \"$out_dir\"" "$image_file" >> "$logFile" 2>&1 || {
1929 echo "[-] Failed to extract data from '$image_file'"
1930 abort 1
1931 }
1932 done
1933 fi
1934
1935 local symlink_err="rdump: Attempt to read block from filesystem resulted in short read while reading symlink"
1936 if grep -Fq "$symlink_err" "$logFile"; then
1937 echo "[-] Symlinks have not been properly processed from $image_file"
1938 echo "[!] If you don't have a compatible debugfs version, modify 'execute-all.sh' to disable 'USE_DEBUGFS' flag"
1939 abort 1
1940 fi
1941}
1942
1943declare -ra VENDOR_SKIP_FILES=(
1944 "bin/toybox_vendor"
1945 "bin/toolbox"
1946 "bin/grep"
1947 "build.prop"
1948 "compatibility_matrix.xml"
1949 "default.prop"
1950 "etc/NOTICE.xml.gz"
1951 "etc/vintf/compatibility_matrix.xml"
1952 "etc/vintf/manifest.xml"
1953 "etc/wifi/wpa_supplicant.conf"
1954 "manifest.xml"
1955 "overlay/DisplayCutoutEmulationCorner/DisplayCutoutEmulationCornerOverlay.apk"
1956 "overlay/DisplayCutoutEmulationDouble/DisplayCutoutEmulationDoubleOverlay.apk"
1957 "overlay/DisplayCutoutEmulationTall/DisplayCutoutEmulationTallOverlay.apk"
1958 "overlay/DisplayCutoutNoCutout/NoCutoutOverlay.apk"
1959 "overlay/framework-res__auto_generated_rro.apk"
1960 "overlay/SysuiDarkTheme/SysuiDarkThemeOverlay.apk"
1961)
1962
1963function array_contains() {
1964 local element
1965 for element in "${@:2}"; do [[ "$element" == "$1" ]] && return 0; done
1966 return 1
1967}
1968
1969function generate_prop_list_from_image() {
1970 local image_file="$1"
1971 local image_dir="$TMPDIR/image-temp"
1972 local output_list="$2"
1973 local output_list_tmp="$TMPDIR/_proprietary-blobs.txt"
1974 local -n skipped_vendor_files="$3"
1975
1976 extract_img_data "$image_file" "$image_dir"
1977
1978 find "$image_dir" -not -type d | sed "s#^$image_dir/##" | while read -r FILE
1979 do
1980 # Skip VENDOR_SKIP_FILES since it will be re-generated at build time
1981 if array_contains "$FILE" "${VENDOR_SKIP_FILES[@]}"; then
1982 continue
1983 fi
1984 # Skip device defined skipped files since they will be re-generated at build time
1985 if array_contains "$FILE" "${skipped_vendor_files[@]}"; then
1986 continue
1987 fi
1988 if suffix_match_file ".apk" "$FILE" ; then
1989 echo "-vendor/$FILE" >> "$output_list_tmp"
1990 else
1991 echo "vendor/$FILE" >> "$output_list_tmp"
1992 fi
1993 done
1994
1995 # Sort merged file with all lists
1996 sort -u "$output_list_tmp" > "$output_list"
1997
1998 # Clean-up
1999 rm -f "$output_list_tmp"
2000}