SurfaceFlinger의 시스템 속성

ConfigStore HAL은 기존 공급업체 파티션을 지원할 수 있도록 AOSP에 남아 있습니다. 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"],
}

다음 자바 코드 스니펫은 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);
    ...
}
...