blob: 4a8727596ad7f324ae668713021bc5185d2d82f4 [file] [log] [blame]
Robin Pengc2b5ca92021-02-23 20:00:28 +08001#
2# Copyright (C) 2019 The Android Open-Source Project
3#
4# Licensed under the Apache License, Version 2.0 (the "License");
5# you may not use this file except in compliance with the License.
6# You may obtain a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS,
12# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13# See the License for the specific language governing permissions and
14# limitations under the License.
15#
16include build/make/target/board/BoardConfigMainlineCommon.mk
Tianjiea76d1042021-03-12 11:42:05 -080017include build/make/target/board/BoardConfigPixelCommon.mk
Robin Pengc2b5ca92021-02-23 20:00:28 +080018
19# Should be uncommented after fixing vndk-sp violation is fixed.
20PRODUCT_FULL_TREBLE_OVERRIDE := true
21
22# HACK : To fix up after bring up multimedia devices.
23TARGET_SOC := gs101
24
25TARGET_SOC_NAME := google
26
27USES_DEVICE_GOOGLE_GS101 := true
28
29TARGET_ARCH := arm64
Philip Cuadra0111d392021-06-03 10:25:34 -070030TARGET_ARCH_VARIANT := armv8-2a
Robin Pengc2b5ca92021-02-23 20:00:28 +080031TARGET_CPU_ABI := arm64-v8a
Philip Cuadra0111d392021-06-03 10:25:34 -070032TARGET_CPU_VARIANT := cortex-a55
33TARGET_CPU_VARIANT_RUNTIME := cortex-a55
Robin Pengc2b5ca92021-02-23 20:00:28 +080034
35ifeq (,$(filter %_64,$(TARGET_PRODUCT)))
36TARGET_2ND_ARCH := arm
37TARGET_2ND_ARCH_VARIANT := armv8-a
38TARGET_2ND_CPU_ABI := armeabi-v7a
39TARGET_2ND_CPU_ABI2 := armeabi
40TARGET_2ND_CPU_VARIANT := generic
41TARGET_2ND_CPU_VARIANT_RUNTIME := cortex-a53
42endif
43
Minchan Kim5d135292021-03-17 15:13:38 -070044BOARD_KERNEL_CMDLINE += dyndbg=\"func alloc_contig_dump_pages +p\"
Oleg Matcovschi9963cf02021-03-23 14:03:45 -070045BOARD_KERNEL_CMDLINE += earlycon=exynos4210,0x10A00000 console=ttySAC0,115200 androidboot.console=ttySAC0 printk.devkmsg=on
Minchan Kim3623b572021-03-29 13:18:03 -070046BOARD_KERNEL_CMDLINE += cma_sysfs.experimental=Y
Minchan Kimc9f14082021-05-07 13:00:29 -070047BOARD_KERNEL_CMDLINE += stack_depot_disable=off page_pinner=on
Martin Liu5bcfdac2021-11-08 22:09:01 +080048BOARD_KERNEL_CMDLINE += swiotlb=noforce
Daniel Mentzc37a73b2021-04-08 20:24:38 -070049BOARD_BOOTCONFIG += androidboot.boot_devices=14700000.ufs
Robin Pengc2b5ca92021-02-23 20:00:28 +080050
51TARGET_NO_BOOTLOADER := true
Jason Chiud037bee2021-09-29 07:17:17 +000052TARGET_NO_RADIOIMAGE := true
Petri Gynther96a90bd2021-10-01 02:26:57 +000053ifneq (,$(filter userdebug eng,$(TARGET_BUILD_VARIANT)))
54BOARD_PREBUILT_BOOTIMAGE := $(wildcard $(TARGET_KERNEL_DIR)/boot.img)
55else
56BOARD_PREBUILT_BOOTIMAGE := $(wildcard $(TARGET_KERNEL_DIR)/boot-user.img)
57endif
58ifneq (,$(BOARD_PREBUILT_BOOTIMAGE))
59TARGET_NO_KERNEL := true
60else
61TARGET_NO_KERNEL := false
62endif
Robin Pengc2b5ca92021-02-23 20:00:28 +080063BOARD_USES_GENERIC_KERNEL_IMAGE := true
64BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT := true
65BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT := true
66TARGET_RECOVERY_WIPE := device/google/gs101/conf/recovery.wipe
Eric Biggersf739cf62021-08-30 14:09:06 -070067
68# This is the fstab file that will be included in the recovery image. Note that
69# recovery doesn't care about the encryption settings, so it doesn't matter
70# whether we use the normal or the fips fstab here.
71#
72# Since this is a generated file, it's necessary to use intermediates-dir-for in
73# order to refer to it correctly. And since intermediates-dir-for isn't defined
74# yet when this file is included, it's necessary to use a deferred variable
75# assignment ( = ) rather than an immediate variable assignment ( := ).
76TARGET_RECOVERY_FSTAB = $(call intermediates-dir-for,ETC,fstab.gs101)/fstab.gs101
77
Robin Pengc2b5ca92021-02-23 20:00:28 +080078TARGET_RECOVERY_PIXEL_FORMAT := ABGR_8888
79TARGET_RECOVERY_UI_MARGIN_HEIGHT := 165
80TARGET_RECOVERY_UI_LIB := \
81 librecovery_ui_pixel \
82 libfstab
83
84AB_OTA_UPDATER := true
85
86AB_OTA_PARTITIONS += \
87 system \
88 system_ext \
89 product \
90 vbmeta_system
91
92ifneq ($(PRODUCT_BUILD_BOOT_IMAGE),false)
93AB_OTA_PARTITIONS += boot
94endif
95ifneq ($(PRODUCT_BUILD_VENDOR_BOOT_IMAGE),false)
96AB_OTA_PARTITIONS += vendor_boot
97AB_OTA_PARTITIONS += dtbo
98endif
99ifneq ($(PRODUCT_BUILD_VBMETA_IMAGE),false)
100AB_OTA_PARTITIONS += vbmeta
101endif
Pierre-Clément Tosi871071a2021-12-15 14:37:27 +0100102ifneq ($(PRODUCT_BUILD_PVMFW_IMAGE),false)
103AB_OTA_PARTITIONS += pvmfw
104endif
Robin Pengc2b5ca92021-02-23 20:00:28 +0800105
106# EMULATOR common modules
107BOARD_EMULATOR_COMMON_MODULES := liblight
108
109OVERRIDE_RS_DRIVER := libRSDriverArm.so
110BOARD_EGL_CFG := device/google/gs101/conf/egl.cfg
111#BOARD_USES_HGL := true
112USE_OPENGL_RENDERER := true
113NUM_FRAMEBUFFER_SURFACE_BUFFERS := 3
114BOARD_USES_EXYNOS5_COMMON_GRALLOC := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800115BOARD_USES_ALIGN_RESTRICTION := false
Sean Callanan13c4abd2021-03-25 18:27:04 -0700116BOARD_USES_GRALLOC_ION_SYNC := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800117
118# This should be the same value as USE_SWIFTSHADER in device.mk
119BOARD_USES_SWIFTSHADER := false
120
121# Gralloc4
Robin Pengc2b5ca92021-02-23 20:00:28 +0800122ifeq ($(BOARD_USES_SWIFTSHADER),true)
Sasha Smundakb44a6622021-12-15 10:00:29 -0800123$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,true)
124$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,false)
125$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,false)
126$(call soong_config_set,arm_gralloc,gralloc_init_afbc,false)
127$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,false)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800128else
Sasha Smundakb44a6622021-12-15 10:00:29 -0800129$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,false)
130$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,true)
131$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,true)
132$(call soong_config_set,arm_gralloc,gralloc_init_afbc,true)
133$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800134endif # ifeq ($(BOARD_USES_SWIFTSHADER),true)
Sasha Smundakb44a6622021-12-15 10:00:29 -0800135$(call soong_config_set,arm_gralloc,gralloc_ion_sync_on_lock,$(BOARD_USES_GRALLOC_ION_SYNC))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800136
137# Graphics
138#BOARD_USES_EXYNOS_DATASPACE_FEATURE := true
139
Robin Pengc2b5ca92021-02-23 20:00:28 +0800140# Enable chain partition for system.
141BOARD_AVB_VBMETA_SYSTEM := system system_ext product
142BOARD_AVB_VBMETA_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
143BOARD_AVB_VBMETA_SYSTEM_ALGORITHM := SHA256_RSA2048
144BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
145BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION := 1
146
Will McVickerb5b92ea2021-01-26 12:37:06 -0800147# Enable chained vbmeta for boot images
148BOARD_AVB_BOOT_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
149BOARD_AVB_BOOT_ALGORITHM := SHA256_RSA2048
150BOARD_AVB_BOOT_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
151BOARD_AVB_BOOT_ROLLBACK_INDEX_LOCATION := 2
152
Robin Pengc2b5ca92021-02-23 20:00:28 +0800153TARGET_USERIMAGES_USE_EXT4 := true
154TARGET_USERIMAGES_USE_F2FS := true
155BOARD_USERDATAIMAGE_PARTITION_SIZE := 11796480000
156BOARD_USERDATAIMAGE_FILE_SYSTEM_TYPE := f2fs
157PRODUCT_FS_COMPRESSION := 1
158BOARD_FLASH_BLOCK_SIZE := 4096
159BOARD_MOUNT_SDCARD_RW := true
160
161# product.img
162BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := ext4
163TARGET_COPY_OUT_PRODUCT := product
164
165# system_ext.img
166BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := ext4
167TARGET_COPY_OUT_SYSTEM_EXT := system_ext
168
169########################
170# Video Codec
171########################
172# 1. Exynos C2
173BOARD_USE_CSC_FILTER := false
174BOARD_USE_DEC_SW_CSC := true
175BOARD_USE_ENC_SW_CSC := true
176BOARD_SUPPORT_MFC_ENC_RGB := true
Charlie Chen935a1dd2021-03-16 16:26:13 +0800177BOARD_USE_BLOB_ALLOCATOR := false
Robin Pengc2b5ca92021-02-23 20:00:28 +0800178########################
179
180BOARD_SUPER_PARTITION_SIZE := 8531214336
181BOARD_SUPER_PARTITION_GROUPS := google_dynamic_partitions
Pat Tjin977ea342021-03-11 23:20:27 -0800182# Set size to BOARD_SUPER_PARTITION_SIZE - overhead (4MiB) (b/182237294)
183BOARD_GOOGLE_DYNAMIC_PARTITIONS_SIZE := 8527020032
Robin Pengc2b5ca92021-02-23 20:00:28 +0800184BOARD_GOOGLE_DYNAMIC_PARTITIONS_PARTITION_LIST := \
185 system \
186 system_ext \
187 product \
Daniel Mentzfc05a5f2021-03-03 14:44:17 -0800188 vendor \
189 vendor_dlkm
Robin Pengc2b5ca92021-02-23 20:00:28 +0800190
191# Set error limit to BOARD_SUPER_PARTITON_SIZE - 500MB
192BOARD_SUPER_PARTITION_ERROR_LIMIT := 8006926336
193
194#
195# AUDIO & VOICE
196#
197BOARD_USES_GENERIC_AUDIO := true
198
Sasha Smundakb44a6622021-12-15 10:00:29 -0800199$(call soong_config_set,aoc_audio_func,ext_hidl,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800200
201ifneq (,$(filter userdebug eng, $(TARGET_BUILD_VARIANT)))
Sasha Smundakb44a6622021-12-15 10:00:29 -0800202$(call soong_config_set,aoc_audio_func,dump_usecase_data,true)
203$(call soong_config_set,aoc_audio_func,hal_socket_control,true)
204$(call soong_config_set,aoc_audio_func,record_tunning_keys,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800205endif
206
Carter Hsu977c44c2021-05-12 17:02:05 +0800207ifneq (,$(filter aosp_%,$(TARGET_PRODUCT)))
Sasha Smundakb44a6622021-12-15 10:00:29 -0800208$(call soong_config_set,aoc_audio_func,aosp_build,true)
Carter Hsu977c44c2021-05-12 17:02:05 +0800209endif
210
Sasha Smundakb44a6622021-12-15 10:00:29 -0800211$(call soong_config_set,haptics,actuator_model,$(ACTUATOR_MODEL))
Vince Leung58180f02021-08-27 03:50:21 +0000212
Robin Pengc2b5ca92021-02-23 20:00:28 +0800213# Primary AudioHAL Configuration
214#BOARD_USE_COMMON_AUDIOHAL := true
215#BOARD_USE_CALLIOPE_AUDIOHAL := false
216#BOARD_USE_AUDIOHAL := true
217
218# Compress Offload Configuration
219#BOARD_USE_OFFLOAD_AUDIO := true
220#BOARD_USE_OFFLOAD_EFFECT := false
221
222# SoundTriggerHAL Configuration
223#BOARD_USE_SOUNDTRIGGER_HAL := false
224
225# HWComposer
226BOARD_HWC_VERSION := libhwc2.1
227TARGET_RUNNING_WITHOUT_SYNC_FRAMEWORK := false
228BOARD_HDMI_INCAPABLE := true
229TARGET_USES_HWC2 := true
230HWC_SKIP_VALIDATE := true
231HWC_SUPPORT_RENDER_INTENT := true
232HWC_SUPPORT_COLOR_TRANSFORM := true
233#BOARD_USES_DISPLAYPORT := true
234# if AFBC is enabled, must set ro.vendor.ddk.set.afbc=1
235BOARD_USES_EXYNOS_AFBC_FEATURE := true
236#BOARD_USES_HDRUI_GLES_CONVERSION := true
237
238BOARD_LIBACRYL_DEFAULT_COMPOSITOR := fimg2d_gs101
239BOARD_LIBACRYL_G2D_HDR_PLUGIN := libacryl_hdr_plugin
240
241# HWCServices
242BOARD_USES_HWC_SERVICES := true
243
244# WiFiDisplay
245# BOARD_USES_VIRTUAL_DISPLAY := true
246# BOARD_USES_VDS_EXYNOS_HWC := true
247# BOARD_USES_WIFI_DISPLAY:= true
248# BOARD_USES_EGL_SURFACE_FOR_COMPOSITION_MIXED := true
249# BOARD_USES_VDS_YUV420SPM := true
250# BOARD_USES_VDS_OTHERFORMAT := true
251# BOARD_USES_VDS_DEBUG_FLAG := true
252# BOARD_USES_DISABLE_COMPOSITIONTYPE_GLES := true
253# BOARD_USES_SECURE_ENCODER_ONLY := true
254# BOARD_USES_TSMUX := true
255
256# SCALER
257BOARD_USES_DEFAULT_CSC_HW_SCALER := true
258BOARD_DEFAULT_CSC_HW_SCALER := 4
259BOARD_USES_SCALER_M2M1SHOT := true
260
261# Device Tree
262BOARD_USES_DT := true
263BOARD_INCLUDE_DTB_IN_BOOTIMG := true
264BOARD_PREBUILT_DTBIMAGE_DIR := $(TARGET_KERNEL_DIR)
265BOARD_PREBUILT_DTBOIMAGE := $(BOARD_PREBUILT_DTBIMAGE_DIR)/dtbo.img
266
267# PLATFORM LOG
268TARGET_USES_LOGD := true
269
270# LIBHWJPEG
271#TARGET_USES_UNIVERSAL_LIBHWJPEG := true
272#LIBHWJPEG_HWSCALER_ID := 0
273
274#Keymaster
275#BOARD_USES_KEYMASTER_VER1 := true
276
277#FMP
278#BOARD_USES_FMP_DM_CRYPT := true
279#BOARD_USES_FMP_FSCRYPTO := true
280BOARD_USES_METADATA_PARTITION := true
281
Robin Pengc2b5ca92021-02-23 20:00:28 +0800282# SKIA
283#BOARD_USES_SKIA_MULTITHREADING := true
284#BOARD_USES_FIMGAPI_V5X := true
285
286# SECCOMP Policy
287BOARD_SECCOMP_POLICY = device/google/gs101/seccomp_policy
288
289#CURL
290BOARD_USES_CURL := true
291
292# Sensor HAL
293BOARD_USES_EXYNOS_SENSORS_DUMMY := true
294
295# VISION
296# Exynos vision framework (EVF)
297#TARGET_USES_EVF := true
298# HW acceleration
299#TARGET_USES_VPU_KERNEL := true
300#TARGET_USES_SCORE_KERNEL := true
301#TARGET_USES_CL_KERNEL := false
302
303# exynos RIL
304TARGET_EXYNOS_RIL_SOURCE := true
305ENABLE_VENDOR_RIL_SERVICE := true
306
307# GNSS
308# BOARD_USES_EXYNOS_GNSS_DUMMY := true
309
310# Bluetooth defines
311# TODO(b/123695868): Remove the need for this
312BOARD_BLUETOOTH_BDROID_BUILDCFG_INCLUDE_DIR := \
313 build/make/target/board/mainline_arm64/bluetooth
314
Robin Pengc2b5ca92021-02-23 20:00:28 +0800315#VNDK
316BOARD_PROPERTY_OVERRIDES_SPLIT_ENABLED := true
317BOARD_VNDK_VERSION := current
318
319# H/W align restriction of MM IPs
320BOARD_EXYNOS_S10B_FORMAT_ALIGN := 64
321
Robin Pengc2b5ca92021-02-23 20:00:28 +0800322# NeuralNetworks
323GPU_SOURCE_PRESENT := $(wildcard vendor/arm/mali/valhall)
linjoey3097b782021-05-26 11:24:26 +0800324GPU_PREBUILD_PRESENT := $(wildcard vendor/google_devices/gs101/prebuilts/gpu/libs)
Sasha Smundak70f028e2021-09-02 11:29:01 -0700325ifneq (,$(strip $(GPU_SOURCE_PRESENT) $(GPU_PREBUILD_PRESENT)))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800326ARMNN_COMPUTE_CL_ENABLE := 1
327else
328ARMNN_COMPUTE_CL_ENABLE := 0
329endif
330ARMNN_COMPUTE_NEON_ENABLE := 1
331
332# Boot.img
333BOARD_RAMDISK_USE_LZ4 := true
334#BOARD_KERNEL_BASE := 0x80000000
335#BOARD_KERNEL_PAGESIZE := 2048
336#BOARD_KERNEL_OFFSET := 0x80000
337#BOARD_RAMDISK_OFFSET := 0x4000000
Daniel Mentzc37a73b2021-04-08 20:24:38 -0700338BOARD_BOOT_HEADER_VERSION := 4
Robin Pengc2b5ca92021-02-23 20:00:28 +0800339BOARD_MKBOOTIMG_ARGS += --header_version $(BOARD_BOOT_HEADER_VERSION)
340
Daniel Mentzc37a73b2021-04-08 20:24:38 -0700341BOARD_VENDOR_RAMDISK_FRAGMENTS := dlkm
342BOARD_VENDOR_RAMDISK_FRAGMENT.dlkm.KERNEL_MODULE_DIRS := top
343
Robin Pengc2b5ca92021-02-23 20:00:28 +0800344# Enable AVB2.0
345BOARD_AVB_ENABLE := true
346BOARD_BOOTIMAGE_PARTITION_SIZE := 0x04000000
347BOARD_VENDOR_BOOTIMAGE_PARTITION_SIZE := 0x04000000
348BOARD_DTBOIMG_PARTITION_SIZE := 0x01000000
349
350# System As Root
351BOARD_BUILD_SYSTEM_ROOT_IMAGE := false
352
Petri Gynther3c5da8c2021-03-07 01:19:46 -0800353# Vendor ramdisk image for kernel development
354BOARD_BUILD_VENDOR_RAMDISK_IMAGE := true
355
Daniel Mentz24b12e22021-05-13 17:26:39 -0700356BOARD_VENDOR_KERNEL_MODULES_BLOCKLIST_FILE := device/google/gs101/vendor_dlkm.blocklist
357
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700358KERNEL_MODULE_DIR := $(TARGET_KERNEL_DIR)
359KERNEL_MODULES := $(wildcard $(KERNEL_MODULE_DIR)/*.ko)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800360
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700361BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD := $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_boot.modules.load))
362ifndef BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD
363$(error vendor_boot.modules.load not found or empty)
364endif
365BOARD_VENDOR_RAMDISK_KERNEL_MODULES := $(addprefix $(KERNEL_MODULE_DIR)/, $(notdir $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD)))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800366
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700367BOARD_VENDOR_KERNEL_MODULES_LOAD := $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_dlkm.modules.load))
368ifndef BOARD_VENDOR_KERNEL_MODULES_LOAD
369$(error vendor_dlkm.modules.load not found or empty)
370endif
371BOARD_VENDOR_KERNEL_MODULES := $(KERNEL_MODULES)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800372
373# Using BUILD_COPY_HEADERS
374BUILD_BROKEN_USES_BUILD_COPY_HEADERS := true
375
376include device/google/gs101-sepolicy/gs101-sepolicy.mk
Robin Pengc2b5ca92021-02-23 20:00:28 +0800377
378# Battery options
379BOARD_KERNEL_CMDLINE += at24.write_timeout=100
J. Aviladf9dc5c2021-04-12 18:22:36 +0000380
381# Enable larger logbuf
382BOARD_KERNEL_CMDLINE += log_buf_len=1024K
Jeffrey Carlyle15d83482021-06-15 08:26:29 -0700383
David Brazdilae3c59f2021-10-12 16:09:56 +0000384# Protected VM firmware
David Brazdilae3c59f2021-10-12 16:09:56 +0000385BOARD_PVMFWIMAGE_PARTITION_SIZE := 0x00100000
David Brazdilae3c59f2021-10-12 16:09:56 +0000386
Jeffrey Carlyle15d83482021-06-15 08:26:29 -0700387-include vendor/google_devices/gs101/proprietary/BoardConfigVendor.mk