Loading libs/nativewindow/Android.bp +5 −0 Original line number Diff line number Diff line Loading @@ -85,6 +85,11 @@ cc_library { export_header_lib_headers: [ "libnativebase_headers", ], stubs: { symbol_file: "libnativewindow.map.txt", versions: ["29"], }, } llndk_library { Loading libs/nativewindow/libnativewindow.map.txt +2 −2 Original line number Diff line number Diff line Loading @@ -2,9 +2,9 @@ LIBNATIVEWINDOW { global: AHardwareBuffer_acquire; AHardwareBuffer_allocate; AHardwareBuffer_createFromHandle; # llndk AHardwareBuffer_createFromHandle; # llndk # apex AHardwareBuffer_describe; AHardwareBuffer_getNativeHandle; # llndk AHardwareBuffer_getNativeHandle; # llndk # apex AHardwareBuffer_isSupported; # introduced=29 AHardwareBuffer_lock; AHardwareBuffer_lockAndGetInfo; # introduced=29 Loading libs/nativewindow/tests/AHardwareBufferTest.cpp +27 −2 Original line number Diff line number Diff line Loading @@ -20,6 +20,7 @@ #include <android/hardware_buffer.h> #include <private/android/AHardwareBufferHelpers.h> #include <android/hardware/graphics/common/1.0/types.h> #include <vndk/hardware_buffer.h> #include <gtest/gtest.h> Loading Loading @@ -106,3 +107,27 @@ EXPECT_TRUE(TestUsageConversion( AHARDWAREBUFFER_USAGE_GPU_COLOR_OUTPUT | AHARDWAREBUFFER_USAGE_GPU_SAMPLED_IMAGE | AHARDWAREBUFFER_USAGE_VENDOR_1 | AHARDWAREBUFFER_USAGE_VENDOR_13)); } TEST(AHardwareBufferTest, GetCreateHandleTest) { AHardwareBuffer_Desc desc{ .width = 64, .height = 1, .layers = 1, .format = AHARDWAREBUFFER_FORMAT_BLOB, .usage = AHARDWAREBUFFER_USAGE_CPU_READ_OFTEN | AHARDWAREBUFFER_USAGE_CPU_WRITE_OFTEN, .stride = 64, }; AHardwareBuffer* buffer = nullptr; EXPECT_EQ(0, AHardwareBuffer_allocate(&desc, &buffer)); const native_handle_t* handle = AHardwareBuffer_getNativeHandle(buffer); EXPECT_NE(nullptr, handle); AHardwareBuffer* otherBuffer = nullptr; EXPECT_EQ(0, AHardwareBuffer_createFromHandle( &desc, handle, AHARDWAREBUFFER_CREATE_FROM_HANDLE_METHOD_CLONE, &otherBuffer)); EXPECT_NE(nullptr, otherBuffer); AHardwareBuffer_release(buffer); AHardwareBuffer_release(otherBuffer); } Loading
libs/nativewindow/Android.bp +5 −0 Original line number Diff line number Diff line Loading @@ -85,6 +85,11 @@ cc_library { export_header_lib_headers: [ "libnativebase_headers", ], stubs: { symbol_file: "libnativewindow.map.txt", versions: ["29"], }, } llndk_library { Loading
libs/nativewindow/libnativewindow.map.txt +2 −2 Original line number Diff line number Diff line Loading @@ -2,9 +2,9 @@ LIBNATIVEWINDOW { global: AHardwareBuffer_acquire; AHardwareBuffer_allocate; AHardwareBuffer_createFromHandle; # llndk AHardwareBuffer_createFromHandle; # llndk # apex AHardwareBuffer_describe; AHardwareBuffer_getNativeHandle; # llndk AHardwareBuffer_getNativeHandle; # llndk # apex AHardwareBuffer_isSupported; # introduced=29 AHardwareBuffer_lock; AHardwareBuffer_lockAndGetInfo; # introduced=29 Loading
libs/nativewindow/tests/AHardwareBufferTest.cpp +27 −2 Original line number Diff line number Diff line Loading @@ -20,6 +20,7 @@ #include <android/hardware_buffer.h> #include <private/android/AHardwareBufferHelpers.h> #include <android/hardware/graphics/common/1.0/types.h> #include <vndk/hardware_buffer.h> #include <gtest/gtest.h> Loading Loading @@ -106,3 +107,27 @@ EXPECT_TRUE(TestUsageConversion( AHARDWAREBUFFER_USAGE_GPU_COLOR_OUTPUT | AHARDWAREBUFFER_USAGE_GPU_SAMPLED_IMAGE | AHARDWAREBUFFER_USAGE_VENDOR_1 | AHARDWAREBUFFER_USAGE_VENDOR_13)); } TEST(AHardwareBufferTest, GetCreateHandleTest) { AHardwareBuffer_Desc desc{ .width = 64, .height = 1, .layers = 1, .format = AHARDWAREBUFFER_FORMAT_BLOB, .usage = AHARDWAREBUFFER_USAGE_CPU_READ_OFTEN | AHARDWAREBUFFER_USAGE_CPU_WRITE_OFTEN, .stride = 64, }; AHardwareBuffer* buffer = nullptr; EXPECT_EQ(0, AHardwareBuffer_allocate(&desc, &buffer)); const native_handle_t* handle = AHardwareBuffer_getNativeHandle(buffer); EXPECT_NE(nullptr, handle); AHardwareBuffer* otherBuffer = nullptr; EXPECT_EQ(0, AHardwareBuffer_createFromHandle( &desc, handle, AHARDWAREBUFFER_CREATE_FROM_HANDLE_METHOD_CLONE, &otherBuffer)); EXPECT_NE(nullptr, otherBuffer); AHardwareBuffer_release(buffer); AHardwareBuffer_release(otherBuffer); }