blob: cdd5a04120cdf530030510ab3677e87a13b070eb [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
Fan Xu021776e2018-12-05 13:34:48 -080035using ::android::BufferHubDefs::AnyClientAcquired;
36using ::android::BufferHubDefs::AnyClientGained;
37using ::android::BufferHubDefs::AnyClientPosted;
38using ::android::BufferHubDefs::IsBufferReleased;
39using ::android::BufferHubDefs::IsClientAcquired;
40using ::android::BufferHubDefs::IsClientGained;
41using ::android::BufferHubDefs::IsClientPosted;
42using ::android::BufferHubDefs::IsClientReleased;
43using ::android::BufferHubDefs::kMetadataHeaderSize;
44using ::testing::IsNull;
45using ::testing::NotNull;
46
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070047const int kWidth = 640;
48const int kHeight = 480;
49const int kLayerCount = 1;
50const int kFormat = HAL_PIXEL_FORMAT_RGBA_8888;
51const int kUsage = 0;
Fan Xu021776e2018-12-05 13:34:48 -080052const AHardwareBuffer_Desc kDesc = {kWidth, kHeight, kLayerCount, kFormat,
53 kUsage, /*stride=*/0UL, /*rfu0=*/0UL, /*rfu1=*/0ULL};
54const size_t kUserMetadataSize = 1;
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070055
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070056class BufferHubBufferTest : public ::testing::Test {
Tianyu Jiangb08b7222018-11-16 17:55:26 -080057protected:
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070058 void SetUp() override { android::hardware::ProcessState::self()->startThreadPool(); }
59};
60
Fan Xu021776e2018-12-05 13:34:48 -080061bool cmpAHardwareBufferDesc(const AHardwareBuffer_Desc& desc, const AHardwareBuffer_Desc& other) {
62 // Not comparing stride because it's unknown before allocation
63 return desc.format == other.format && desc.height == other.height &&
64 desc.layers == other.layers && desc.usage == other.usage && desc.width == other.width;
65}
66
Tianyu Jiangb08b7222018-11-16 17:55:26 -080067class BufferHubBufferStateTransitionTest : public BufferHubBufferTest {
68protected:
69 void SetUp() override {
70 BufferHubBufferTest::SetUp();
71 CreateTwoClientsOfABuffer();
72 }
73
74 std::unique_ptr<BufferHubBuffer> b1;
Tianyu Jiangec97b762019-01-07 17:14:02 -080075 uint32_t b1ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080076 std::unique_ptr<BufferHubBuffer> b2;
Tianyu Jiangec97b762019-01-07 17:14:02 -080077 uint32_t b2ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080078
79private:
80 // Creates b1 and b2 as the clients of the same buffer for testing.
81 void CreateTwoClientsOfABuffer();
82};
83
84void BufferHubBufferStateTransitionTest::CreateTwoClientsOfABuffer() {
85 b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage, kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -080086 ASSERT_THAT(b1, NotNull());
Tianyu Jiangb08b7222018-11-16 17:55:26 -080087 b1ClientMask = b1->client_state_mask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080088 ASSERT_NE(b1ClientMask, 0U);
Fan Xu021776e2018-12-05 13:34:48 -080089
90 native_handle_t* token = b1->Duplicate();
91 ASSERT_THAT(token, NotNull());
92
93 // TODO(b/122543147): use a movalbe wrapper for token
94 b2 = BufferHubBuffer::Import(token);
95 native_handle_close(token);
96 native_handle_delete(token);
97 ASSERT_THAT(b2, NotNull());
98
Tianyu Jiangb08b7222018-11-16 17:55:26 -080099 b2ClientMask = b2->client_state_mask();
Tianyu Jianga99f9112018-12-13 18:23:07 -0800100 ASSERT_NE(b2ClientMask, 0U);
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800101 ASSERT_NE(b2ClientMask, b1ClientMask);
102}
103
Fan Xu021776e2018-12-05 13:34:48 -0800104TEST_F(BufferHubBufferTest, CreateBufferFails) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700105 // Buffer Creation will fail: BLOB format requires height to be 1.
106 auto b1 = BufferHubBuffer::Create(kWidth, /*height=*/2, kLayerCount,
107 /*format=*/HAL_PIXEL_FORMAT_BLOB, kUsage, kUserMetadataSize);
108
Fan Xu021776e2018-12-05 13:34:48 -0800109 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700110
111 // Buffer Creation will fail: user metadata size too large.
112 auto b2 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
113 /*userMetadataSize=*/std::numeric_limits<size_t>::max());
114
Fan Xu021776e2018-12-05 13:34:48 -0800115 EXPECT_THAT(b2, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700116
117 // Buffer Creation will fail: user metadata size too large.
118 const size_t userMetadataSize = std::numeric_limits<size_t>::max() - kMetadataHeaderSize;
119 auto b3 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
120 userMetadataSize);
121
Fan Xu021776e2018-12-05 13:34:48 -0800122 EXPECT_THAT(b3, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700123}
124
Fan Xu021776e2018-12-05 13:34:48 -0800125TEST_F(BufferHubBufferTest, CreateBuffer) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700126 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
127 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800128 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700129 EXPECT_TRUE(b1->IsConnected());
130 EXPECT_TRUE(b1->IsValid());
Fan Xu021776e2018-12-05 13:34:48 -0800131 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), kDesc));
132 EXPECT_EQ(b1->user_metadata_size(), kUserMetadataSize);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700133}
134
Fan Xu021776e2018-12-05 13:34:48 -0800135TEST_F(BufferHubBufferTest, DuplicateAndImportBuffer) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700136 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
137 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800138 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700139 EXPECT_TRUE(b1->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700140
Fan Xu021776e2018-12-05 13:34:48 -0800141 native_handle_t* token = b1->Duplicate();
142 EXPECT_TRUE(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700143
144 // The detached buffer should still be valid.
145 EXPECT_TRUE(b1->IsConnected());
146 EXPECT_TRUE(b1->IsValid());
147
Fan Xu021776e2018-12-05 13:34:48 -0800148 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
149 native_handle_close(token);
150 native_handle_delete(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700151
Fan Xu021776e2018-12-05 13:34:48 -0800152 ASSERT_THAT(b2, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700153 EXPECT_TRUE(b2->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700154
Fan Xu021776e2018-12-05 13:34:48 -0800155 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), b2->desc()));
156 EXPECT_EQ(b1->user_metadata_size(), b2->user_metadata_size());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700157
158 // These two buffer instances are based on the same physical buffer under the
159 // hood, so they should share the same id.
Fan Xu021776e2018-12-05 13:34:48 -0800160 EXPECT_EQ(b1->id(), b2->id());
Tianyu Jiang7e204b72018-10-26 15:39:18 -0700161 // We use client_state_mask() to tell those two instances apart.
Fan Xu021776e2018-12-05 13:34:48 -0800162 EXPECT_NE(b1->client_state_mask(), b2->client_state_mask());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700163
Tianyuf669f6a2018-10-10 15:34:32 -0700164 // Both buffer instances should be in released state currently.
165 EXPECT_TRUE(IsBufferReleased(b1->buffer_state()));
166 EXPECT_TRUE(IsBufferReleased(b2->buffer_state()));
Fan Xu5cf47bc2019-01-15 15:02:15 -0800167
168 // The event fd should behave like duped event fds.
169 const BufferHubEventFd& eventFd1 = b1->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800170 ASSERT_GE(eventFd1.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800171 const BufferHubEventFd& eventFd2 = b2->eventFd();
Tianyu Jiangce232742019-01-29 10:17:31 -0800172 ASSERT_GE(eventFd2.get(), 0);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800173
174 base::unique_fd epollFd(epoll_create(64));
175 ASSERT_GE(epollFd.get(), 0);
176
177 // Add eventFd1 to epoll set, and signal eventFd2.
178 epoll_event e = {.events = EPOLLIN | EPOLLET, .data = {.u32 = 0}};
Tianyu Jiangce232742019-01-29 10:17:31 -0800179 ASSERT_EQ(epoll_ctl(epollFd.get(), EPOLL_CTL_ADD, eventFd1.get(), &e), 0) << strerror(errno);
Fan Xu5cf47bc2019-01-15 15:02:15 -0800180
181 std::array<epoll_event, 1> events;
182 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
183
184 eventFd2.signal();
185 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 1);
186
187 // The epoll fd is edge triggered, so it only responds to the eventFd once.
188 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
189
190 eventFd2.signal();
191 eventFd2.clear();
192 EXPECT_EQ(epoll_wait(epollFd.get(), events.data(), events.size(), 0), 0);
Fan Xu021776e2018-12-05 13:34:48 -0800193}
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700194
Fan Xu021776e2018-12-05 13:34:48 -0800195TEST_F(BufferHubBufferTest, ImportFreedBuffer) {
196 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
197 kUserMetadataSize);
198 ASSERT_THAT(b1, NotNull());
199 EXPECT_TRUE(b1->IsValid());
200
201 native_handle_t* token = b1->Duplicate();
202 EXPECT_TRUE(token);
203
204 // Explicitly destroy b1. Backend buffer should be freed and token becomes invalid
205 b1.reset();
206
207 // TODO(b/122543147): use a movalbe wrapper for token
208 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
209 native_handle_close(token);
210 native_handle_delete(token);
211
212 // Import should fail with INVALID_TOKEN
213 EXPECT_THAT(b2, IsNull());
214}
215
216// nullptr must not crash the service
217TEST_F(BufferHubBufferTest, ImportNullToken) {
218 auto b1 = BufferHubBuffer::Import(nullptr);
219 EXPECT_THAT(b1, IsNull());
220}
221
222// TODO(b/118180214): remove the comment after ag/5856474 landed
223// This test has a very little chance to fail (number of existing tokens / 2 ^ 32)
224TEST_F(BufferHubBufferTest, ImportInvalidToken) {
225 native_handle_t* token = native_handle_create(/*numFds=*/0, /*numInts=*/1);
226 token->data[0] = 0;
227
228 auto b1 = BufferHubBuffer::Import(token);
229 native_handle_delete(token);
230
231 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700232}
233
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800234TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromReleasedState) {
235 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
236
237 // Successful gaining the buffer should change the buffer state bit of b1 to
238 // gained state, other client state bits to released state.
239 EXPECT_EQ(b1->Gain(), 0);
240 EXPECT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
241}
242
243TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromGainedState) {
244 ASSERT_EQ(b1->Gain(), 0);
245 auto current_buffer_state = b1->buffer_state();
246 ASSERT_TRUE(IsClientGained(current_buffer_state, b1ClientMask));
247
248 // Gaining from gained state by the same client should not return error.
249 EXPECT_EQ(b1->Gain(), 0);
250
251 // Gaining from gained state by another client should return error.
252 EXPECT_EQ(b2->Gain(), -EBUSY);
253}
254
255TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromAcquiredState) {
256 ASSERT_EQ(b1->Gain(), 0);
257 ASSERT_EQ(b1->Post(), 0);
258 ASSERT_EQ(b2->Acquire(), 0);
259 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
260
261 // Gaining from acquired state should fail.
262 EXPECT_EQ(b1->Gain(), -EBUSY);
263 EXPECT_EQ(b2->Gain(), -EBUSY);
264}
265
266TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromOtherClientInPostedState) {
267 ASSERT_EQ(b1->Gain(), 0);
268 ASSERT_EQ(b1->Post(), 0);
269 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
270
271 // Gaining a buffer who has other posted client should succeed.
272 EXPECT_EQ(b1->Gain(), 0);
273}
274
275TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromSelfInPostedState) {
276 ASSERT_EQ(b1->Gain(), 0);
277 ASSERT_EQ(b1->Post(), 0);
278 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
279
280 // A posted client should be able to gain the buffer when there is no other clients in
281 // acquired state.
282 EXPECT_EQ(b2->Gain(), 0);
283}
284
285TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromOtherInGainedState) {
286 ASSERT_EQ(b1->Gain(), 0);
287 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
288
289 EXPECT_EQ(b2->Post(), -EBUSY);
290}
291
292TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromSelfInGainedState) {
293 ASSERT_EQ(b1->Gain(), 0);
294 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
295
296 EXPECT_EQ(b1->Post(), 0);
297 auto current_buffer_state = b1->buffer_state();
298 EXPECT_TRUE(IsClientReleased(current_buffer_state, b1ClientMask));
299 EXPECT_TRUE(IsClientPosted(current_buffer_state, b2ClientMask));
300}
301
302TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromPostedState) {
303 ASSERT_EQ(b1->Gain(), 0);
304 ASSERT_EQ(b1->Post(), 0);
305 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
306
307 // Post from posted state should fail.
308 EXPECT_EQ(b1->Post(), -EBUSY);
309 EXPECT_EQ(b2->Post(), -EBUSY);
310}
311
312TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromAcquiredState) {
313 ASSERT_EQ(b1->Gain(), 0);
314 ASSERT_EQ(b1->Post(), 0);
315 ASSERT_EQ(b2->Acquire(), 0);
316 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
317
318 // Posting from acquired state should fail.
319 EXPECT_EQ(b1->Post(), -EBUSY);
320 EXPECT_EQ(b2->Post(), -EBUSY);
321}
322
323TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromReleasedState) {
324 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
325
326 // Posting from released state should fail.
327 EXPECT_EQ(b1->Post(), -EBUSY);
328 EXPECT_EQ(b2->Post(), -EBUSY);
329}
330
331TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInPostedState) {
332 ASSERT_EQ(b1->Gain(), 0);
333 ASSERT_EQ(b1->Post(), 0);
334 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
335
336 // Acquire from posted state should pass.
337 EXPECT_EQ(b2->Acquire(), 0);
338}
339
340TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromOtherInPostedState) {
341 ASSERT_EQ(b1->Gain(), 0);
342 ASSERT_EQ(b1->Post(), 0);
343 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
344
345 // Acquire from released state should fail, although there are other clients
346 // in posted state.
347 EXPECT_EQ(b1->Acquire(), -EBUSY);
348}
349
350TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInAcquiredState) {
351 ASSERT_EQ(b1->Gain(), 0);
352 ASSERT_EQ(b1->Post(), 0);
353 ASSERT_EQ(b2->Acquire(), 0);
354 auto current_buffer_state = b1->buffer_state();
355 ASSERT_TRUE(IsClientAcquired(current_buffer_state, b2ClientMask));
356
357 // Acquiring from acquired state by the same client should not error out.
358 EXPECT_EQ(b2->Acquire(), 0);
359}
360
361TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromReleasedState) {
362 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
363
364 // Acquiring form released state should fail.
365 EXPECT_EQ(b1->Acquire(), -EBUSY);
366 EXPECT_EQ(b2->Acquire(), -EBUSY);
367}
368
369TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromGainedState) {
370 ASSERT_EQ(b1->Gain(), 0);
371 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
372
373 // Acquiring from gained state should fail.
374 EXPECT_EQ(b1->Acquire(), -EBUSY);
375 EXPECT_EQ(b2->Acquire(), -EBUSY);
376}
377
378TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInReleasedState) {
379 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
380
381 EXPECT_EQ(b1->Release(), 0);
382}
383
384TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInGainedState) {
385 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
386 ASSERT_EQ(b1->Gain(), 0);
387 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
388
389 EXPECT_EQ(b1->Release(), 0);
390}
391
392TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInPostedState) {
393 ASSERT_EQ(b1->Gain(), 0);
394 ASSERT_EQ(b1->Post(), 0);
395 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
396
397 EXPECT_EQ(b2->Release(), 0);
398}
399
400TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInAcquiredState) {
401 ASSERT_EQ(b1->Gain(), 0);
402 ASSERT_EQ(b1->Post(), 0);
403 ASSERT_EQ(b2->Acquire(), 0);
404 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
405
406 EXPECT_EQ(b2->Release(), 0);
407}
408
Tianyu Jiangec97b762019-01-07 17:14:02 -0800409TEST_F(BufferHubBufferStateTransitionTest, BasicUsage) {
410 // 1 producer buffer and 1 consumer buffer initialised in testcase setup.
411 // Test if this set of basic operation succeed:
412 // Producer post three times to the consumer, and released by consumer.
413 for (int i = 0; i < 3; ++i) {
414 ASSERT_EQ(b1->Gain(), 0);
415 ASSERT_EQ(b1->Post(), 0);
416 ASSERT_EQ(b2->Acquire(), 0);
417 ASSERT_EQ(b2->Release(), 0);
418 }
419}
420
421TEST_F(BufferHubBufferTest, createNewConsumerAfterGain) {
422 // Create a poducer buffer and gain.
423 std::unique_ptr<BufferHubBuffer> b1 =
424 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
425 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800426 ASSERT_THAT(b1, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800427 ASSERT_EQ(b1->Gain(), 0);
428
429 // Create a consumer of the buffer and test if the consumer can acquire the
430 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800431 // TODO(b/122543147): use a movalbe wrapper for token
432 native_handle_t* token = b1->Duplicate();
433 ASSERT_TRUE(token);
434
435 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
436 native_handle_close(token);
437 native_handle_delete(token);
438
439 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800440 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
441
442 ASSERT_EQ(b1->Post(), 0);
443 EXPECT_EQ(b2->Acquire(), 0);
444}
445
446TEST_F(BufferHubBufferTest, createNewConsumerAfterPost) {
447 // Create a poducer buffer and post.
448 std::unique_ptr<BufferHubBuffer> b1 =
449 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
450 kUserMetadataSize);
451 ASSERT_EQ(b1->Gain(), 0);
452 ASSERT_EQ(b1->Post(), 0);
453
454 // Create a consumer of the buffer and test if the consumer can acquire the
455 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800456 // TODO(b/122543147): use a movalbe wrapper for token
457 native_handle_t* token = b1->Duplicate();
458 ASSERT_TRUE(token);
459
460 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
461 native_handle_close(token);
462 native_handle_delete(token);
463
464 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800465 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
466
467 EXPECT_EQ(b2->Acquire(), 0);
468}
469
Fan Xuca70b7b2018-10-31 13:20:12 -0700470} // namespace
Fan Xu021776e2018-12-05 13:34:48 -0800471
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700472} // namespace android