blob: cd744cd1066032a0f2903b20fdd78c008d940e62 [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
Fan Xu93c94902018-11-01 12:22:05 -070019#include <android/hardware_buffer.h>
Fan Xu467e08f2018-11-09 15:58:51 -080020#include <cutils/native_handle.h>
Fan Xu021776e2018-12-05 13:34:48 -080021#include <gmock/gmock.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070022#include <gtest/gtest.h>
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070023#include <hidl/ServiceManagement.h>
24#include <hwbinder/IPCThreadState.h>
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070025#include <ui/BufferHubBuffer.h>
26
27namespace android {
28
29namespace {
30
Fan Xu021776e2018-12-05 13:34:48 -080031using ::android::BufferHubDefs::AnyClientAcquired;
32using ::android::BufferHubDefs::AnyClientGained;
33using ::android::BufferHubDefs::AnyClientPosted;
34using ::android::BufferHubDefs::IsBufferReleased;
35using ::android::BufferHubDefs::IsClientAcquired;
36using ::android::BufferHubDefs::IsClientGained;
37using ::android::BufferHubDefs::IsClientPosted;
38using ::android::BufferHubDefs::IsClientReleased;
39using ::android::BufferHubDefs::kMetadataHeaderSize;
40using ::testing::IsNull;
41using ::testing::NotNull;
42
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070043const int kWidth = 640;
44const int kHeight = 480;
45const int kLayerCount = 1;
46const int kFormat = HAL_PIXEL_FORMAT_RGBA_8888;
47const int kUsage = 0;
Fan Xu021776e2018-12-05 13:34:48 -080048const AHardwareBuffer_Desc kDesc = {kWidth, kHeight, kLayerCount, kFormat,
49 kUsage, /*stride=*/0UL, /*rfu0=*/0UL, /*rfu1=*/0ULL};
50const size_t kUserMetadataSize = 1;
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -070051
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070052class BufferHubBufferTest : public ::testing::Test {
Tianyu Jiangb08b7222018-11-16 17:55:26 -080053protected:
Jiwen 'Steve' Caid9f2abe2018-10-20 17:03:13 -070054 void SetUp() override { android::hardware::ProcessState::self()->startThreadPool(); }
55};
56
Fan Xu021776e2018-12-05 13:34:48 -080057bool cmpAHardwareBufferDesc(const AHardwareBuffer_Desc& desc, const AHardwareBuffer_Desc& other) {
58 // Not comparing stride because it's unknown before allocation
59 return desc.format == other.format && desc.height == other.height &&
60 desc.layers == other.layers && desc.usage == other.usage && desc.width == other.width;
61}
62
Tianyu Jiangb08b7222018-11-16 17:55:26 -080063class BufferHubBufferStateTransitionTest : public BufferHubBufferTest {
64protected:
65 void SetUp() override {
66 BufferHubBufferTest::SetUp();
67 CreateTwoClientsOfABuffer();
68 }
69
70 std::unique_ptr<BufferHubBuffer> b1;
Tianyu Jiangec97b762019-01-07 17:14:02 -080071 uint32_t b1ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080072 std::unique_ptr<BufferHubBuffer> b2;
Tianyu Jiangec97b762019-01-07 17:14:02 -080073 uint32_t b2ClientMask = 0U;
Tianyu Jiangb08b7222018-11-16 17:55:26 -080074
75private:
76 // Creates b1 and b2 as the clients of the same buffer for testing.
77 void CreateTwoClientsOfABuffer();
78};
79
80void BufferHubBufferStateTransitionTest::CreateTwoClientsOfABuffer() {
81 b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage, kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -080082 ASSERT_THAT(b1, NotNull());
Tianyu Jiangb08b7222018-11-16 17:55:26 -080083 b1ClientMask = b1->client_state_mask();
Tianyu Jianga99f9112018-12-13 18:23:07 -080084 ASSERT_NE(b1ClientMask, 0U);
Fan Xu021776e2018-12-05 13:34:48 -080085
86 native_handle_t* token = b1->Duplicate();
87 ASSERT_THAT(token, NotNull());
88
89 // TODO(b/122543147): use a movalbe wrapper for token
90 b2 = BufferHubBuffer::Import(token);
91 native_handle_close(token);
92 native_handle_delete(token);
93 ASSERT_THAT(b2, NotNull());
94
Tianyu Jiangb08b7222018-11-16 17:55:26 -080095 b2ClientMask = b2->client_state_mask();
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.
102 auto b1 = BufferHubBuffer::Create(kWidth, /*height=*/2, kLayerCount,
103 /*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.
108 auto b2 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
109 /*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;
115 auto b3 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
116 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) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700122 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
123 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800124 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700125 EXPECT_TRUE(b1->IsConnected());
126 EXPECT_TRUE(b1->IsValid());
Fan Xu021776e2018-12-05 13:34:48 -0800127 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), kDesc));
128 EXPECT_EQ(b1->user_metadata_size(), kUserMetadataSize);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700129}
130
Fan Xu021776e2018-12-05 13:34:48 -0800131TEST_F(BufferHubBufferTest, DuplicateAndImportBuffer) {
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700132 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
133 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800134 ASSERT_THAT(b1, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700135 EXPECT_TRUE(b1->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700136
Fan Xu021776e2018-12-05 13:34:48 -0800137 native_handle_t* token = b1->Duplicate();
138 EXPECT_TRUE(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700139
140 // The detached buffer should still be valid.
141 EXPECT_TRUE(b1->IsConnected());
142 EXPECT_TRUE(b1->IsValid());
143
Fan Xu021776e2018-12-05 13:34:48 -0800144 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
145 native_handle_close(token);
146 native_handle_delete(token);
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700147
Fan Xu021776e2018-12-05 13:34:48 -0800148 ASSERT_THAT(b2, NotNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700149 EXPECT_TRUE(b2->IsValid());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700150
Fan Xu021776e2018-12-05 13:34:48 -0800151 EXPECT_TRUE(cmpAHardwareBufferDesc(b1->desc(), b2->desc()));
152 EXPECT_EQ(b1->user_metadata_size(), b2->user_metadata_size());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700153
154 // These two buffer instances are based on the same physical buffer under the
155 // hood, so they should share the same id.
Fan Xu021776e2018-12-05 13:34:48 -0800156 EXPECT_EQ(b1->id(), b2->id());
Tianyu Jiang7e204b72018-10-26 15:39:18 -0700157 // We use client_state_mask() to tell those two instances apart.
Fan Xu021776e2018-12-05 13:34:48 -0800158 EXPECT_NE(b1->client_state_mask(), b2->client_state_mask());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700159
Tianyuf669f6a2018-10-10 15:34:32 -0700160 // Both buffer instances should be in released state currently.
161 EXPECT_TRUE(IsBufferReleased(b1->buffer_state()));
162 EXPECT_TRUE(IsBufferReleased(b2->buffer_state()));
Fan Xu021776e2018-12-05 13:34:48 -0800163}
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700164
Fan Xu021776e2018-12-05 13:34:48 -0800165TEST_F(BufferHubBufferTest, ImportFreedBuffer) {
166 auto b1 = BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
167 kUserMetadataSize);
168 ASSERT_THAT(b1, NotNull());
169 EXPECT_TRUE(b1->IsValid());
170
171 native_handle_t* token = b1->Duplicate();
172 EXPECT_TRUE(token);
173
174 // Explicitly destroy b1. Backend buffer should be freed and token becomes invalid
175 b1.reset();
176
177 // TODO(b/122543147): use a movalbe wrapper for token
178 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
179 native_handle_close(token);
180 native_handle_delete(token);
181
182 // Import should fail with INVALID_TOKEN
183 EXPECT_THAT(b2, IsNull());
184}
185
186// nullptr must not crash the service
187TEST_F(BufferHubBufferTest, ImportNullToken) {
188 auto b1 = BufferHubBuffer::Import(nullptr);
189 EXPECT_THAT(b1, IsNull());
190}
191
192// TODO(b/118180214): remove the comment after ag/5856474 landed
193// This test has a very little chance to fail (number of existing tokens / 2 ^ 32)
194TEST_F(BufferHubBufferTest, ImportInvalidToken) {
195 native_handle_t* token = native_handle_create(/*numFds=*/0, /*numInts=*/1);
196 token->data[0] = 0;
197
198 auto b1 = BufferHubBuffer::Import(token);
199 native_handle_delete(token);
200
201 EXPECT_THAT(b1, IsNull());
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700202}
203
Tianyu Jiangb08b7222018-11-16 17:55:26 -0800204TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromReleasedState) {
205 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
206
207 // Successful gaining the buffer should change the buffer state bit of b1 to
208 // gained state, other client state bits to released state.
209 EXPECT_EQ(b1->Gain(), 0);
210 EXPECT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
211}
212
213TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromGainedState) {
214 ASSERT_EQ(b1->Gain(), 0);
215 auto current_buffer_state = b1->buffer_state();
216 ASSERT_TRUE(IsClientGained(current_buffer_state, b1ClientMask));
217
218 // Gaining from gained state by the same client should not return error.
219 EXPECT_EQ(b1->Gain(), 0);
220
221 // Gaining from gained state by another client should return error.
222 EXPECT_EQ(b2->Gain(), -EBUSY);
223}
224
225TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromAcquiredState) {
226 ASSERT_EQ(b1->Gain(), 0);
227 ASSERT_EQ(b1->Post(), 0);
228 ASSERT_EQ(b2->Acquire(), 0);
229 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
230
231 // Gaining from acquired state should fail.
232 EXPECT_EQ(b1->Gain(), -EBUSY);
233 EXPECT_EQ(b2->Gain(), -EBUSY);
234}
235
236TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromOtherClientInPostedState) {
237 ASSERT_EQ(b1->Gain(), 0);
238 ASSERT_EQ(b1->Post(), 0);
239 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
240
241 // Gaining a buffer who has other posted client should succeed.
242 EXPECT_EQ(b1->Gain(), 0);
243}
244
245TEST_F(BufferHubBufferStateTransitionTest, GainBuffer_fromSelfInPostedState) {
246 ASSERT_EQ(b1->Gain(), 0);
247 ASSERT_EQ(b1->Post(), 0);
248 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
249
250 // A posted client should be able to gain the buffer when there is no other clients in
251 // acquired state.
252 EXPECT_EQ(b2->Gain(), 0);
253}
254
255TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromOtherInGainedState) {
256 ASSERT_EQ(b1->Gain(), 0);
257 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
258
259 EXPECT_EQ(b2->Post(), -EBUSY);
260}
261
262TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromSelfInGainedState) {
263 ASSERT_EQ(b1->Gain(), 0);
264 ASSERT_TRUE(IsClientGained(b1->buffer_state(), b1ClientMask));
265
266 EXPECT_EQ(b1->Post(), 0);
267 auto current_buffer_state = b1->buffer_state();
268 EXPECT_TRUE(IsClientReleased(current_buffer_state, b1ClientMask));
269 EXPECT_TRUE(IsClientPosted(current_buffer_state, b2ClientMask));
270}
271
272TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromPostedState) {
273 ASSERT_EQ(b1->Gain(), 0);
274 ASSERT_EQ(b1->Post(), 0);
275 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
276
277 // Post from posted state should fail.
278 EXPECT_EQ(b1->Post(), -EBUSY);
279 EXPECT_EQ(b2->Post(), -EBUSY);
280}
281
282TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromAcquiredState) {
283 ASSERT_EQ(b1->Gain(), 0);
284 ASSERT_EQ(b1->Post(), 0);
285 ASSERT_EQ(b2->Acquire(), 0);
286 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
287
288 // Posting from acquired state should fail.
289 EXPECT_EQ(b1->Post(), -EBUSY);
290 EXPECT_EQ(b2->Post(), -EBUSY);
291}
292
293TEST_F(BufferHubBufferStateTransitionTest, PostBuffer_fromReleasedState) {
294 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
295
296 // Posting from released state should fail.
297 EXPECT_EQ(b1->Post(), -EBUSY);
298 EXPECT_EQ(b2->Post(), -EBUSY);
299}
300
301TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInPostedState) {
302 ASSERT_EQ(b1->Gain(), 0);
303 ASSERT_EQ(b1->Post(), 0);
304 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
305
306 // Acquire from posted state should pass.
307 EXPECT_EQ(b2->Acquire(), 0);
308}
309
310TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromOtherInPostedState) {
311 ASSERT_EQ(b1->Gain(), 0);
312 ASSERT_EQ(b1->Post(), 0);
313 ASSERT_TRUE(IsClientPosted(b1->buffer_state(), b2ClientMask));
314
315 // Acquire from released state should fail, although there are other clients
316 // in posted state.
317 EXPECT_EQ(b1->Acquire(), -EBUSY);
318}
319
320TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromSelfInAcquiredState) {
321 ASSERT_EQ(b1->Gain(), 0);
322 ASSERT_EQ(b1->Post(), 0);
323 ASSERT_EQ(b2->Acquire(), 0);
324 auto current_buffer_state = b1->buffer_state();
325 ASSERT_TRUE(IsClientAcquired(current_buffer_state, b2ClientMask));
326
327 // Acquiring from acquired state by the same client should not error out.
328 EXPECT_EQ(b2->Acquire(), 0);
329}
330
331TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromReleasedState) {
332 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
333
334 // Acquiring form released state should fail.
335 EXPECT_EQ(b1->Acquire(), -EBUSY);
336 EXPECT_EQ(b2->Acquire(), -EBUSY);
337}
338
339TEST_F(BufferHubBufferStateTransitionTest, AcquireBuffer_fromGainedState) {
340 ASSERT_EQ(b1->Gain(), 0);
341 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
342
343 // Acquiring from gained state should fail.
344 EXPECT_EQ(b1->Acquire(), -EBUSY);
345 EXPECT_EQ(b2->Acquire(), -EBUSY);
346}
347
348TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInReleasedState) {
349 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
350
351 EXPECT_EQ(b1->Release(), 0);
352}
353
354TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInGainedState) {
355 ASSERT_TRUE(IsBufferReleased(b1->buffer_state()));
356 ASSERT_EQ(b1->Gain(), 0);
357 ASSERT_TRUE(AnyClientGained(b1->buffer_state()));
358
359 EXPECT_EQ(b1->Release(), 0);
360}
361
362TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInPostedState) {
363 ASSERT_EQ(b1->Gain(), 0);
364 ASSERT_EQ(b1->Post(), 0);
365 ASSERT_TRUE(AnyClientPosted(b1->buffer_state()));
366
367 EXPECT_EQ(b2->Release(), 0);
368}
369
370TEST_F(BufferHubBufferStateTransitionTest, ReleaseBuffer_fromSelfInAcquiredState) {
371 ASSERT_EQ(b1->Gain(), 0);
372 ASSERT_EQ(b1->Post(), 0);
373 ASSERT_EQ(b2->Acquire(), 0);
374 ASSERT_TRUE(AnyClientAcquired(b1->buffer_state()));
375
376 EXPECT_EQ(b2->Release(), 0);
377}
378
Tianyu Jiangec97b762019-01-07 17:14:02 -0800379TEST_F(BufferHubBufferStateTransitionTest, BasicUsage) {
380 // 1 producer buffer and 1 consumer buffer initialised in testcase setup.
381 // Test if this set of basic operation succeed:
382 // Producer post three times to the consumer, and released by consumer.
383 for (int i = 0; i < 3; ++i) {
384 ASSERT_EQ(b1->Gain(), 0);
385 ASSERT_EQ(b1->Post(), 0);
386 ASSERT_EQ(b2->Acquire(), 0);
387 ASSERT_EQ(b2->Release(), 0);
388 }
389}
390
391TEST_F(BufferHubBufferTest, createNewConsumerAfterGain) {
392 // Create a poducer buffer and gain.
393 std::unique_ptr<BufferHubBuffer> b1 =
394 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
395 kUserMetadataSize);
Fan Xu021776e2018-12-05 13:34:48 -0800396 ASSERT_THAT(b1, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800397 ASSERT_EQ(b1->Gain(), 0);
398
399 // Create a consumer of the buffer and test if the consumer can acquire the
400 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800401 // TODO(b/122543147): use a movalbe wrapper for token
402 native_handle_t* token = b1->Duplicate();
403 ASSERT_TRUE(token);
404
405 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
406 native_handle_close(token);
407 native_handle_delete(token);
408
409 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800410 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
411
412 ASSERT_EQ(b1->Post(), 0);
413 EXPECT_EQ(b2->Acquire(), 0);
414}
415
416TEST_F(BufferHubBufferTest, createNewConsumerAfterPost) {
417 // Create a poducer buffer and post.
418 std::unique_ptr<BufferHubBuffer> b1 =
419 BufferHubBuffer::Create(kWidth, kHeight, kLayerCount, kFormat, kUsage,
420 kUserMetadataSize);
421 ASSERT_EQ(b1->Gain(), 0);
422 ASSERT_EQ(b1->Post(), 0);
423
424 // Create a consumer of the buffer and test if the consumer can acquire the
425 // buffer if producer posts.
Fan Xu021776e2018-12-05 13:34:48 -0800426 // TODO(b/122543147): use a movalbe wrapper for token
427 native_handle_t* token = b1->Duplicate();
428 ASSERT_TRUE(token);
429
430 std::unique_ptr<BufferHubBuffer> b2 = BufferHubBuffer::Import(token);
431 native_handle_close(token);
432 native_handle_delete(token);
433
434 ASSERT_THAT(b2, NotNull());
Tianyu Jiangec97b762019-01-07 17:14:02 -0800435 ASSERT_NE(b1->client_state_mask(), b2->client_state_mask());
436
437 EXPECT_EQ(b2->Acquire(), 0);
438}
439
Fan Xuca70b7b2018-10-31 13:20:12 -0700440} // namespace
Fan Xu021776e2018-12-05 13:34:48 -0800441
Jiwen 'Steve' Cai0e7ee222018-10-12 17:20:40 -0700442} // namespace android