SurfaceFlinger 中的系統屬性

ConfigStore HAL 仍會保留在 Android 開放原始碼計畫中,以支援舊版供應商分區。在執行 Android 10 以上版本的裝置上,surfaceflinger 會先讀取系統屬性;如果 SurfaceFlingerProperties.sysprop 中沒有為設定項目定義系統屬性,surfaceflinger 會改用 ConfigStore HAL。

建構標記和系統屬性

ConfigStore 中的每個建構標記都有相符的系統屬性,如下表所示。如要進一步瞭解這些屬性,請參閱 frameworks/native/services/surfaceflinger/sysprop/SurfaceFlingerProperties.sysprop

建構旗標 系統屬性
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

使用 SurfaceFlingerProperties

以下範例說明如何使用 SurfaceFlingerProperties 程式庫和 Surface Flinger 屬性 ro.surface_flinger.vsync_event_phase_offset_ns

如要查詢參照中的屬性值,請使用屬性的 api_name 做為函式名稱。

在建構檔案中加入 SurfaceFlingerProperties,如下所示:

cc_binary {
    name: "cc_client",
    srcs: ["baz.cpp"],
    shared_libs: ["SurfaceFlingerProperties"],
}
java_library {
    name: "JavaClient",
    srcs: ["foo/bar.java"],
    libs: ["SurfaceFlingerProperties"],
}

下列 Java 程式碼片段使用 ro.surface_flinger.vsync_event_phase_offset_ns 系統屬性:

import android.sysprop.SurfaceFlingerProperties;
...

static void foo() {
    ...
    boolean temp = SurfaceFlingerProperties.vsync_event_phase_offset_ns().orElse(true);
    ...
}
...

以下 C++ 程式碼片段使用 ro.surface_flinger.vsync_event_phase_offset_ns 系統屬性:

#include <SurfaceFlingerProperties.sysprop.h>
using namespace android::sysprop;

...

void bar() {
    ...
    bool temp = SurfaceFlingerProperties::vsync_event_phase_offset_ns(true);
    ...
}
...