blob: efc1a80401d0d7fb2c4d6f52a1b63cb499b76961 [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
Fan Xu93c94902018-11-01 12:22:05 -070022#include <android/hardware_buffer.h>
Fan Xu467e08f2018-11-09 15:58:51 -080023#include <cutils/native_handle.h>
Fan Xu021776e2018-12-05 13:34:48 -080024#include <gmock/gmock.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070025#include <gtest/gtest.h>
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070026#include <hidl/ServiceManagement.h>
27#include <hwbinder/IPCThreadState.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070028#include <ui/BufferHubBuffer.h>
Fan Xu5cf47bc2019-01-15 15:02:15 -080029#include <ui/BufferHubEventFd.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070030
31namespace android {
32
33namespace {
34
Tianyu Jiang727ede42019-02-01 11:44:51 -080035using ::android::BufferHubDefs::isAnyClientAcquired;
36using ::android::BufferHubDefs::isAnyClientGained;
37using ::android::BufferHubDefs::isAnyClientPosted;
38using ::android::BufferHubDefs::isClientAcquired;
39using ::android::BufferHubDefs::isClientGained;
40using ::android::BufferHubDefs::isClientPosted;
41using ::android::BufferHubDefs::isClientReleased;
Fan Xu021776e2018-12-05 13:34:48 -080042using ::android::BufferHubDefs::kMetadataHeaderSize;
43using ::testing::IsNull;
44using ::testing::NotNull;
45
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070046const int kWidth = 640;
47const int kHeight = 480;
48const int kLayerCount = 1;
49const int kFormat = HAL_PIXEL_FORMAT_RGBA_8888;
50const int kUsage = 0;
Fan Xu021776e2018-12-05 13:34:48 -080051const AHardwareBuffer_Desc kDesc = {kWidth, kHeight, kLayerCount, kFormat,
52 kUsage, /*stride=*/0UL, /*rfu0=*/0UL, /*rfu1=*/0ULL};
53const size_t kUserMetadataSize = 1;
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070054
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070055class BufferHubBufferTest : public ::testing::Test {
Tianyu Jiangb08b7222018-11-16 17:55:26 -080056protected:
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070057 void SetUp() override { android::hardware::ProcessState::self()->startThreadPool(); }
58};
59
Fan Xu021776e2018-12-05 13:34:48 -080060bool cmpAHardwareBufferDesc(const AHardwareBuffer_Desc& desc, const AHardwareBuffer_Desc& other) {
61 // Not comparing stride because it's unknown before allocation
62 return desc.format == other.format && desc.height == other.height &&
63 desc.layers == other.layers && desc.usage == other.usage && desc.width == other.width;
64}
65
Tianyu Jiangb08b7222018-11-16 17:55:26 -080066class BufferHubBufferStateTransitionTest : public BufferHubBufferTest {
67protected:
68 void SetUp() override {
69 BufferHubBufferTest::SetUp();
70 CreateTwoClientsOfABuffer();
71 }
72
73 std::unique_ptr<BufferHubBuffer> b1;
Tianyu Jiangec97b762019-01-07 17:14:02 -080074 uint32_t b1ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080075 std::unique_ptr<BufferHubBuffer> b2;
Tianyu Jiangec97b762019-01-07 17:14:02 -080076 uint32_t b2ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080077
78private:
79 // Creates b1 and b2 as the clients of the same buffer for testing.
80 void CreateTwoClientsOfABuffer();
81};
82
83void BufferHubBufferStateTransitionTest::CreateTwoClientsOfABuffer() {
Tianyu Jiang727ede42019-02-01 11:44:51 -080084 b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage, kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -080085 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -080086 b1ClientMask = b1->clientStateMask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080087 ASSERT_NE(b1ClientMask, 0U);
Fan Xu021776e2018-12-05 13:34:48 -080088
Tianyu Jiang8a7e7652019-02-11 13:41:20 -080089 sp<NativeHandle> token = b1->duplicate();
Fan Xu021776e2018-12-05 13:34:48 -080090 ASSERT_THAT(token, NotNull());
91
Tianyu Jiang727ede42019-02-01 11:44:51 -080092 b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -080093 ASSERT_THAT(b2, NotNull());
94
Tianyu Jiang727ede42019-02-01 11:44:51 -080095 b2ClientMask = b2->clientStateMask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080096 ASSERT_NE(b2ClientMask, 0U);
Tianyu Jiangb08b7222018-11-16 17:55:26 -080097 ASSERT_NE(b2ClientMask, b1ClientMask);
98}
99
Fan Xu021776e2018-12-05 13:34:48 -0800100TEST_F(BufferHubBufferTest, CreateBufferFails) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700101 // Buffer Creation will fail: BLOB format requires height to be 1.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800102 auto b1 = BufferHubBuffer::create(kWidth, /*height=*/2, kLayerCount,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700103 /*format=*/HAL_PIXEL_FORMAT_BLOB, kUsage, kUserMetadataSize);
104
Fan Xu021776e2018-12-05 13:34:48 -0800105 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700106
107 // Buffer Creation will fail: user metadata size too large.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800108 auto b2 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700109 /*userMetadataSize=*/std::numeric_limits<size_t>::max());
110
Fan Xu021776e2018-12-05 13:34:48 -0800111 EXPECT_THAT(b2, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700112
113 // Buffer Creation will fail: user metadata size too large.
114 const size_t userMetadataSize = std::numeric_limits<size_t>::max() - kMetadataHeaderSize;
Tianyu Jiang727ede42019-02-01 11:44:51 -0800115 auto b3 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700116 userMetadataSize);
117
Fan Xu021776e2018-12-05 13:34:48 -0800118 EXPECT_THAT(b3, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700119}
120
Fan Xu021776e2018-12-05 13:34:48 -0800121TEST_F(BufferHubBufferTest, CreateBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800122 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700123 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800124 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800125 EXPECT_TRUE(b1->isConnected());
126 EXPECT_TRUE(b1->isValid());
Fan Xu021776e2018-12-05 13:34:48 -0800127 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), kDesc));
Tianyu Jiang727ede42019-02-01 11:44:51 -0800128 EXPECT_EQ(b1->userMetadataSize(), kUserMetadataSize);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700129}
130
Fan Xu021776e2018-12-05 13:34:48 -0800131TEST_F(BufferHubBufferTest, DuplicateAndImportBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800132 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700133 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800134 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800135 EXPECT_TRUE(b1->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700136
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800137 sp<NativeHandle> token = b1->duplicate();
138 ASSERT_THAT(token, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700139
140 // The detached buffer should still be valid.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800141 EXPECT_TRUE(b1->isConnected());
142 EXPECT_TRUE(b1->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700143
Tianyu Jiang727ede42019-02-01 11:44:51 -0800144 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700145
Fan Xu021776e2018-12-05 13:34:48 -0800146 ASSERT_THAT(b2, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800147 EXPECT_TRUE(b2->isValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700148
Fan Xu021776e2018-12-05 13:34:48 -0800149 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), b2->desc()));
Tianyu Jiang727ede42019-02-01 11:44:51 -0800150 EXPECT_EQ(b1->userMetadataSize(), b2->userMetadataSize());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700151
152 // These two buffer instances are based on the same physical buffer under the
153 // hood, so they should share the same id.
Fan Xu021776e2018-12-05 13:34:48 -0800154 EXPECT_EQ(b1->id(), b2->id());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800155 // We use clientStateMask() to tell those two instances apart.
156 EXPECT_NE(b1->clientStateMask(), b2->clientStateMask());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700157
Tianyuf669f6a2018-10-10 15:34:32 -0700158 // Both buffer instances should be in released state currently.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800159 EXPECT_TRUE(b1->isReleased());
160 EXPECT_TRUE(b2->isReleased());
Fan Xu5cf47bc2019-01-15 15:02:15 -0800161
162 // The event fd should behave like duped event fds.
163 const BufferHubEventFd& eventFd1 = b1->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800164 ASSERT_GE(eventFd1.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800165 const BufferHubEventFd& eventFd2 = b2->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800166 ASSERT_GE(eventFd2.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800167
168 base::unique_fd epollFd(epoll_create(64));
169 ASSERT_GE(epollFd.get(), 0);
170
171 // Add eventFd1 to epoll set, and signal eventFd2.
172 epoll_event e = {.events = EPOLLIN | EPOLLET, .data = {.u32 = 0}};
Tianyu Jiangce232742019-01-29 10:17:31 -0800173 ASSERT_EQ(epoll_ctl(epollFd.get(), EPOLL_CTL_ADD, eventFd1.get(), &e), 0) << strerror(errno);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800174
175 std::array<epoll_event, 1> events;
176 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
177
178 eventFd2.signal();
179 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 1);
180
181 // The epoll fd is edge triggered, so it only responds to the eventFd once.
182 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
183
184 eventFd2.signal();
185 eventFd2.clear();
186 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
Fan Xu021776e2018-12-05 13:34:48 -0800187}
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700188
Fan Xu021776e2018-12-05 13:34:48 -0800189TEST_F(BufferHubBufferTest, ImportFreedBuffer) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800190 auto b1 = BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Fan Xu021776e2018-12-05 13:34:48 -0800191 kUserMetadataSize);
192 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800193 EXPECT_TRUE(b1->isValid());
Fan Xu021776e2018-12-05 13:34:48 -0800194
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800195 sp<NativeHandle> token = b1->duplicate();
196 ASSERT_THAT(token, NotNull());
Fan Xu021776e2018-12-05 13:34:48 -0800197
198 // Explicitly destroy b1. Backend buffer should be freed and token becomes invalid
199 b1.reset();
200
Tianyu Jiang727ede42019-02-01 11:44:51 -0800201 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800202
203 // Import should fail with INVALID_TOKEN
204 EXPECT_THAT(b2, IsNull());
205}
206
207// nullptr must not crash the service
208TEST_F(BufferHubBufferTest, ImportNullToken) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800209 auto b1 = BufferHubBuffer::import(nullptr);
Fan Xu021776e2018-12-05 13:34:48 -0800210 EXPECT_THAT(b1, IsNull());
211}
212
Fan Xu021776e2018-12-05 13:34:48 -0800213TEST_F(BufferHubBufferTest, ImportInvalidToken) {
214 native_handle_t* token = native_handle_create(/*numFds=*/0, /*numInts=*/1);
215 token->data[0] = 0;
216
Tianyu Jiang750c8872019-02-14 11:08:08 -0800217 sp<NativeHandle> tokenHandle = NativeHandle::create(token, /*ownHandle=*/true);
218 auto b1 = BufferHubBuffer::import(tokenHandle);
Fan Xu021776e2018-12-05 13:34:48 -0800219
220 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700221}
222
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800223TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800224 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800225
226 // Successful gaining the buffer should change the buffer state bit of b1 to
227 // gained state, other client state bits to released state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800228 EXPECT_EQ(b1->gain(), 0);
229 EXPECT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800230}
231
232TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800233 ASSERT_EQ(b1->gain(), 0);
234 auto currentBufferState = b1->bufferState();
235 ASSERT_TRUE(isClientGained(currentBufferState, b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800236
237 // Gaining from gained state by the same client should not return error.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800238 EXPECT_EQ(b1->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800239
240 // Gaining from gained state by another client should return error.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800241 EXPECT_EQ(b2->gain(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800242}
243
244TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800245 ASSERT_EQ(b1->gain(), 0);
246 ASSERT_EQ(b1->post(), 0);
247 ASSERT_EQ(b2->acquire(), 0);
248 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800249
250 // Gaining from acquired state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800251 EXPECT_EQ(b1->gain(), -EBUSY);
252 EXPECT_EQ(b2->gain(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800253}
254
255TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromOtherClientInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800256 ASSERT_EQ(b1->gain(), 0);
257 ASSERT_EQ(b1->post(), 0);
258 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800259
260 // Gaining a buffer who has other posted client should succeed.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800261 EXPECT_EQ(b1->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800262}
263
264TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800265 ASSERT_EQ(b1->gain(), 0);
266 ASSERT_EQ(b1->post(), 0);
267 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800268
269 // A posted client should be able to gain the buffer when there is no other clients in
270 // acquired state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800271 EXPECT_EQ(b2->gain(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800272}
273
274TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromOtherInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800275 ASSERT_EQ(b1->gain(), 0);
276 ASSERT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800277
Tianyu Jiang727ede42019-02-01 11:44:51 -0800278 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800279}
280
281TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromSelfInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800282 ASSERT_EQ(b1->gain(), 0);
283 ASSERT_TRUE(isClientGained(b1->bufferState(), b1ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800284
Tianyu Jiang727ede42019-02-01 11:44:51 -0800285 EXPECT_EQ(b1->post(), 0);
286 auto currentBufferState = b1->bufferState();
287 EXPECT_TRUE(isClientReleased(currentBufferState, b1ClientMask));
288 EXPECT_TRUE(isClientPosted(currentBufferState, b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800289}
290
291TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800292 ASSERT_EQ(b1->gain(), 0);
293 ASSERT_EQ(b1->post(), 0);
294 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800295
296 // Post from posted state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800297 EXPECT_EQ(b1->post(), -EBUSY);
298 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800299}
300
301TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800302 ASSERT_EQ(b1->gain(), 0);
303 ASSERT_EQ(b1->post(), 0);
304 ASSERT_EQ(b2->acquire(), 0);
305 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800306
307 // Posting from acquired state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800308 EXPECT_EQ(b1->post(), -EBUSY);
309 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800310}
311
312TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800313 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800314
315 // Posting from released state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800316 EXPECT_EQ(b1->post(), -EBUSY);
317 EXPECT_EQ(b2->post(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800318}
319
320TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800321 ASSERT_EQ(b1->gain(), 0);
322 ASSERT_EQ(b1->post(), 0);
323 ASSERT_TRUE(isClientPosted(b1->bufferState(), b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800324
325 // Acquire from posted state should pass.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800326 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800327}
328
329TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromOtherInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800330 ASSERT_EQ(b1->gain(), 0);
331 ASSERT_EQ(b1->post(), 0);
332 ASSERT_TRUE(isClientPosted(b1->bufferState(), b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800333
334 // Acquire from released state should fail, although there are other clients
335 // in posted state.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800336 EXPECT_EQ(b1->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800337}
338
339TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800340 ASSERT_EQ(b1->gain(), 0);
341 ASSERT_EQ(b1->post(), 0);
342 ASSERT_EQ(b2->acquire(), 0);
343 auto currentBufferState = b1->bufferState();
344 ASSERT_TRUE(isClientAcquired(currentBufferState, b2ClientMask));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800345
346 // Acquiring from acquired state by the same client should not error out.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800347 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800348}
349
350TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800351 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800352
353 // Acquiring form released state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800354 EXPECT_EQ(b1->acquire(), -EBUSY);
355 EXPECT_EQ(b2->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800356}
357
358TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800359 ASSERT_EQ(b1->gain(), 0);
360 ASSERT_TRUE(isAnyClientGained(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800361
362 // Acquiring from gained state should fail.
Tianyu Jiang727ede42019-02-01 11:44:51 -0800363 EXPECT_EQ(b1->acquire(), -EBUSY);
364 EXPECT_EQ(b2->acquire(), -EBUSY);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800365}
366
367TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInReleasedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800368 ASSERT_TRUE(b1->isReleased());
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800369
Tianyu Jiang727ede42019-02-01 11:44:51 -0800370 EXPECT_EQ(b1->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800371}
372
373TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInGainedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800374 ASSERT_TRUE(b1->isReleased());
375 ASSERT_EQ(b1->gain(), 0);
376 ASSERT_TRUE(isAnyClientGained(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800377
Tianyu Jiang727ede42019-02-01 11:44:51 -0800378 EXPECT_EQ(b1->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800379}
380
381TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInPostedState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800382 ASSERT_EQ(b1->gain(), 0);
383 ASSERT_EQ(b1->post(), 0);
384 ASSERT_TRUE(isAnyClientPosted(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800385
Tianyu Jiang727ede42019-02-01 11:44:51 -0800386 EXPECT_EQ(b2->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800387}
388
389TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInAcquiredState) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800390 ASSERT_EQ(b1->gain(), 0);
391 ASSERT_EQ(b1->post(), 0);
392 ASSERT_EQ(b2->acquire(), 0);
393 ASSERT_TRUE(isAnyClientAcquired(b1->bufferState()));
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800394
Tianyu Jiang727ede42019-02-01 11:44:51 -0800395 EXPECT_EQ(b2->release(), 0);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800396}
397
Tianyu Jiangec97b762019-01-07 17:14:02 -0800398TEST_F(BufferHubBufferStateTransitionTest, BasicUsage) {
399 // 1 producer buffer and 1 consumer buffer initialised in testcase setup.
400 // Test if this set of basic operation succeed:
401 // Producer post three times to the consumer, and released by consumer.
402 for (int i = 0; i < 3; ++i) {
Tianyu Jiang727ede42019-02-01 11:44:51 -0800403 ASSERT_EQ(b1->gain(), 0);
404 ASSERT_EQ(b1->post(), 0);
405 ASSERT_EQ(b2->acquire(), 0);
406 ASSERT_EQ(b2->release(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800407 }
408}
409
410TEST_F(BufferHubBufferTest, createNewConsumerAfterGain) {
411 // Create a poducer buffer and gain.
412 std::unique_ptr<BufferHubBuffer> b1 =
Tianyu Jiang727ede42019-02-01 11:44:51 -0800413 BufferHubBuffer::create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
Tianyu Jiangec97b762019-01-07 17:14:02 -0800414 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800415 ASSERT_THAT(b1, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800416 ASSERT_EQ(b1->gain(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800417
418 // Create a consumer of the buffer and test if the consumer can acquire the
419 // buffer if producer posts.
Tianyu Jiang8a7e7652019-02-11 13:41:20 -0800420 sp<NativeHandle> token = b1->duplicate();
421 ASSERT_THAT(token, NotNull());
Fan Xu021776e2018-12-05 13:34:48 -0800422
Tianyu Jiang727ede42019-02-01 11:44:51 -0800423 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::import(token);
Fan Xu021776e2018-12-05 13:34:48 -0800424
425 ASSERT_THAT(b2, NotNull());
Tianyu Jiang727ede42019-02-01 11:44:51 -0800426 ASSERT_NE(b1->clientStateMask(), b2->clientStateMask());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800427
Tianyu Jiang727ede42019-02-01 11:44:51 -0800428 ASSERT_EQ(b1->post(), 0);
429 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800430}
431
432TEST_F(BufferHubBufferTest, createNewConsumerAfterPost) {
433 // Create a poducer buffer and post.
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);
Tianyu Jiang727ede42019-02-01 11:44:51 -0800437 ASSERT_EQ(b1->gain(), 0);
438 ASSERT_EQ(b1->post(), 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 EXPECT_EQ(b2->acquire(), 0);
Tianyu Jiangec97b762019-01-07 17:14:02 -0800451}
452
Fan Xuca70b7b2018-10-31 13:20:12 -0700453} // namespace
Fan Xu021776e2018-12-05 13:34:48 -0800454
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700455} // namespace android