BoardConfigCommon.mk 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. #
  2. # Copyright (C) 2022 The LineageOS Project
  3. #
  4. # SPDX-License-Identifier: Apache-2.0
  5. #
  6. # Inherit from the proprietary version
  7. include vendor/xiaomi/sm8450-common/BoardConfigVendor.mk
  8. COMMON_PATH := device/xiaomi/sm8450-common
  9. # A/B
  10. AB_OTA_UPDATER := true
  11. AB_OTA_PARTITIONS += \
  12. boot \
  13. dtbo \
  14. odm \
  15. product \
  16. recovery \
  17. system \
  18. system_ext \
  19. vbmeta \
  20. vbmeta_system \
  21. vendor \
  22. vendor_boot \
  23. vendor_dlkm
  24. # Architecture
  25. TARGET_ARCH := arm64
  26. TARGET_ARCH_VARIANT := armv8-a-branchprot
  27. TARGET_CPU_ABI := arm64-v8a
  28. TARGET_CPU_ABI2 :=
  29. TARGET_CPU_VARIANT := kryo300
  30. TARGET_2ND_ARCH := arm
  31. TARGET_2ND_ARCH_VARIANT := armv8-2a
  32. TARGET_2ND_CPU_ABI := armeabi-v7a
  33. TARGET_2ND_CPU_ABI2 := armeabi
  34. TARGET_2ND_CPU_VARIANT := cortex-a75
  35. # Boot control
  36. $(call soong_config_set, ufsbsg, ufsframework, bsg)
  37. # Bootloader
  38. TARGET_BOOTLOADER_BOARD_NAME := taro
  39. TARGET_NO_BOOTLOADER := true
  40. # Filesystem
  41. TARGET_FS_CONFIG_GEN := $(COMMON_PATH)/configs/config.fs
  42. # Metadata
  43. BOARD_USES_METADATA_PARTITION := true
  44. # Partitions
  45. BOARD_FLASH_BLOCK_SIZE := 0x020000 # (BOARD_KERNEL_PAGESIZE * 64)
  46. BOARD_BOOTIMAGE_PARTITION_SIZE := 0x0C000000
  47. BOARD_DTBOIMG_PARTITION_SIZE := 0x01800000
  48. BOARD_RECOVERYIMAGE_PARTITION_SIZE := 0x06400000
  49. BOARD_SUPER_PARTITION_SIZE := 9126805504 # 0x220000000
  50. BOARD_USERDATAIMAGE_PARTITION_SIZE := 239033364480 # 0x37A77FB000
  51. BOARD_VENDOR_BOOTIMAGE_PARTITION_SIZE := 0x06000000
  52. BOARD_SUPER_PARTITION_GROUPS := qti_dynamic_partitions
  53. BOARD_QTI_DYNAMIC_PARTITIONS_PARTITION_LIST := odm product system system_ext vendor vendor_dlkm
  54. BOARD_QTI_DYNAMIC_PARTITIONS_SIZE := 9122611200 # 0x21FC00000 # BOARD_SUPER_PARTITION_SIZE - overhead (4MiB)
  55. BOARD_ODMIMAGE_FILE_SYSTEM_TYPE := ext4
  56. BOARD_PRODUCTIMAGE_FILE_SYSTEM_TYPE := ext4
  57. BOARD_SYSTEMIMAGE_FILE_SYSTEM_TYPE := ext4
  58. BOARD_SYSTEM_EXTIMAGE_FILE_SYSTEM_TYPE := ext4
  59. BOARD_VENDORIMAGE_FILE_SYSTEM_TYPE := ext4
  60. BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE := ext4
  61. TARGET_COPY_OUT_ODM := odm
  62. TARGET_COPY_OUT_PRODUCT := product
  63. TARGET_COPY_OUT_SYSTEM_EXT := system_ext
  64. TARGET_COPY_OUT_VENDOR := vendor
  65. TARGET_COPY_OUT_VENDOR_DLKM := vendor_dlkm
  66. # Platform
  67. BOARD_USES_QCOM_HARDWARE := true
  68. TARGET_BOARD_PLATFORM := taro
  69. # Power
  70. TARGET_POWERHAL_MODE_EXT := $(COMMON_PATH)/power/power-mode.cpp
  71. # Properties
  72. TARGET_ODM_PROP += $(COMMON_PATH)/properties/odm.prop
  73. TARGET_PRODUCT_PROP += $(COMMON_PATH)/properties/product.prop
  74. TARGET_SYSTEM_PROP += $(COMMON_PATH)/properties/system.prop
  75. TARGET_SYSTEM_EXT_PROP += $(COMMON_PATH)/properties/system_ext.prop
  76. TARGET_VENDOR_PROP += $(COMMON_PATH)/properties/vendor.prop
  77. # Recovery
  78. TARGET_RECOVERY_FSTAB := $(COMMON_PATH)/rootdir/etc/recovery.fstab
  79. TARGET_RECOVERY_PIXEL_FORMAT := RGBX_8888
  80. TARGET_USERIMAGES_USE_EXT4 := true
  81. TARGET_USERIMAGES_USE_F2FS := true
  82. BOARD_EXCLUDE_KERNEL_FROM_RECOVERY_IMAGE := true
  83. # RIL
  84. ENABLE_VENDOR_RIL_SERVICE := true
  85. # Sepolicy
  86. include device/qcom/sepolicy_vndr/SEPolicy.mk
  87. # VINTF
  88. DEVICE_MATRIX_FILE := $(COMMON_PATH)/vintf/compatibility_matrix.xml
  89. DEVICE_MANIFEST_SKUS := taro diwali cape ukee
  90. $(foreach sku, $(call to-upper, $(DEVICE_MANIFEST_SKUS)), \
  91. $(eval DEVICE_MANIFEST_$(sku)_FILES := \
  92. $(COMMON_PATH)/vintf/manifest.xml \
  93. $(COMMON_PATH)/vintf/manifest_xiaomi.xml \
  94. ))
  95. DEVICE_FRAMEWORK_COMPATIBILITY_MATRIX_FILE := \
  96. $(COMMON_PATH)/vintf/xiaomi_framework_compatibility_matrix.xml \
  97. hardware/qcom-caf/common/vendor_framework_compatibility_matrix.xml \
  98. hardware/xiaomi/vintf/xiaomi_framework_compatibility_matrix.xml \
  99. vendor/lineage/config/device_framework_matrix.xml
  100. # Verified Boot
  101. BOARD_AVB_ENABLE := true
  102. BOARD_AVB_MAKE_VBMETA_IMAGE_ARGS += --flags 3
  103. BOARD_AVB_RECOVERY_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
  104. BOARD_AVB_RECOVERY_ALGORITHM := SHA256_RSA2048
  105. BOARD_AVB_RECOVERY_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
  106. BOARD_AVB_RECOVERY_ROLLBACK_INDEX_LOCATION := 1
  107. BOARD_AVB_VBMETA_SYSTEM := system system_ext product
  108. BOARD_AVB_VBMETA_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem
  109. BOARD_AVB_VBMETA_SYSTEM_ALGORITHM := SHA256_RSA2048
  110. BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP)
  111. BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION := 2
  112. BOARD_MOVE_GSI_AVB_KEYS_TO_VENDOR_BOOT := true