blob: 0c73a72debbfac8b1873e35fa07f2c3ab5c6d83e [file] [log] [blame]
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -07001/*
2 * Copyright 2018 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_TAG "BufferHubBufferTest"
18
Tianyu Jiangce232742019-01-29 10:17:31 -080019#include <errno.h>
Fan Xu5cf47bc2019-01-15 15:02:15 -080020#include <sys/epoll.h>
21
Jiwen 'Steve' Cai1f98fbe2019-03-29 14:57:17 -070022#include <android/frameworks/bufferhub/1.0/IBufferHub.h>
Fan Xu93c94902018-11-01 12:22:05 -070023#include <android/hardware_buffer.h>
Fan Xu467e08f2018-11-09 15:58:51 -080024#include <cutils/native_handle.h>
Fan Xu021776e2018-12-05 13:34:48 -080025#include <gmock/gmock.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070026#include <gtest/gtest.h>
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070027#include <hidl/ServiceManagement.h>
28#include <hwbinder/IPCThreadState.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070029#include <ui/BufferHubBuffer.h>
Fan Xu5cf47bc2019-01-15 15:02:15 -080030#include <ui/BufferHubEventFd.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070031
32namespace android {
33
34namespace {
35
Tianyu Jiang727ede42019-02-01 11:44:51 -080036using ::android::BufferHubDefs::isAnyClientAcquired;
37using ::android::BufferHubDefs::isAnyClientGained;
38using ::android::BufferHubDefs::isAnyClientPosted;
39using ::android::BufferHubDefs::isClientAcquired;
40using ::android::BufferHubDefs::isClientGained;
41using ::android::BufferHubDefs::isClientPosted;
42using ::android::BufferHubDefs::isClientReleased;
Fan Xu021776e2018-12-05 13:34:48 -080043using ::android::BufferHubDefs::kMetadataHeaderSize;
Jiwen 'Steve' Cai1f98fbe2019-03-29 14:57:17 -070044using ::android::frameworks::bufferhub::V1_0::IBufferHub;
Fan Xu021776e2018-12-05 13:34:48 -080045using ::testing::IsNull;
46using ::testing::NotNull;
47
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070048const int kWidth = 640;
49const int kHeight = 480;
50const int kLayerCount = 1;
51const int kFormat = HAL_PIXEL_FORMAT_RGBA_8888;
52const int kUsage = 0;
Fan Xu021776e2018-12-05 13:34:48 -080053const AHardwareBuffer_Desc kDesc = {kWidth, kHeight, kLayerCount, kFormat,
54 kUsage, /*stride=*/0UL, /*rfu0=*/0UL, /*rfu1=*/0ULL};
55const size_t kUserMetadataSize = 1;
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070056
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070057class BufferHubBufferTest : public ::testing::Test {
Tianyu Jiangb08b7222018-11-16 17:55:26 -080058protected:
Jiwen 'Steve' Cai1f98fbe2019-03-29 14:57:17 -070059 void SetUp() override {
60 android::hardware::ProcessState::self()->startThreadPool();
61
62 if (!BufferHubServiceRunning()) {
63 // TODO(b/112940221): Enforce the test cross all devices once BufferHub lands in Android
64 // R for all Android varieties.
65 GTEST_SKIP() << "Skip test as the BufferHub service is not running.";
66 }
67 }
68
69 bool BufferHubServiceRunning() {
70 sp<IBufferHub> bufferhub = IBufferHub::getService();
71 return bufferhub.get() != nullptr;
72 }
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070073};
74
Fan Xu021776e2018-12-05 13:34:48 -080075bool cmpAHardwareBufferDesc(const AHardwareBuffer_Desc& desc, const AHardwareBuffer_Desc& other) {
76 // Not comparing stride because it's unknown before allocation
77 return desc.format == other.format && desc.height == other.height &&
78 desc.layers == other.layers && desc.usage == other.usage && desc.width == other.width;
79}
80
Tianyu Jiangb08b7222018-11-16 17:55:26 -080081class BufferHubBufferStateTransitionTest : public BufferHubBufferTest {
82protected:
83 void SetUp() override {
84 BufferHubBufferTest::SetUp();
Jiwen 'Steve' Cai1f98fbe2019-03-29 14:57:17 -070085
86 if (IsSkipped()) {
87 // If the base class' SetUp() stated the test should be skipped, we should short
88 // circuit this sub-class' logic.
89 return;
90 }
91
Tianyu Jiangb08b7222018-11-16 17:55:26 -080092 CreateTwoClientsOfABuffer();
93 }
94
95 std::unique_ptr<BufferHubBuffer> b1;
Tianyu Jiangec97b762019-01-07 17:14:02 -080096 uint32_t b1ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080097 std::unique_ptr<BufferHubBuffer> b2;
Tianyu Jiangec97b762019-01-07 17:14:02 -080098 uint32_t b2ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080099
100private:
101 // Creates b1 and b2 as the clients of the same buffer for testing.
102 void CreateTwoClientsOfABuffer();
103};
104
105void BufferHubBufferStateTransitionTest::CreateTwoClientsOfABuffer() {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800106 b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage, kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800107 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800108 b1ClientMask = b1->clientStateMask();
Tianyu Jianga99f9112018-12-13 18:23:07 -0800109 ASSERT_NE(b1ClientMask, 0U);
Fan Xu021776e2018-12-05 13:34:48 -0800110
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800111 sp<NativeHandle> token = b1->duplicate();
Fan Xu021776e2018-12-05 13:34:48 -0800112 ASSERT_THAT(token, NotNull());
113
Tianyu Jiang727ede42019-02-01 11:44:51 -0800114 b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800115 ASSERT_THAT(b2, NotNull());
116
Tianyu Jiang727ede42019-02-01 11:44:51 -0800117 b2ClientMask = b2->clientStateMask();
Tianyu Jianga99f9112018-12-13 18:23:07 -0800118 ASSERT_NE(b2ClientMask, 0U);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800119 ASSERT_NE(b2ClientMask, b1ClientMask);
120}
121
Fan Xu021776e2018-12-05 13:34:48 -0800122TEST_F(BufferHubBufferTest, CreateBufferFails) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700123 // Buffer Creation will fail: BLOB format requires height to be 1.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800124 auto b1 = BufferHubBuffer::create(kWidth, /*height=*/2, kLayerCount,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700125 /*format=*/HAL_PIXEL_FORMAT_BLOB, kUsage, kUserMetadataSize);
126
Fan Xu021776e2018-12-05 13:34:48 -0800127 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700128
129 // Buffer Creation will fail: user metadata size too large.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800130 auto b2 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700131 /*userMetadataSize=*/std::numeric_limits<size_t>::max());
132
Fan Xu021776e2018-12-05 13:34:48 -0800133 EXPECT_THAT(b2, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700134
135 // Buffer Creation will fail: user metadata size too large.
136 const size_t userMetadataSize = std::numeric_limits<size_t>::max() - kMetadataHeaderSize;
Tianyu Jiang727ede42019-02-01 11:44:51 -0800137 auto b3 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700138 userMetadataSize);
139
Fan Xu021776e2018-12-05 13:34:48 -0800140 EXPECT_THAT(b3, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700141}
142
Fan Xu021776e2018-12-05 13:34:48 -0800143TEST_F(BufferHubBufferTest, CreateBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800144 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700145 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800146 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800147 EXPECT_TRUE(b1->isConnected());
148 EXPECT_TRUE(b1->isValid());
Fan Xu021776e2018-12-05 13:34:48 -0800149 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), kDesc));
Tianyu Jiang727ede42019-02-01 11:44:51 -0800150 EXPECT_EQ(b1->userMetadataSize(), kUserMetadataSize);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700151}
152
Fan Xu021776e2018-12-05 13:34:48 -0800153TEST_F(BufferHubBufferTest, DuplicateAndImportBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800154 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700155 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800156 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800157 EXPECT_TRUE(b1->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700158
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800159 sp<NativeHandle> token = b1->duplicate();
160 ASSERT_THAT(token, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700161
162 // The detached buffer should still be valid.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800163 EXPECT_TRUE(b1->isConnected());
164 EXPECT_TRUE(b1->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700165
Tianyu Jiang727ede42019-02-01 11:44:51 -0800166 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700167
Fan Xu021776e2018-12-05 13:34:48 -0800168 ASSERT_THAT(b2, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800169 EXPECT_TRUE(b2->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700170
Fan Xu021776e2018-12-05 13:34:48 -0800171 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), b2->desc()));
Tianyu Jiang727ede42019-02-01 11:44:51 -0800172 EXPECT_EQ(b1->userMetadataSize(), b2->userMetadataSize());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700173
174 // These two buffer instances are based on the same physical buffer under the
175 // hood, so they should share the same id.
Fan Xu021776e2018-12-05 13:34:48 -0800176 EXPECT_EQ(b1->id(), b2->id());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800177 // We use clientStateMask() to tell those two instances apart.
178 EXPECT_NE(b1->clientStateMask(), b2->clientStateMask());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700179
Tianyuf669f6a2018-10-10 15:34:32 -0700180 // Both buffer instances should be in released state currently.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800181 EXPECT_TRUE(b1->isReleased());
182 EXPECT_TRUE(b2->isReleased());
Fan Xu5cf47bc2019-01-15 15:02:15 -0800183
184 // The event fd should behave like duped event fds.
185 const BufferHubEventFd& eventFd1 = b1->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800186 ASSERT_GE(eventFd1.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800187 const BufferHubEventFd& eventFd2 = b2->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800188 ASSERT_GE(eventFd2.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800189
190 base::unique_fd epollFd(epoll_create(64));
191 ASSERT_GE(epollFd.get(), 0);
192
193 // Add eventFd1 to epoll set, and signal eventFd2.
194 epoll_event e = {.events = EPOLLIN | EPOLLET, .data = {.u32 = 0}};
Tianyu Jiangce232742019-01-29 10:17:31 -0800195 ASSERT_EQ(epoll_ctl(epollFd.get(), EPOLL_CTL_ADD, eventFd1.get(), &e), 0) << strerror(errno);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800196
197 std::array<epoll_event, 1> events;
198 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
199
200 eventFd2.signal();
201 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 1);
202
203 // The epoll fd is edge triggered, so it only responds to the eventFd once.
204 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
205
206 eventFd2.signal();
207 eventFd2.clear();
208 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
Fan Xu021776e2018-12-05 13:34:48 -0800209}
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700210
Fan Xu021776e2018-12-05 13:34:48 -0800211TEST_F(BufferHubBufferTest, ImportFreedBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800212 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Fan Xu021776e2018-12-05 13:34:48 -0800213 kUserMetadataSize);
214 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800215 EXPECT_TRUE(b1->isValid());
Fan Xu021776e2018-12-05 13:34:48 -0800216
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800217 sp<NativeHandle> token = b1->duplicate();
218 ASSERT_THAT(token, NotNull());
Fan Xu021776e2018-12-05 13:34:48 -0800219
220 // Explicitly destroy b1. Backend buffer should be freed and token becomes invalid
221 b1.reset();
222
Tianyu Jiang727ede42019-02-01 11:44:51 -0800223 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800224
225 // Import should fail with INVALID_TOKEN
226 EXPECT_THAT(b2, IsNull());
227}
228
229// nullptr must not crash the service
230TEST_F(BufferHubBufferTest, ImportNullToken) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800231 auto b1 = BufferHubBuffer::import(nullptr);
Fan Xu021776e2018-12-05 13:34:48 -0800232 EXPECT_THAT(b1, IsNull());
233}
234
Fan Xu021776e2018-12-05 13:34:48 -0800235TEST_F(BufferHubBufferTest, ImportInvalidToken) {
236 native_handle_t* token = native_handle_create(/*numFds=*/0, /*numInts=*/1);
237 token->data[0] = 0;
238
Tianyu Jiang750c8872019-02-14 11:08:08 -0800239 sp<NativeHandle> tokenHandle = NativeHandle::create(token, /*ownHandle=*/true);
240 auto b1 = BufferHubBuffer::import(tokenHandle);
Fan Xu021776e2018-12-05 13:34:48 -0800241
242 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700243}
244
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800245TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800246 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800247
248 // Successful gaining the buffer should change the buffer state bit of b1 to
249 // gained state, other client state bits to released state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800250 EXPECT_EQ(b1->gain(), 0);
251 EXPECT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800252}
253
254TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800255 ASSERT_EQ(b1->gain(), 0);
256 auto currentBufferState = b1->bufferState();
257 ASSERT_TRUE(isClientGained(currentBufferState, b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800258
259 // Gaining from gained state by the same client should not return error.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800260 EXPECT_EQ(b1->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800261
262 // Gaining from gained state by another client should return error.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800263 EXPECT_EQ(b2->gain(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800264}
265
266TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800267 ASSERT_EQ(b1->gain(), 0);
268 ASSERT_EQ(b1->post(), 0);
269 ASSERT_EQ(b2->acquire(), 0);
270 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800271
272 // Gaining from acquired state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800273 EXPECT_EQ(b1->gain(), -EBUSY);
274 EXPECT_EQ(b2->gain(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800275}
276
277TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromOtherClientInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800278 ASSERT_EQ(b1->gain(), 0);
279 ASSERT_EQ(b1->post(), 0);
280 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800281
282 // Gaining a buffer who has other posted client should succeed.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800283 EXPECT_EQ(b1->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800284}
285
286TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800287 ASSERT_EQ(b1->gain(), 0);
288 ASSERT_EQ(b1->post(), 0);
289 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800290
291 // A posted client should be able to gain the buffer when there is no other clients in
292 // acquired state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800293 EXPECT_EQ(b2->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800294}
295
296TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromOtherInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800297 ASSERT_EQ(b1->gain(), 0);
298 ASSERT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800299
Tianyu Jiang727ede42019-02-01 11:44:51 -0800300 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800301}
302
303TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromSelfInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800304 ASSERT_EQ(b1->gain(), 0);
305 ASSERT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800306
Tianyu Jiang727ede42019-02-01 11:44:51 -0800307 EXPECT_EQ(b1->post(), 0);
308 auto currentBufferState = b1->bufferState();
309 EXPECT_TRUE(isClientReleased(currentBufferState, b1ClientMask));
310 EXPECT_TRUE(isClientPosted(currentBufferState, b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800311}
312
313TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800314 ASSERT_EQ(b1->gain(), 0);
315 ASSERT_EQ(b1->post(), 0);
316 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800317
318 // Post from posted state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800319 EXPECT_EQ(b1->post(), -EBUSY);
320 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800321}
322
323TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800324 ASSERT_EQ(b1->gain(), 0);
325 ASSERT_EQ(b1->post(), 0);
326 ASSERT_EQ(b2->acquire(), 0);
327 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800328
329 // Posting from acquired state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800330 EXPECT_EQ(b1->post(), -EBUSY);
331 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800332}
333
334TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800335 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800336
337 // Posting from released state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800338 EXPECT_EQ(b1->post(), -EBUSY);
339 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800340}
341
342TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800343 ASSERT_EQ(b1->gain(), 0);
344 ASSERT_EQ(b1->post(), 0);
345 ASSERT_TRUE(isClientPosted(b1->bufferState(), b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800346
347 // Acquire from posted state should pass.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800348 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800349}
350
351TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromOtherInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800352 ASSERT_EQ(b1->gain(), 0);
353 ASSERT_EQ(b1->post(), 0);
354 ASSERT_TRUE(isClientPosted(b1->bufferState(), b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800355
356 // Acquire from released state should fail, although there are other clients
357 // in posted state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800358 EXPECT_EQ(b1->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800359}
360
361TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800362 ASSERT_EQ(b1->gain(), 0);
363 ASSERT_EQ(b1->post(), 0);
364 ASSERT_EQ(b2->acquire(), 0);
365 auto currentBufferState = b1->bufferState();
366 ASSERT_TRUE(isClientAcquired(currentBufferState, b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800367
368 // Acquiring from acquired state by the same client should not error out.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800369 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800370}
371
372TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800373 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800374
375 // Acquiring form released state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800376 EXPECT_EQ(b1->acquire(), -EBUSY);
377 EXPECT_EQ(b2->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800378}
379
380TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800381 ASSERT_EQ(b1->gain(), 0);
382 ASSERT_TRUE(isAnyClientGained(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800383
384 // Acquiring from gained state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800385 EXPECT_EQ(b1->acquire(), -EBUSY);
386 EXPECT_EQ(b2->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800387}
388
389TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800390 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800391
Tianyu Jiang727ede42019-02-01 11:44:51 -0800392 EXPECT_EQ(b1->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800393}
394
395TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800396 ASSERT_TRUE(b1->isReleased());
397 ASSERT_EQ(b1->gain(), 0);
398 ASSERT_TRUE(isAnyClientGained(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800399
Tianyu Jiang727ede42019-02-01 11:44:51 -0800400 EXPECT_EQ(b1->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800401}
402
403TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800404 ASSERT_EQ(b1->gain(), 0);
405 ASSERT_EQ(b1->post(), 0);
406 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800407
Tianyu Jiang727ede42019-02-01 11:44:51 -0800408 EXPECT_EQ(b2->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800409}
410
411TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800412 ASSERT_EQ(b1->gain(), 0);
413 ASSERT_EQ(b1->post(), 0);
414 ASSERT_EQ(b2->acquire(), 0);
415 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800416
Tianyu Jiang727ede42019-02-01 11:44:51 -0800417 EXPECT_EQ(b2->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800418}
419
Tianyu Jiangec97b762019-01-07 17:14:02 -0800420TEST_F(BufferHubBufferStateTransitionTest, BasicUsage) {
421 // 1 producer buffer and 1 consumer buffer initialised in testcase setup.
422 // Test if this set of basic operation succeed:
423 // Producer post three times to the consumer, and released by consumer.
424 for (int i = 0; i < 3; ++i) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800425 ASSERT_EQ(b1->gain(), 0);
426 ASSERT_EQ(b1->post(), 0);
427 ASSERT_EQ(b2->acquire(), 0);
428 ASSERT_EQ(b2->release(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800429 }
430}
431
432TEST_F(BufferHubBufferTest, createNewConsumerAfterGain) {
433 // Create a poducer buffer and gain.
434 std::unique_ptr<BufferHubBuffer> b1 =
Tianyu Jiang727ede42019-02-01 11:44:51 -0800435 BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Tianyu Jiangec97b762019-01-07 17:14:02 -0800436 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800437 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800438 ASSERT_EQ(b1->gain(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800439
440 // Create a consumer of the buffer and test if the consumer can acquire the
441 // buffer if producer posts.
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800442 sp<NativeHandle> token = b1->duplicate();
443 ASSERT_THAT(token, NotNull());
Fan Xu021776e2018-12-05 13:34:48 -0800444
Tianyu Jiang727ede42019-02-01 11:44:51 -0800445 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800446
447 ASSERT_THAT(b2, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800448 ASSERT_NE(b1->clientStateMask(), b2->clientStateMask());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800449
Tianyu Jiang727ede42019-02-01 11:44:51 -0800450 ASSERT_EQ(b1->post(), 0);
451 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800452}
453
454TEST_F(BufferHubBufferTest, createNewConsumerAfterPost) {
455 // Create a poducer buffer and post.
456 std::unique_ptr<BufferHubBuffer> b1 =
Tianyu Jiang727ede42019-02-01 11:44:51 -0800457 BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Tianyu Jiangec97b762019-01-07 17:14:02 -0800458 kUserMetadataSize);
Tianyu Jiang727ede42019-02-01 11:44:51 -0800459 ASSERT_EQ(b1->gain(), 0);
460 ASSERT_EQ(b1->post(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800461
462 // Create a consumer of the buffer and test if the consumer can acquire the
463 // buffer if producer posts.
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800464 sp<NativeHandle> token = b1->duplicate();
465 ASSERT_THAT(token, NotNull());
Fan Xu021776e2018-12-05 13:34:48 -0800466
Tianyu Jiang727ede42019-02-01 11:44:51 -0800467 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800468
469 ASSERT_THAT(b2, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800470 ASSERT_NE(b1->clientStateMask(), b2->clientStateMask());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800471
Tianyu Jiang727ede42019-02-01 11:44:51 -0800472 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800473}
474
Fan Xuca70b7b2018-10-31 13:20:12 -0700475} // namespace
Fan Xu021776e2018-12-05 13:34:48 -0800476
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700477} // namespace android