Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "cc/resources/resource_provider.h" | 5 #include "cc/resources/resource_provider.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <map> | 8 #include <map> |
| 9 #include <set> | 9 #include <set> |
| 10 | 10 |
| (...skipping 1027 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1038 id1); | 1038 id1); |
| 1039 child_resource_provider_->DeleteResource(id1); | 1039 child_resource_provider_->DeleteResource(id1); |
| 1040 EXPECT_EQ(1u, child_resource_provider_->num_resources()); | 1040 EXPECT_EQ(1u, child_resource_provider_->num_resources()); |
| 1041 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | 1041 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); |
| 1042 } | 1042 } |
| 1043 | 1043 |
| 1044 EXPECT_EQ(0u, child_resource_provider_->num_resources()); | 1044 EXPECT_EQ(0u, child_resource_provider_->num_resources()); |
| 1045 resource_provider_->DestroyChild(child_id); | 1045 resource_provider_->DestroyChild(child_id); |
| 1046 } | 1046 } |
| 1047 | 1047 |
| 1048 class TestFence : public ResourceProvider::Fence { | |
| 1049 public: | |
| 1050 TestFence() {} | |
| 1051 | |
| 1052 void Set() override {} | |
| 1053 bool HasPassed() override { return passed; } | |
| 1054 void Wait() override {} | |
| 1055 | |
| 1056 bool passed = false; | |
| 1057 | |
| 1058 private: | |
| 1059 ~TestFence() override {} | |
| 1060 }; | |
| 1061 | |
| 1062 TEST_P(ResourceProviderTest, ReadLockFenceStopsReturnToChildOrDelete) { | |
| 1063 if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) | |
| 1064 return; | |
| 1065 gfx::Size size(1, 1); | |
| 1066 ResourceFormat format = RGBA_8888; | |
| 1067 | |
| 1068 ResourceId id1 = child_resource_provider_->CreateResource( | |
| 1069 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
| 1070 uint8_t data1[4] = {1, 2, 3, 4}; | |
| 1071 child_resource_provider_->CopyToResource(id1, data1, size); | |
| 1072 child_resource_provider_->EnableReadLockFencesForTesting(id1); | |
| 1073 ReturnedResourceArray returned_to_child; | |
| 1074 int child_id = | |
| 1075 resource_provider_->CreateChild(GetReturnCallback(&returned_to_child)); | |
| 1076 | |
| 1077 // Transfer some resources to the parent. | |
| 1078 ResourceProvider::ResourceIdArray resource_ids_to_transfer; | |
| 1079 resource_ids_to_transfer.push_back(id1); | |
| 1080 TransferableResourceArray list; | |
| 1081 child_resource_provider_->PrepareSendToParent(resource_ids_to_transfer, | |
| 1082 &list); | |
| 1083 ASSERT_EQ(1u, list.size()); | |
| 1084 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | |
|
piman
2015/06/16 16:46:20
nit: you could add an EXPECT_TRUE(list[0].read_loc
Daniele Castagna
2015/06/17 15:20:41
Done.
| |
| 1085 | |
| 1086 resource_provider_->ReceiveFromChild(child_id, list); | |
| 1087 | |
| 1088 scoped_refptr<TestFence> fence(new TestFence); | |
| 1089 resource_provider_->SetReadLockFence(fence.get()); | |
| 1090 { | |
| 1091 unsigned parent_id = list.front().id; | |
| 1092 resource_provider_->WaitSyncPointIfNeeded(parent_id); | |
| 1093 ResourceProvider::ScopedReadLockGL lock(resource_provider_.get(), | |
| 1094 parent_id); | |
| 1095 } | |
| 1096 resource_provider_->DeclareUsedResourcesFromChild( | |
| 1097 child_id, ResourceProvider::ResourceIdSet()); | |
| 1098 EXPECT_EQ(0u, returned_to_child.size()); | |
| 1099 | |
| 1100 resource_provider_->DeclareUsedResourcesFromChild( | |
| 1101 child_id, ResourceProvider::ResourceIdSet()); | |
| 1102 EXPECT_EQ(0u, returned_to_child.size()); | |
| 1103 fence->passed = true; | |
| 1104 | |
| 1105 resource_provider_->DeclareUsedResourcesFromChild( | |
| 1106 child_id, ResourceProvider::ResourceIdSet()); | |
| 1107 EXPECT_EQ(1u, returned_to_child.size()); | |
| 1108 | |
| 1109 child_resource_provider_->ReceiveReturnsFromParent(returned_to_child); | |
| 1110 child_resource_provider_->DeleteResource(id1); | |
| 1111 EXPECT_EQ(0u, child_resource_provider_->num_resources()); | |
| 1112 } | |
| 1113 | |
| 1114 TEST_P(ResourceProviderTest, ReadLockFenceDestroyChild) { | |
| 1115 if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) | |
| 1116 return; | |
| 1117 gfx::Size size(1, 1); | |
| 1118 ResourceFormat format = RGBA_8888; | |
| 1119 | |
| 1120 ResourceId id1 = child_resource_provider_->CreateResource( | |
| 1121 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
| 1122 uint8_t data[4] = {1, 2, 3, 4}; | |
| 1123 child_resource_provider_->CopyToResource(id1, data, size); | |
| 1124 child_resource_provider_->EnableReadLockFencesForTesting(id1); | |
| 1125 | |
| 1126 ResourceId id2 = child_resource_provider_->CreateResource( | |
| 1127 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
| 1128 child_resource_provider_->CopyToResource(id2, data, size); | |
| 1129 | |
| 1130 ReturnedResourceArray returned_to_child; | |
| 1131 int child_id = | |
| 1132 resource_provider_->CreateChild(GetReturnCallback(&returned_to_child)); | |
| 1133 | |
| 1134 // Transfer resources to the parent. | |
| 1135 ResourceProvider::ResourceIdArray resource_ids_to_transfer; | |
| 1136 resource_ids_to_transfer.push_back(id1); | |
| 1137 resource_ids_to_transfer.push_back(id2); | |
| 1138 TransferableResourceArray list; | |
| 1139 child_resource_provider_->PrepareSendToParent(resource_ids_to_transfer, | |
| 1140 &list); | |
| 1141 ASSERT_EQ(2u, list.size()); | |
| 1142 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | |
| 1143 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id2)); | |
| 1144 | |
| 1145 resource_provider_->ReceiveFromChild(child_id, list); | |
| 1146 | |
| 1147 scoped_refptr<TestFence> fence(new TestFence); | |
| 1148 resource_provider_->SetReadLockFence(fence.get()); | |
| 1149 { | |
| 1150 for (size_t i = 0; i < list.size(); i++) { | |
| 1151 unsigned parent_id = list[i].id; | |
| 1152 resource_provider_->WaitSyncPointIfNeeded(parent_id); | |
| 1153 ResourceProvider::ScopedReadLockGL lock(resource_provider_.get(), | |
| 1154 parent_id); | |
| 1155 } | |
| 1156 } | |
| 1157 EXPECT_EQ(0u, returned_to_child.size()); | |
| 1158 | |
| 1159 EXPECT_EQ(2u, resource_provider_->num_resources()); | |
| 1160 | |
| 1161 resource_provider_->DestroyChild(child_id); | |
| 1162 | |
| 1163 EXPECT_EQ(0u, resource_provider_->num_resources()); | |
| 1164 EXPECT_EQ(2u, returned_to_child.size()); | |
| 1165 | |
| 1166 bool swapped = id1 != returned_to_child.front().id; | |
| 1167 EXPECT_TRUE(returned_to_child[swapped ? 1 : 0].lost); | |
|
piman
2015/06/16 16:46:20
nit: Maybe something along the lines of:
EXPECT_EQ
Daniele Castagna
2015/06/17 15:20:41
Done.
| |
| 1168 EXPECT_FALSE(returned_to_child[swapped ? 0 : 1].lost); | |
| 1169 | |
| 1170 child_resource_provider_->ReceiveReturnsFromParent(returned_to_child); | |
| 1171 child_resource_provider_->DeleteResource(id1); | |
| 1172 child_resource_provider_->DeleteResource(id2); | |
| 1173 EXPECT_EQ(0u, child_resource_provider_->num_resources()); | |
| 1174 } | |
| 1175 | |
| 1176 TEST_P(ResourceProviderTest, ReadLockFenceContextLost) { | |
| 1177 if (GetParam() != ResourceProvider::RESOURCE_TYPE_GL_TEXTURE) | |
| 1178 return; | |
| 1179 gfx::Size size(1, 1); | |
| 1180 ResourceFormat format = RGBA_8888; | |
| 1181 | |
| 1182 ResourceId id1 = child_resource_provider_->CreateResource( | |
| 1183 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
| 1184 uint8_t data[4] = {1, 2, 3, 4}; | |
| 1185 child_resource_provider_->CopyToResource(id1, data, size); | |
| 1186 child_resource_provider_->EnableReadLockFencesForTesting(id1); | |
| 1187 | |
| 1188 ResourceId id2 = child_resource_provider_->CreateResource( | |
| 1189 size, GL_CLAMP_TO_EDGE, ResourceProvider::TEXTURE_HINT_IMMUTABLE, format); | |
| 1190 child_resource_provider_->CopyToResource(id2, data, size); | |
| 1191 | |
| 1192 ReturnedResourceArray returned_to_child; | |
| 1193 int child_id = | |
| 1194 resource_provider_->CreateChild(GetReturnCallback(&returned_to_child)); | |
| 1195 | |
| 1196 // Transfer resources to the parent. | |
| 1197 ResourceProvider::ResourceIdArray resource_ids_to_transfer; | |
| 1198 resource_ids_to_transfer.push_back(id1); | |
| 1199 resource_ids_to_transfer.push_back(id2); | |
| 1200 TransferableResourceArray list; | |
| 1201 child_resource_provider_->PrepareSendToParent(resource_ids_to_transfer, | |
| 1202 &list); | |
| 1203 ASSERT_EQ(2u, list.size()); | |
| 1204 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id1)); | |
| 1205 EXPECT_TRUE(child_resource_provider_->InUseByConsumer(id2)); | |
| 1206 | |
| 1207 resource_provider_->ReceiveFromChild(child_id, list); | |
| 1208 | |
| 1209 scoped_refptr<TestFence> fence(new TestFence); | |
| 1210 resource_provider_->SetReadLockFence(fence.get()); | |
| 1211 { | |
| 1212 for (size_t i = 0; i < list.size(); i++) { | |
| 1213 unsigned parent_id = list[i].id; | |
| 1214 resource_provider_->WaitSyncPointIfNeeded(parent_id); | |
| 1215 ResourceProvider::ScopedReadLockGL lock(resource_provider_.get(), | |
| 1216 parent_id); | |
| 1217 } | |
| 1218 } | |
| 1219 EXPECT_EQ(0u, returned_to_child.size()); | |
| 1220 | |
| 1221 EXPECT_EQ(2u, resource_provider_->num_resources()); | |
| 1222 resource_provider_->DidLoseOutputSurface(); | |
| 1223 resource_provider_ = nullptr; | |
| 1224 | |
| 1225 EXPECT_EQ(2u, returned_to_child.size()); | |
| 1226 | |
| 1227 EXPECT_TRUE(returned_to_child[0].lost); | |
| 1228 EXPECT_TRUE(returned_to_child[1].lost); | |
| 1229 } | |
| 1230 | |
| 1048 TEST_P(ResourceProviderTest, TransferSoftwareResources) { | 1231 TEST_P(ResourceProviderTest, TransferSoftwareResources) { |
| 1049 if (GetParam() != ResourceProvider::RESOURCE_TYPE_BITMAP) | 1232 if (GetParam() != ResourceProvider::RESOURCE_TYPE_BITMAP) |
| 1050 return; | 1233 return; |
| 1051 | 1234 |
| 1052 gfx::Size size(1, 1); | 1235 gfx::Size size(1, 1); |
| 1053 ResourceFormat format = RGBA_8888; | 1236 ResourceFormat format = RGBA_8888; |
| 1054 size_t pixel_size = TextureSizeBytes(size, format); | 1237 size_t pixel_size = TextureSizeBytes(size, format); |
| 1055 ASSERT_EQ(4U, pixel_size); | 1238 ASSERT_EQ(4U, pixel_size); |
| 1056 | 1239 |
| 1057 ResourceId id1 = child_resource_provider_->CreateResource( | 1240 ResourceId id1 = child_resource_provider_->CreateResource( |
| (...skipping 2570 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 3628 resource_provider->AllocateForTesting(id); | 3811 resource_provider->AllocateForTesting(id); |
| 3629 Mock::VerifyAndClearExpectations(context); | 3812 Mock::VerifyAndClearExpectations(context); |
| 3630 | 3813 |
| 3631 DCHECK_EQ(10u, context->PeekTextureId()); | 3814 DCHECK_EQ(10u, context->PeekTextureId()); |
| 3632 resource_provider->DeleteResource(id); | 3815 resource_provider->DeleteResource(id); |
| 3633 } | 3816 } |
| 3634 } | 3817 } |
| 3635 | 3818 |
| 3636 } // namespace | 3819 } // namespace |
| 3637 } // namespace cc | 3820 } // namespace cc |
| OLD | NEW |