blob: 3a39946eaa20733878c92e4890c49f1d07d126c0 [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
Robin Pengc2b5ca92021-02-23 20:00:28 +080019# HACK : To fix up after bring up multimedia devices.
20TARGET_SOC := gs101
21
22TARGET_SOC_NAME := google
23
24USES_DEVICE_GOOGLE_GS101 := true
kellyhung47aaa4b2024-10-22 10:19:45 +000025$(call soong_config_set,CitadelProvision,target_soc,gs101)
Robin Pengc2b5ca92021-02-23 20:00:28 +080026
27TARGET_ARCH := arm64
Philip Cuadra0111d392021-06-03 10:25:34 -070028TARGET_ARCH_VARIANT := armv8-2a
Robin Pengc2b5ca92021-02-23 20:00:28 +080029TARGET_CPU_ABI := arm64-v8a
Philip Cuadra0111d392021-06-03 10:25:34 -070030TARGET_CPU_VARIANT := cortex-a55
Robin Pengc2b5ca92021-02-23 20:00:28 +080031
Gina Kod8a98052022-03-14 18:26:30 +000032DEVICE_IS_64BIT_ONLY ?= $(if $(filter %_64,$(TARGET_PRODUCT)),true,false)
Gina Ko18bd11a2022-02-25 17:05:22 -080033
34ifneq ($(DEVICE_IS_64BIT_ONLY),true)
Robin Pengc2b5ca92021-02-23 20:00:28 +080035TARGET_2ND_ARCH := arm
36TARGET_2ND_ARCH_VARIANT := armv8-a
37TARGET_2ND_CPU_ABI := armeabi-v7a
38TARGET_2ND_CPU_ABI2 := armeabi
39TARGET_2ND_CPU_VARIANT := generic
40TARGET_2ND_CPU_VARIANT_RUNTIME := cortex-a53
41endif
42
Minchan Kim5d135292021-03-17 15:13:38 -070043BOARD_KERNEL_CMDLINE += dyndbg=\"func alloc_contig_dump_pages +p\"
Oleg Matcovschi9963cf02021-03-23 14:03:45 -070044BOARD_KERNEL_CMDLINE += earlycon=exynos4210,0x10A00000 console=ttySAC0,115200 androidboot.console=ttySAC0 printk.devkmsg=on
Minchan Kim3623b572021-03-29 13:18:03 -070045BOARD_KERNEL_CMDLINE += cma_sysfs.experimental=Y
Qais Yousef9adfff42024-08-12 14:31:07 +000046BOARD_KERNEL_CMDLINE += rcupdate.rcu_expedited=1 rcu_nocbs=all rcutree.enable_rcu_lazy
Martin Liu5bcfdac2021-11-08 22:09:01 +080047BOARD_KERNEL_CMDLINE += swiotlb=noforce
Robin Hsu60ef8d62024-10-14 02:50:00 +000048BOARD_KERNEL_CMDLINE += cgroup.memory=nokmem
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 +000053BOARD_PREBUILT_BOOTIMAGE := $(wildcard $(TARGET_KERNEL_DIR)/boot.img)
Petri Gynther96a90bd2021-10-01 02:26:57 +000054ifneq (,$(BOARD_PREBUILT_BOOTIMAGE))
55TARGET_NO_KERNEL := true
56else
57TARGET_NO_KERNEL := false
58endif
Robin Pengc2b5ca92021-02-23 20:00:28 +080059BOARD_USES_GENERIC_KERNEL_IMAGE := true
60BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT := true
61BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT := true
62TARGET_RECOVERY_WIPE := device/google/gs101/conf/recovery.wipe
Eric Biggersf739cf62021-08-30 14:09:06 -070063
64# This is the fstab file that will be included in the recovery image. Note that
65# recovery doesn't care about the encryption settings, so it doesn't matter
66# whether we use the normal or the fips fstab here.
Cole Faust23a4d7b2022-01-05 14:44:44 -080067TARGET_RECOVERY_FSTAB_GENRULE = gen_fstab.gs101
Eric Biggersf739cf62021-08-30 14:09:06 -070068
Robin Pengc2b5ca92021-02-23 20:00:28 +080069TARGET_RECOVERY_PIXEL_FORMAT := ABGR_8888
70TARGET_RECOVERY_UI_MARGIN_HEIGHT := 165
71TARGET_RECOVERY_UI_LIB := \
Nelson Lic3aac002024-11-26 08:44:48 +000072 //hardware/google/pixel/recovery:librecovery_ui_pixel \
Robin Pengc2b5ca92021-02-23 20:00:28 +080073 libfstab
74
75AB_OTA_UPDATER := true
76
77AB_OTA_PARTITIONS += \
78 system \
79 system_ext \
80 product \
81 vbmeta_system
82
83ifneq ($(PRODUCT_BUILD_BOOT_IMAGE),false)
84AB_OTA_PARTITIONS += boot
85endif
86ifneq ($(PRODUCT_BUILD_VENDOR_BOOT_IMAGE),false)
87AB_OTA_PARTITIONS += vendor_boot
88AB_OTA_PARTITIONS += dtbo
89endif
90ifneq ($(PRODUCT_BUILD_VBMETA_IMAGE),false)
91AB_OTA_PARTITIONS += vbmeta
92endif
93
94# EMULATOR common modules
95BOARD_EMULATOR_COMMON_MODULES := liblight
96
97OVERRIDE_RS_DRIVER := libRSDriverArm.so
98BOARD_EGL_CFG := device/google/gs101/conf/egl.cfg
99#BOARD_USES_HGL := true
100USE_OPENGL_RENDERER := true
101NUM_FRAMEBUFFER_SURFACE_BUFFERS := 3
102BOARD_USES_EXYNOS5_COMMON_GRALLOC := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800103BOARD_USES_ALIGN_RESTRICTION := false
Sean Callanan13c4abd2021-03-25 18:27:04 -0700104BOARD_USES_GRALLOC_ION_SYNC := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800105
106# This should be the same value as USE_SWIFTSHADER in device.mk
107BOARD_USES_SWIFTSHADER := false
108
109# Gralloc4
Robin Pengc2b5ca92021-02-23 20:00:28 +0800110ifeq ($(BOARD_USES_SWIFTSHADER),true)
Sasha Smundakb44a6622021-12-15 10:00:29 -0800111$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,true)
112$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,false)
113$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,false)
114$(call soong_config_set,arm_gralloc,gralloc_init_afbc,false)
115$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,false)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800116else
Sasha Smundakb44a6622021-12-15 10:00:29 -0800117$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,false)
118$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,true)
119$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,true)
120$(call soong_config_set,arm_gralloc,gralloc_init_afbc,true)
121$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800122endif # ifeq ($(BOARD_USES_SWIFTSHADER),true)
Sasha Smundakb44a6622021-12-15 10:00:29 -0800123$(call soong_config_set,arm_gralloc,gralloc_ion_sync_on_lock,$(BOARD_USES_GRALLOC_ION_SYNC))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800124
125# Graphics
126#BOARD_USES_EXYNOS_DATASPACE_FEATURE := true
127
Robin Pengc2b5ca92021-02-23 20:00:28 +0800128# Enable chain partition for system.
Akilesh Kailash7bb42932022-05-20 06:22:54 +0000129BOARD_AVB_VBMETA_SYSTEM := system system_ext product
Robin Pengc2b5ca92021-02-23 20:00:28 +0800130BOARD_AVB_VBMETA_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
131BOARD_AVB_VBMETA_SYSTEM_ALGORITHM := SHA256_RSA2048
132BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
133BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION := 1
134
Pierre-Clément Tosi39764122023-04-18 11:25:52 +0100135ifneq ($(PRODUCT_BUILD_PVMFW_IMAGE),false)
136BOARD_AVB_VBMETA_SYSTEM += pvmfw
137endif
138
Will McVickerb5b92ea2021-01-26 12:37:06 -0800139# Enable chained vbmeta for boot images
140BOARD_AVB_BOOT_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
141BOARD_AVB_BOOT_ALGORITHM := SHA256_RSA2048
142BOARD_AVB_BOOT_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
143BOARD_AVB_BOOT_ROLLBACK_INDEX_LOCATION := 2
144
Robin Pengc2b5ca92021-02-23 20:00:28 +0800145TARGET_USERIMAGES_USE_EXT4 := true
146TARGET_USERIMAGES_USE_F2FS := true
147BOARD_USERDATAIMAGE_PARTITION_SIZE := 11796480000
148BOARD_USERDATAIMAGE_FILE_SYSTEM_TYPE := f2fs
149PRODUCT_FS_COMPRESSION := 1
150BOARD_FLASH_BLOCK_SIZE := 4096
151BOARD_MOUNT_SDCARD_RW := true
152
153# product.img
154BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := ext4
155TARGET_COPY_OUT_PRODUCT := product
156
157# system_ext.img
158BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := ext4
159TARGET_COPY_OUT_SYSTEM_EXT := system_ext
160
161########################
162# Video Codec
163########################
164# 1. Exynos C2
wenchangliud662abb2023-12-14 18:21:07 +0000165BOARD_USE_CODEC2_HIDL_1_2 := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800166BOARD_USE_CSC_FILTER := false
167BOARD_USE_DEC_SW_CSC := true
168BOARD_USE_ENC_SW_CSC := true
169BOARD_SUPPORT_MFC_ENC_RGB := true
Charlie Chen935a1dd2021-03-16 16:26:13 +0800170BOARD_USE_BLOB_ALLOCATOR := false
Taehwan Kim4b4e1812022-09-23 18:39:27 +0900171BOARD_SUPPORT_MFC_ENC_BT2020 := true
wenchangliu49f6cdf2023-01-12 09:17:19 +0000172BOARD_SUPPORT_FLEXIBLE_P010 := true
Herbert Xue17c45432024-11-06 11:00:15 +0800173$(call soong_config_set,video_codec,target_soc_name,$(TARGET_SOC_NAME))
174$(call soong_config_set_bool,video_codec,board_use_codec2_hidl_1_2,$(BOARD_USE_CODEC2_HIDL_1_2))
Herbert Xue89b65692024-11-19 15:33:05 +0800175$(call soong_config_set_bool,video_codec,board_use_csc_filter,$(BOARD_USE_CSC_FILTER))
Herbert Xue6a9c8ba2024-11-08 15:24:04 +0800176$(call soong_config_set_bool,video_codec,board_use_dec_sw_csc,$(BOARD_USE_DEC_SW_CSC))
Herbert Xue89b65692024-11-19 15:33:05 +0800177$(call soong_config_set_bool,video_codec,board_use_enc_sw_csc,$(BOARD_USE_ENC_SW_CSC))
178$(call soong_config_set_bool,video_codec,board_support_mfc_enc_rgb,$(BOARD_SUPPORT_MFC_ENC_RGB))
179$(call soong_config_set_bool,video_codec,board_use_blob_allocator,$(BOARD_USE_BLOB_ALLOCATOR))
Herbert Xue17c45432024-11-06 11:00:15 +0800180$(call soong_config_set_bool,video_codec,board_support_mfc_enc_bt2020,$(BOARD_SUPPORT_MFC_ENC_BT2020))
181$(call soong_config_set_bool,video_codec,board_support_flexible_p010,$(BOARD_SUPPORT_FLEXIBLE_P010))
182$(call soong_config_set_bool,video_codec,board_use_codec2_aidl,$(if $(BOARD_USE_CODEC2_AIDL),true,false))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800183########################
184
185BOARD_SUPER_PARTITION_SIZE := 8531214336
186BOARD_SUPER_PARTITION_GROUPS := google_dynamic_partitions
Pat Tjin977ea342021-03-11 23:20:27 -0800187# Set size to BOARD_SUPER_PARTITION_SIZE - overhead (4MiB) (b/182237294)
188BOARD_GOOGLE_DYNAMIC_PARTITIONS_SIZE := 8527020032
Robin Pengc2b5ca92021-02-23 20:00:28 +0800189BOARD_GOOGLE_DYNAMIC_PARTITIONS_PARTITION_LIST := \
190 system \
191 system_ext \
192 product \
Daniel Mentzfc05a5f2021-03-03 14:44:17 -0800193 vendor \
194 vendor_dlkm
Robin Pengc2b5ca92021-02-23 20:00:28 +0800195
Gina Koa4178502024-03-26 18:10:50 -0700196# Set error limit to BOARD_SUPER_PARTITON_SIZE - 400MB
197BOARD_SUPER_PARTITION_ERROR_LIMIT := 8111783936
Robin Pengc2b5ca92021-02-23 20:00:28 +0800198
Vincent Palomaresf78d6a12022-04-27 13:15:11 -0700199# Testing related defines
200BOARD_PERFSETUP_SCRIPT := platform_testing/scripts/perf-setup/r4o6-setup.sh
201
Robin Pengc2b5ca92021-02-23 20:00:28 +0800202#
203# AUDIO & VOICE
204#
205BOARD_USES_GENERIC_AUDIO := true
206
Sasha Smundakb44a6622021-12-15 10:00:29 -0800207$(call soong_config_set,aoc_audio_func,ext_hidl,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800208
209ifneq (,$(filter userdebug eng, $(TARGET_BUILD_VARIANT)))
Sasha Smundakb44a6622021-12-15 10:00:29 -0800210$(call soong_config_set,aoc_audio_func,dump_usecase_data,true)
211$(call soong_config_set,aoc_audio_func,hal_socket_control,true)
Jasmine Cha88ae21d2023-10-17 15:10:42 +0800212$(call soong_config_set,aoc_audio_func,record_tuning_keys,true)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800213endif
214
Carter Hsu977c44c2021-05-12 17:02:05 +0800215ifneq (,$(filter aosp_%,$(TARGET_PRODUCT)))
Sasha Smundakb44a6622021-12-15 10:00:29 -0800216$(call soong_config_set,aoc_audio_func,aosp_build,true)
Carter Hsu977c44c2021-05-12 17:02:05 +0800217endif
218
Sasha Smundakb44a6622021-12-15 10:00:29 -0800219$(call soong_config_set,haptics,actuator_model,$(ACTUATOR_MODEL))
Vince Leung58180f02021-08-27 03:50:21 +0000220
Robin Pengc2b5ca92021-02-23 20:00:28 +0800221# Primary AudioHAL Configuration
222#BOARD_USE_COMMON_AUDIOHAL := true
223#BOARD_USE_CALLIOPE_AUDIOHAL := false
224#BOARD_USE_AUDIOHAL := true
225
226# Compress Offload Configuration
227#BOARD_USE_OFFLOAD_AUDIO := true
228#BOARD_USE_OFFLOAD_EFFECT := false
229
230# SoundTriggerHAL Configuration
231#BOARD_USE_SOUNDTRIGGER_HAL := false
232
Chris Paulo2fd36962023-01-10 01:43:10 +0000233# Vibrator HAL actuator model and adaptive haptics configuration
234$(call soong_config_set,haptics,actuator_model,$(ACTUATOR_MODEL))
235$(call soong_config_set,haptics,adaptive_haptics_feature,$(ADAPTIVE_HAPTICS_FEATURE))
236
Robin Pengc2b5ca92021-02-23 20:00:28 +0800237# HWComposer
238BOARD_HWC_VERSION := libhwc2.1
239TARGET_RUNNING_WITHOUT_SYNC_FRAMEWORK := false
240BOARD_HDMI_INCAPABLE := true
241TARGET_USES_HWC2 := true
Robin Pengc2b5ca92021-02-23 20:00:28 +0800242HWC_SUPPORT_RENDER_INTENT := true
243HWC_SUPPORT_COLOR_TRANSFORM := true
244#BOARD_USES_DISPLAYPORT := true
245# if AFBC is enabled, must set ro.vendor.ddk.set.afbc=1
246BOARD_USES_EXYNOS_AFBC_FEATURE := true
247#BOARD_USES_HDRUI_GLES_CONVERSION := true
248
249BOARD_LIBACRYL_DEFAULT_COMPOSITOR := fimg2d_gs101
250BOARD_LIBACRYL_G2D_HDR_PLUGIN := libacryl_hdr_plugin
Bill Yangce576fa2024-10-22 10:36:29 +0000251$(call soong_config_set,acryl,libacryl_g2d_hdr_plugin,//hardware/google/graphics/gs101/libacryl_plugins:libacryl_hdr_plugin)
252$(call soong_config_set,acryl,libacryl_c_include,hardware/google/graphics/$(TARGET_BOARD_PLATFORM)/libcap)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800253
254# HWCServices
255BOARD_USES_HWC_SERVICES := true
256
257# WiFiDisplay
258# BOARD_USES_VIRTUAL_DISPLAY := true
259# BOARD_USES_VDS_EXYNOS_HWC := true
260# BOARD_USES_WIFI_DISPLAY:= true
261# BOARD_USES_EGL_SURFACE_FOR_COMPOSITION_MIXED := true
262# BOARD_USES_VDS_YUV420SPM := true
263# BOARD_USES_VDS_OTHERFORMAT := true
264# BOARD_USES_VDS_DEBUG_FLAG := true
265# BOARD_USES_DISABLE_COMPOSITIONTYPE_GLES := true
266# BOARD_USES_SECURE_ENCODER_ONLY := true
267# BOARD_USES_TSMUX := true
268
269# SCALER
270BOARD_USES_DEFAULT_CSC_HW_SCALER := true
271BOARD_DEFAULT_CSC_HW_SCALER := 4
272BOARD_USES_SCALER_M2M1SHOT := true
273
274# Device Tree
275BOARD_USES_DT := true
276BOARD_INCLUDE_DTB_IN_BOOTIMG := true
277BOARD_PREBUILT_DTBIMAGE_DIR := $(TARGET_KERNEL_DIR)
278BOARD_PREBUILT_DTBOIMAGE := $(BOARD_PREBUILT_DTBIMAGE_DIR)/dtbo.img
279
280# PLATFORM LOG
281TARGET_USES_LOGD := true
282
283# LIBHWJPEG
284#TARGET_USES_UNIVERSAL_LIBHWJPEG := true
285#LIBHWJPEG_HWSCALER_ID := 0
286
287#Keymaster
288#BOARD_USES_KEYMASTER_VER1 := true
289
290#FMP
291#BOARD_USES_FMP_DM_CRYPT := true
292#BOARD_USES_FMP_FSCRYPTO := true
293BOARD_USES_METADATA_PARTITION := true
294
Robin Pengc2b5ca92021-02-23 20:00:28 +0800295# SKIA
296#BOARD_USES_SKIA_MULTITHREADING := true
297#BOARD_USES_FIMGAPI_V5X := true
298
299# SECCOMP Policy
300BOARD_SECCOMP_POLICY = device/google/gs101/seccomp_policy
301
302#CURL
303BOARD_USES_CURL := true
304
Robin Pengc2b5ca92021-02-23 20:00:28 +0800305# VISION
306# Exynos vision framework (EVF)
307#TARGET_USES_EVF := true
308# HW acceleration
309#TARGET_USES_VPU_KERNEL := true
310#TARGET_USES_SCORE_KERNEL := true
311#TARGET_USES_CL_KERNEL := false
312
313# exynos RIL
314TARGET_EXYNOS_RIL_SOURCE := true
315ENABLE_VENDOR_RIL_SERVICE := true
316
317# GNSS
318# BOARD_USES_EXYNOS_GNSS_DUMMY := true
319
320# Bluetooth defines
321# TODO(b/123695868): Remove the need for this
322BOARD_BLUETOOTH_BDROID_BUILDCFG_INCLUDE_DIR := \
323 build/make/target/board/mainline_arm64/bluetooth
324
Robin Pengc2b5ca92021-02-23 20:00:28 +0800325#VNDK
326BOARD_PROPERTY_OVERRIDES_SPLIT_ENABLED := true
327BOARD_VNDK_VERSION := current
328
329# H/W align restriction of MM IPs
330BOARD_EXYNOS_S10B_FORMAT_ALIGN := 64
331
Robin Pengc2b5ca92021-02-23 20:00:28 +0800332# 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
Petri Gynther3c5da8c2021-03-07 01:19:46 -0800350# Vendor ramdisk image for kernel development
351BOARD_BUILD_VENDOR_RAMDISK_IMAGE := true
352
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700353KERNEL_MODULE_DIR := $(TARGET_KERNEL_DIR)
354KERNEL_MODULES := $(wildcard $(KERNEL_MODULE_DIR)/*.ko)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800355
Robin Peng85e14852022-01-21 18:08:36 +0800356BOARD_VENDOR_KERNEL_MODULES_BLOCKLIST_FILE := $(KERNEL_MODULE_DIR)/vendor_dlkm.modules.blocklist
357
Robin Pengd790cec2024-01-26 12:50:28 +0000358# Since Pixel 6/6pro doesn't have a system_dlkm partition, the GKI modules are
359# on the vendor_dlkm partition. In order to allow them to load properly, we
360# need to retain the module signature which would normally get stripped during
361# packaging. Disable stripping the vendor_dlkm modules to retain the GKI
362# modules' signature. Note, the pixel kernel builds always strip the modules in
363# favor of saving space via the kleaf property: strip_modules = True.
364BOARD_DO_NOT_STRIP_VENDOR_MODULES := true
365
Daniel Mentzf41ee9f2022-07-21 14:45:34 -0700366# Prebuilt kernel modules that are *not* listed in vendor_boot.modules.load
Qian-Hao Huang32035fe2024-04-23 23:22:27 +0800367BOARD_PREBUILT_VENDOR_RAMDISK_KERNEL_MODULES = fips140.ko
Daniel Mentzf41ee9f2022-07-21 14:45:34 -0700368BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA = $(foreach k,$(BOARD_PREBUILT_VENDOR_RAMDISK_KERNEL_MODULES),$(if $(wildcard $(KERNEL_MODULE_DIR)/$(k)), $(k)))
Daniel Mentzf41ee9f2022-07-21 14:45:34 -0700369
370# Kernel modules that are listed in vendor_boot.modules.load
Jacky Liuacf71382024-08-05 11:59:57 +0800371# Starting from 6.1, use modules.load instead. It lists modules for vendor ramdisk regardless of the partition name.
372ifneq ($(wildcard $(KERNEL_MODULE_DIR)/modules.load),)
373 BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE := $(strip $(shell cat $(KERNEL_MODULE_DIR)/modules.load))
374else
375 BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE := $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_boot.modules.load))
376endif
Daniel Mentzf41ee9f2022-07-21 14:45:34 -0700377ifndef BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700378$(error vendor_boot.modules.load not found or empty)
379endif
Daniel Mentzf41ee9f2022-07-21 14:45:34 -0700380BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD := $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA)
381BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD += $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE)
382BOARD_VENDOR_RAMDISK_KERNEL_MODULES := $(addprefix $(KERNEL_MODULE_DIR)/, $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA))
383BOARD_VENDOR_RAMDISK_KERNEL_MODULES += $(addprefix $(KERNEL_MODULE_DIR)/, $(notdir $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE)))
Robin Pengc2b5ca92021-02-23 20:00:28 +0800384
Yu Shan79c36032023-01-03 11:29:46 -0800385BOARD_VENDOR_KERNEL_MODULES_LOAD += $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_dlkm.modules.load))
Daniel Mentz6a6d8f82021-05-11 22:58:19 -0700386ifndef BOARD_VENDOR_KERNEL_MODULES_LOAD
387$(error vendor_dlkm.modules.load not found or empty)
388endif
Yu Shan79c36032023-01-03 11:29:46 -0800389BOARD_VENDOR_KERNEL_MODULES += $(KERNEL_MODULES)
Robin Pengc2b5ca92021-02-23 20:00:28 +0800390
391# Using BUILD_COPY_HEADERS
392BUILD_BROKEN_USES_BUILD_COPY_HEADERS := true
393
394include device/google/gs101-sepolicy/gs101-sepolicy.mk
Robin Pengc2b5ca92021-02-23 20:00:28 +0800395
396# Battery options
397BOARD_KERNEL_CMDLINE += at24.write_timeout=100
J. Aviladf9dc5c2021-04-12 18:22:36 +0000398
399# Enable larger logbuf
400BOARD_KERNEL_CMDLINE += log_buf_len=1024K
Jeffrey Carlyle15d83482021-06-15 08:26:29 -0700401
David Brazdilae3c59f2021-10-12 16:09:56 +0000402# Protected VM firmware
David Brazdilae3c59f2021-10-12 16:09:56 +0000403BOARD_PVMFWIMAGE_PARTITION_SIZE := 0x00100000
David Brazdilae3c59f2021-10-12 16:09:56 +0000404
Jeffrey Carlyle489f8192022-08-24 12:23:11 -0700405-include vendor/google_devices/gs-common/proprietary/BoardConfigVendor.mk
maxwen5363dbc2022-11-12 03:58:54 +0100406
407include device/google/gs101/BoardConfig-omni.mk