在 Android 中,系统属性存储在 ConfigStore 类中。ConfigStore 使用 build 标志在供应商分区中存储配置值,系统分区中的服务使用 HIDL 访问这些值。
系统属性使用PRODUCT_DEFAULT_PROPERTY_OVERRIDES 在供应商分区的 default.prop 中存储系统属性,服务使用 sysprop 读取这些属性。
  ConfigStore HAL 保留在 AOSP 中以支持旧版供应商分区。在搭载 Android 10 的设备上,surfaceflinger 首先读取系统属性;如果没有为 SurfaceFlingerProperties.sysprop 中的配置项定义任何系统属性,surfaceflinger 会回退到 ConfigStore HAL。
build 标记和系统属性
ConfigStore 中的每个 build 标志都有一个匹配的系统属性,如下表所示。
| 构建标志 | 系统属性 | 
|---|---|
TARGET_FORCE_HWC_FOR_VIRTUAL_DISPLAYS
    | 
   ro.surface_flinger.force_hwc_copy_for_virtual_displays
    | 
  
TARGET_HAS_HDR_DISPLAY
    | 
   ro.surface_flinger.has_HDR_display
    | 
  
TARGET_HAS_WIDE_COLOR_DISPLAY
    | 
   ro.surface_flinger.has_wide_color_display
    | 
  
NUM_FRAMEBUFFER_SURFACE_BUFFERS
    | 
   ro.surface_flinger.max_frame_buffer_acquired_buffers
    | 
  
MAX_VIRTUAL_DISPLAY_DIMENSION
    | 
   ro.surface_flinger.max_virtual_display_dimension
    | 
  
PRIMARY_DISPLAY_ORIENTATION
    | 
   ro.surface_flinger.primary_display_orientation
    | 
  
PRESENT_TIME_OFFSET_FROM_VSYNC_NS
    | 
   ro.surface_flinger.present_time_offset_from_vsync_ns
    | 
  
TARGET_RUNNING_WITHOUT_SYNC_FRAMEWORK
    | 
   ro.surface_flinger.running_without_sync_framework
    | 
  
SF_START_GRAPHICS_ALLOCATOR_SERVICE
    | 
   ro.surface_flinger.start_graphics_allocator_service
    | 
  
TARGET_USE_CONTEXT_PRIORITY
    | 
   ro.surface_flinger.use_context_priority
    | 
  
USE_VR_FLINGER
    | 
   ro.surface_flinger.use_vr_flinger
    | 
  
VSYNC_EVENT_PHASE_OFFSET_NS
    | 
   ro.surface_flinger.vsync_event_phase_offset_ns
    | 
  
SF_VSYNC_EVENT_PHASE_OFFSET_NS
    | 
   ro.surface_flinger.vsync_sf_event_phase_offset_ns
    | 
  
新系统属性
Android 10 包含以下新系统属性:
ro.surface_flinger.default_composition_dataspacero.surface_flinger.default_composition_pixel_formatro.surface_flinger.use_color_managementro.surface_flinger.wcg_composition_dataspacero.surface_flinger.wcg_composition_pixel_formatro.surface_flinger.display_primary_redro.surface_flinger.display_primary_greenro.surface_flinger.display_primary_bluero.surface_flinger.display_primary_whitero.surface_flinger.protected_contentsro.surface_flinger.set_idle_timer_msro.surface_flinger.set_touch_timer_msro.surface_flinger.use_smart_90_for_videoro.surface_flinger.protected_contentsro.surface_flinger.support_kernel_idle_timer
  如需详细了解这些属性,请参阅 frameworks/native/services/surfaceflinger/sysprop/SurfaceFlingerProperties.sysprop。
使用 SurfaceFlingerProperties
  在 SurfaceFlingerProperties 库的以下示例中,函数名称是 SurfaceFlingerProperties.sysprop 中的 api_name。
cc_binary { name: "cc_client", srcs: ["baz.cpp"], shared_libs: ["SurfaceFlingerProperties"], } java_library { name: "JavaClient", srcs: ["foo/bar.java"], libs: ["SurfaceFlingerProperties"], }
import android.sysprop.SurfaceFlingerProperties; ... static void foo() { ... boolean temp = SurfaceFlingerProperties.vsync_event_phase_offset_ns().orElse(true); ... } ...
#include <SurfaceFlingerProperties.sysprop.h> using namespace android::sysprop; ... void bar() { ... bool temp = SurfaceFlingerProperties::vsync_event_phase_offset_ns(true); ... } ...