1# 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 17include build/make/target/board/BoardConfigPixelCommon.mk 18 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 30TARGET_ARCH_VARIANT := armv8-2a 31TARGET_CPU_ABI := arm64-v8a 32TARGET_CPU_VARIANT := cortex-a55 33TARGET_CPU_VARIANT_RUNTIME := cortex-a55 34 35DEVICE_IS_64BIT_ONLY ?= $(if $(filter %_64,$(TARGET_PRODUCT)),true,false) 36 37ifneq ($(DEVICE_IS_64BIT_ONLY),true) 38TARGET_2ND_ARCH := arm 39TARGET_2ND_ARCH_VARIANT := armv8-a 40TARGET_2ND_CPU_ABI := armeabi-v7a 41TARGET_2ND_CPU_ABI2 := armeabi 42TARGET_2ND_CPU_VARIANT := generic 43TARGET_2ND_CPU_VARIANT_RUNTIME := cortex-a53 44endif 45 46BOARD_KERNEL_CMDLINE += dyndbg=\"func alloc_contig_dump_pages +p\" 47BOARD_KERNEL_CMDLINE += earlycon=exynos4210,0x10A00000 console=ttySAC0,115200 androidboot.console=ttySAC0 printk.devkmsg=on 48BOARD_KERNEL_CMDLINE += cma_sysfs.experimental=Y 49BOARD_KERNEL_CMDLINE += swiotlb=noforce 50BOARD_BOOTCONFIG += androidboot.boot_devices=14700000.ufs 51 52TARGET_NO_BOOTLOADER := true 53TARGET_NO_RADIOIMAGE := true 54BOARD_PREBUILT_BOOTIMAGE := $(wildcard $(TARGET_KERNEL_DIR)/boot.img) 55ifneq (,$(BOARD_PREBUILT_BOOTIMAGE)) 56TARGET_NO_KERNEL := true 57else 58TARGET_NO_KERNEL := false 59endif 60BOARD_USES_GENERIC_KERNEL_IMAGE := true 61BOARD_MOVE_RECOVERY_RESOURCES_TO_VENDOR_BOOT := true 62BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT := true 63TARGET_RECOVERY_WIPE := device/google/gs101/conf/recovery.wipe 64 65# This is the fstab file that will be included in the recovery image. Note that 66# recovery doesn't care about the encryption settings, so it doesn't matter 67# whether we use the normal or the fips fstab here. 68TARGET_RECOVERY_FSTAB_GENRULE = gen_fstab.gs101 69 70TARGET_RECOVERY_PIXEL_FORMAT := ABGR_8888 71TARGET_RECOVERY_UI_MARGIN_HEIGHT := 165 72TARGET_RECOVERY_UI_LIB := \ 73 librecovery_ui_pixel \ 74 libfstab 75 76AB_OTA_UPDATER := true 77 78AB_OTA_PARTITIONS += \ 79 system \ 80 system_ext \ 81 product \ 82 vbmeta_system 83 84ifneq ($(PRODUCT_BUILD_BOOT_IMAGE),false) 85AB_OTA_PARTITIONS += boot 86endif 87ifneq ($(PRODUCT_BUILD_VENDOR_BOOT_IMAGE),false) 88AB_OTA_PARTITIONS += vendor_boot 89AB_OTA_PARTITIONS += dtbo 90endif 91ifneq ($(PRODUCT_BUILD_VBMETA_IMAGE),false) 92AB_OTA_PARTITIONS += vbmeta 93endif 94 95# EMULATOR common modules 96BOARD_EMULATOR_COMMON_MODULES := liblight 97 98OVERRIDE_RS_DRIVER := libRSDriverArm.so 99BOARD_EGL_CFG := device/google/gs101/conf/egl.cfg 100#BOARD_USES_HGL := true 101USE_OPENGL_RENDERER := true 102NUM_FRAMEBUFFER_SURFACE_BUFFERS := 3 103BOARD_USES_EXYNOS5_COMMON_GRALLOC := true 104BOARD_USES_ALIGN_RESTRICTION := false 105BOARD_USES_GRALLOC_ION_SYNC := true 106 107# This should be the same value as USE_SWIFTSHADER in device.mk 108BOARD_USES_SWIFTSHADER := false 109 110# Gralloc4 111ifeq ($(BOARD_USES_SWIFTSHADER),true) 112$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,true) 113$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,false) 114$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,false) 115$(call soong_config_set,arm_gralloc,gralloc_init_afbc,false) 116$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,false) 117else 118$(call soong_config_set,arm_gralloc,gralloc_arm_no_external_afbc,false) 119$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_basic,true) 120$(call soong_config_set,arm_gralloc,mali_gpu_support_afbc_wideblk,true) 121$(call soong_config_set,arm_gralloc,gralloc_init_afbc,true) 122$(call soong_config_set,arm_gralloc,dpu_support_1010102_afbc,true) 123endif # ifeq ($(BOARD_USES_SWIFTSHADER),true) 124$(call soong_config_set,arm_gralloc,gralloc_ion_sync_on_lock,$(BOARD_USES_GRALLOC_ION_SYNC)) 125 126# Graphics 127#BOARD_USES_EXYNOS_DATASPACE_FEATURE := true 128 129# Enable chain partition for system. 130BOARD_AVB_VBMETA_SYSTEM := system system_ext product 131BOARD_AVB_VBMETA_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem 132BOARD_AVB_VBMETA_SYSTEM_ALGORITHM := SHA256_RSA2048 133BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) 134BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION := 1 135 136ifneq ($(PRODUCT_BUILD_PVMFW_IMAGE),false) 137BOARD_AVB_VBMETA_SYSTEM += pvmfw 138endif 139 140# Enable chained vbmeta for boot images 141BOARD_AVB_BOOT_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem 142BOARD_AVB_BOOT_ALGORITHM := SHA256_RSA2048 143BOARD_AVB_BOOT_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) 144BOARD_AVB_BOOT_ROLLBACK_INDEX_LOCATION := 2 145 146TARGET_USERIMAGES_USE_EXT4 := true 147TARGET_USERIMAGES_USE_F2FS := true 148BOARD_USERDATAIMAGE_PARTITION_SIZE := 11796480000 149BOARD_USERDATAIMAGE_FILE_SYSTEM_TYPE := f2fs 150PRODUCT_FS_COMPRESSION := 1 151BOARD_FLASH_BLOCK_SIZE := 4096 152BOARD_MOUNT_SDCARD_RW := true 153 154# product.img 155BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := ext4 156TARGET_COPY_OUT_PRODUCT := product 157 158# system_ext.img 159BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := ext4 160TARGET_COPY_OUT_SYSTEM_EXT := system_ext 161 162######################## 163# Video Codec 164######################## 165# 1. Exynos C2 166BOARD_USE_CSC_FILTER := false 167BOARD_USE_DEC_SW_CSC := true 168BOARD_USE_ENC_SW_CSC := true 169BOARD_SUPPORT_MFC_ENC_RGB := true 170BOARD_USE_BLOB_ALLOCATOR := false 171BOARD_SUPPORT_MFC_ENC_BT2020 := true 172BOARD_SUPPORT_FLEXIBLE_P010 := true 173 174######################## 175 176BOARD_SUPER_PARTITION_SIZE := 8531214336 177BOARD_SUPER_PARTITION_GROUPS := google_dynamic_partitions 178# Set size to BOARD_SUPER_PARTITION_SIZE - overhead (4MiB) (b/182237294) 179BOARD_GOOGLE_DYNAMIC_PARTITIONS_SIZE := 8527020032 180BOARD_GOOGLE_DYNAMIC_PARTITIONS_PARTITION_LIST := \ 181 system \ 182 system_ext \ 183 product \ 184 vendor \ 185 vendor_dlkm 186 187# Set error limit to BOARD_SUPER_PARTITON_SIZE - 500MB 188BOARD_SUPER_PARTITION_ERROR_LIMIT := 8006926336 189 190# Testing related defines 191BOARD_PERFSETUP_SCRIPT := platform_testing/scripts/perf-setup/r4o6-setup.sh 192 193# 194# AUDIO & VOICE 195# 196BOARD_USES_GENERIC_AUDIO := true 197 198$(call soong_config_set,aoc_audio_func,ext_hidl,true) 199 200ifneq (,$(filter userdebug eng, $(TARGET_BUILD_VARIANT))) 201$(call soong_config_set,aoc_audio_func,dump_usecase_data,true) 202$(call soong_config_set,aoc_audio_func,hal_socket_control,true) 203$(call soong_config_set,aoc_audio_func,record_tunning_keys,true) 204endif 205 206ifneq (,$(filter aosp_%,$(TARGET_PRODUCT))) 207$(call soong_config_set,aoc_audio_func,aosp_build,true) 208endif 209 210$(call soong_config_set,haptics,actuator_model,$(ACTUATOR_MODEL)) 211 212# Primary AudioHAL Configuration 213#BOARD_USE_COMMON_AUDIOHAL := true 214#BOARD_USE_CALLIOPE_AUDIOHAL := false 215#BOARD_USE_AUDIOHAL := true 216 217# Compress Offload Configuration 218#BOARD_USE_OFFLOAD_AUDIO := true 219#BOARD_USE_OFFLOAD_EFFECT := false 220 221# SoundTriggerHAL Configuration 222#BOARD_USE_SOUNDTRIGGER_HAL := false 223 224# Vibrator HAL actuator model and adaptive haptics configuration 225$(call soong_config_set,haptics,actuator_model,$(ACTUATOR_MODEL)) 226$(call soong_config_set,haptics,adaptive_haptics_feature,$(ADAPTIVE_HAPTICS_FEATURE)) 227 228# HWComposer 229BOARD_HWC_VERSION := libhwc2.1 230TARGET_RUNNING_WITHOUT_SYNC_FRAMEWORK := false 231BOARD_HDMI_INCAPABLE := true 232TARGET_USES_HWC2 := true 233HWC_SUPPORT_RENDER_INTENT := true 234HWC_SUPPORT_COLOR_TRANSFORM := true 235#BOARD_USES_DISPLAYPORT := true 236# if AFBC is enabled, must set ro.vendor.ddk.set.afbc=1 237BOARD_USES_EXYNOS_AFBC_FEATURE := true 238#BOARD_USES_HDRUI_GLES_CONVERSION := true 239 240BOARD_LIBACRYL_DEFAULT_COMPOSITOR := fimg2d_gs101 241BOARD_LIBACRYL_G2D_HDR_PLUGIN := libacryl_hdr_plugin 242 243# HWCServices 244BOARD_USES_HWC_SERVICES := true 245 246# WiFiDisplay 247# BOARD_USES_VIRTUAL_DISPLAY := true 248# BOARD_USES_VDS_EXYNOS_HWC := true 249# BOARD_USES_WIFI_DISPLAY:= true 250# BOARD_USES_EGL_SURFACE_FOR_COMPOSITION_MIXED := true 251# BOARD_USES_VDS_YUV420SPM := true 252# BOARD_USES_VDS_OTHERFORMAT := true 253# BOARD_USES_VDS_DEBUG_FLAG := true 254# BOARD_USES_DISABLE_COMPOSITIONTYPE_GLES := true 255# BOARD_USES_SECURE_ENCODER_ONLY := true 256# BOARD_USES_TSMUX := true 257 258# SCALER 259BOARD_USES_DEFAULT_CSC_HW_SCALER := true 260BOARD_DEFAULT_CSC_HW_SCALER := 4 261BOARD_USES_SCALER_M2M1SHOT := true 262 263# Device Tree 264BOARD_USES_DT := true 265BOARD_INCLUDE_DTB_IN_BOOTIMG := true 266BOARD_PREBUILT_DTBIMAGE_DIR := $(TARGET_KERNEL_DIR) 267BOARD_PREBUILT_DTBOIMAGE := $(BOARD_PREBUILT_DTBIMAGE_DIR)/dtbo.img 268 269# PLATFORM LOG 270TARGET_USES_LOGD := true 271 272# LIBHWJPEG 273#TARGET_USES_UNIVERSAL_LIBHWJPEG := true 274#LIBHWJPEG_HWSCALER_ID := 0 275 276#Keymaster 277#BOARD_USES_KEYMASTER_VER1 := true 278 279#FMP 280#BOARD_USES_FMP_DM_CRYPT := true 281#BOARD_USES_FMP_FSCRYPTO := true 282BOARD_USES_METADATA_PARTITION := true 283 284# SKIA 285#BOARD_USES_SKIA_MULTITHREADING := true 286#BOARD_USES_FIMGAPI_V5X := true 287 288# SECCOMP Policy 289BOARD_SECCOMP_POLICY = device/google/gs101/seccomp_policy 290 291#CURL 292BOARD_USES_CURL := true 293 294# Sensor HAL 295BOARD_USES_EXYNOS_SENSORS_DUMMY := true 296 297# VISION 298# Exynos vision framework (EVF) 299#TARGET_USES_EVF := true 300# HW acceleration 301#TARGET_USES_VPU_KERNEL := true 302#TARGET_USES_SCORE_KERNEL := true 303#TARGET_USES_CL_KERNEL := false 304 305# exynos RIL 306TARGET_EXYNOS_RIL_SOURCE := true 307ENABLE_VENDOR_RIL_SERVICE := true 308 309# GNSS 310# BOARD_USES_EXYNOS_GNSS_DUMMY := true 311 312# Bluetooth defines 313# TODO(b/123695868): Remove the need for this 314BOARD_BLUETOOTH_BDROID_BUILDCFG_INCLUDE_DIR := \ 315 build/make/target/board/mainline_arm64/bluetooth 316 317#VNDK 318BOARD_PROPERTY_OVERRIDES_SPLIT_ENABLED := true 319BOARD_VNDK_VERSION := current 320 321# H/W align restriction of MM IPs 322BOARD_EXYNOS_S10B_FORMAT_ALIGN := 64 323 324# Boot.img 325BOARD_RAMDISK_USE_LZ4 := true 326#BOARD_KERNEL_BASE := 0x80000000 327#BOARD_KERNEL_PAGESIZE := 2048 328#BOARD_KERNEL_OFFSET := 0x80000 329#BOARD_RAMDISK_OFFSET := 0x4000000 330BOARD_BOOT_HEADER_VERSION := 4 331BOARD_MKBOOTIMG_ARGS += --header_version $(BOARD_BOOT_HEADER_VERSION) 332 333BOARD_VENDOR_RAMDISK_FRAGMENTS := dlkm 334BOARD_VENDOR_RAMDISK_FRAGMENT.dlkm.KERNEL_MODULE_DIRS := top 335 336# Enable AVB2.0 337BOARD_AVB_ENABLE := true 338BOARD_BOOTIMAGE_PARTITION_SIZE := 0x04000000 339BOARD_VENDOR_BOOTIMAGE_PARTITION_SIZE := 0x04000000 340BOARD_DTBOIMG_PARTITION_SIZE := 0x01000000 341 342# Vendor ramdisk image for kernel development 343BOARD_BUILD_VENDOR_RAMDISK_IMAGE := true 344 345KERNEL_MODULE_DIR := $(TARGET_KERNEL_DIR) 346KERNEL_MODULES := $(wildcard $(KERNEL_MODULE_DIR)/*.ko) 347 348BOARD_VENDOR_KERNEL_MODULES_BLOCKLIST_FILE := $(KERNEL_MODULE_DIR)/vendor_dlkm.modules.blocklist 349 350# Prebuilt kernel modules that are *not* listed in vendor_boot.modules.load 351BOARD_PREBUILT_VENDOR_RAMDISK_KERNEL_MODULES = fips140/fips140.ko 352BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA = $(foreach k,$(BOARD_PREBUILT_VENDOR_RAMDISK_KERNEL_MODULES),$(if $(wildcard $(KERNEL_MODULE_DIR)/$(k)), $(k))) 353KERNEL_MODULES += $(addprefix $(KERNEL_MODULE_DIR)/, $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA)) 354 355# Kernel modules that are listed in vendor_boot.modules.load 356BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE := $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_boot.modules.load)) 357ifndef BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE 358$(error vendor_boot.modules.load not found or empty) 359endif 360BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD := $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA) 361BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD += $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE) 362BOARD_VENDOR_RAMDISK_KERNEL_MODULES := $(addprefix $(KERNEL_MODULE_DIR)/, $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_EXTRA)) 363BOARD_VENDOR_RAMDISK_KERNEL_MODULES += $(addprefix $(KERNEL_MODULE_DIR)/, $(notdir $(BOARD_VENDOR_RAMDISK_KERNEL_MODULES_LOAD_FILE))) 364 365BOARD_VENDOR_KERNEL_MODULES_LOAD += $(strip $(shell cat $(KERNEL_MODULE_DIR)/vendor_dlkm.modules.load)) 366ifndef BOARD_VENDOR_KERNEL_MODULES_LOAD 367$(error vendor_dlkm.modules.load not found or empty) 368endif 369BOARD_VENDOR_KERNEL_MODULES += $(KERNEL_MODULES) 370 371# Using BUILD_COPY_HEADERS 372BUILD_BROKEN_USES_BUILD_COPY_HEADERS := true 373 374include device/google/gs101-sepolicy/gs101-sepolicy.mk 375 376# Battery options 377BOARD_KERNEL_CMDLINE += at24.write_timeout=100 378 379# Enable larger logbuf 380BOARD_KERNEL_CMDLINE += log_buf_len=1024K 381 382# Protected VM firmware 383BOARD_PVMFWIMAGE_PARTITION_SIZE := 0x00100000 384 385-include vendor/google_devices/gs-common/proprietary/BoardConfigVendor.mk 386