OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 <stddef.h> | 5 #include <stddef.h> |
6 #include <stdint.h> | 6 #include <stdint.h> |
7 | 7 |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/memory/ptr_util.h" | 9 #include "base/memory/ptr_util.h" |
10 #include "base/test/test_simple_task_runner.h" | 10 #include "base/test/test_simple_task_runner.h" |
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
116 RASTER_BUFFER_PROVIDER_TYPE_GPU, | 116 RASTER_BUFFER_PROVIDER_TYPE_GPU, |
117 RASTER_BUFFER_PROVIDER_TYPE_BITMAP | 117 RASTER_BUFFER_PROVIDER_TYPE_BITMAP |
118 }; | 118 }; |
119 | 119 |
120 static const int kTimeLimitMillis = 2000; | 120 static const int kTimeLimitMillis = 2000; |
121 static const int kWarmupRuns = 5; | 121 static const int kWarmupRuns = 5; |
122 static const int kTimeCheckInterval = 10; | 122 static const int kTimeCheckInterval = 10; |
123 | 123 |
124 class PerfImageDecodeTaskImpl : public TileTask { | 124 class PerfImageDecodeTaskImpl : public TileTask { |
125 public: | 125 public: |
126 PerfImageDecodeTaskImpl() : TileTask(true) {} | 126 PerfImageDecodeTaskImpl() : TileTask(TileTask::Type::IMAGE_DECODE, true) {} |
127 | 127 |
128 // Overridden from Task: | 128 // Overridden from Task: |
129 void RunOnWorkerThread() override {} | 129 void RunOnWorkerThread() override {} |
130 | 130 |
131 // Overridden from TileTask: | |
132 void ScheduleOnOriginThread(RasterBufferProvider* provider) override {} | |
133 void CompleteOnOriginThread(RasterBufferProvider* provider) override { | |
134 Reset(); | |
135 } | |
136 | |
137 void Reset() { | |
138 state().Reset(); | |
139 did_complete_ = false; | |
140 } | |
141 | |
142 protected: | 131 protected: |
143 ~PerfImageDecodeTaskImpl() override {} | 132 ~PerfImageDecodeTaskImpl() override {} |
144 | 133 |
145 private: | 134 private: |
146 DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl); | 135 DISALLOW_COPY_AND_ASSIGN(PerfImageDecodeTaskImpl); |
147 }; | 136 }; |
148 | 137 |
149 class PerfRasterTaskImpl : public TileTask { | 138 class PerfRasterTaskImpl : public TileTask { |
150 public: | 139 public: |
151 PerfRasterTaskImpl(std::unique_ptr<ScopedResource> resource, | 140 PerfRasterTaskImpl(std::unique_ptr<ScopedResource> resource, |
| 141 std::unique_ptr<RasterBuffer> raster_buffer, |
152 TileTask::Vector* dependencies) | 142 TileTask::Vector* dependencies) |
153 : TileTask(true, dependencies), resource_(std::move(resource)) {} | 143 : TileTask(TileTask::Type::RASTER, true, dependencies), |
| 144 resource_(std::move(resource)), |
| 145 raster_buffer_(std::move(raster_buffer)) {} |
154 | 146 |
155 // Overridden from Task: | 147 // Overridden from Task: |
156 void RunOnWorkerThread() override {} | 148 void RunOnWorkerThread() override {} |
157 | 149 |
158 // Overridden from TileTask: | |
159 void ScheduleOnOriginThread(RasterBufferProvider* provider) override { | |
160 // No tile ids are given to support partial updates. | |
161 raster_buffer_ = provider->AcquireBufferForRaster(resource_.get(), 0, 0); | |
162 } | |
163 void CompleteOnOriginThread(RasterBufferProvider* provider) override { | |
164 provider->ReleaseBufferForRaster(std::move(raster_buffer_)); | |
165 Reset(); | |
166 } | |
167 | |
168 void Reset() { | |
169 state().Reset(); | |
170 did_complete_ = false; | |
171 } | |
172 | |
173 protected: | 150 protected: |
174 ~PerfRasterTaskImpl() override {} | 151 ~PerfRasterTaskImpl() override {} |
175 | 152 |
176 private: | 153 private: |
| 154 friend class RasterBufferProviderPerfTest; |
| 155 |
177 std::unique_ptr<ScopedResource> resource_; | 156 std::unique_ptr<ScopedResource> resource_; |
178 std::unique_ptr<RasterBuffer> raster_buffer_; | 157 std::unique_ptr<RasterBuffer> raster_buffer_; |
179 | 158 |
180 DISALLOW_COPY_AND_ASSIGN(PerfRasterTaskImpl); | 159 DISALLOW_COPY_AND_ASSIGN(PerfRasterTaskImpl); |
181 }; | 160 }; |
182 | 161 |
183 class RasterBufferProviderPerfTestBase { | 162 class RasterBufferProviderPerfTestBase { |
184 public: | 163 public: |
185 typedef std::vector<scoped_refptr<TileTask>> RasterTaskVector; | 164 typedef std::vector<scoped_refptr<TileTask>> RasterTaskVector; |
186 | 165 |
187 enum NamedTaskSet { REQUIRED_FOR_ACTIVATION, REQUIRED_FOR_DRAW, ALL }; | 166 enum NamedTaskSet { REQUIRED_FOR_ACTIVATION, REQUIRED_FOR_DRAW, ALL }; |
188 | 167 |
189 RasterBufferProviderPerfTestBase() | 168 RasterBufferProviderPerfTestBase() |
190 : context_provider_(make_scoped_refptr(new PerfContextProvider)), | 169 : context_provider_(make_scoped_refptr(new PerfContextProvider)), |
191 task_runner_(new base::TestSimpleTaskRunner), | 170 task_runner_(new base::TestSimpleTaskRunner), |
192 task_graph_runner_(new SynchronousTaskGraphRunner), | 171 task_graph_runner_(new SynchronousTaskGraphRunner), |
193 timer_(kWarmupRuns, | 172 timer_(kWarmupRuns, |
194 base::TimeDelta::FromMilliseconds(kTimeLimitMillis), | 173 base::TimeDelta::FromMilliseconds(kTimeLimitMillis), |
195 kTimeCheckInterval) {} | 174 kTimeCheckInterval) {} |
196 | 175 |
197 void CreateImageDecodeTasks(unsigned num_image_decode_tasks, | 176 void CreateImageDecodeTasks(unsigned num_image_decode_tasks, |
198 TileTask::Vector* image_decode_tasks) { | 177 TileTask::Vector* image_decode_tasks) { |
199 for (unsigned i = 0; i < num_image_decode_tasks; ++i) | 178 for (unsigned i = 0; i < num_image_decode_tasks; ++i) |
200 image_decode_tasks->push_back(new PerfImageDecodeTaskImpl); | 179 image_decode_tasks->push_back(new PerfImageDecodeTaskImpl); |
201 } | 180 } |
202 | 181 |
203 void CreateRasterTasks(unsigned num_raster_tasks, | 182 void CreateRasterTasks(TileTaskManager* tile_task_manager, |
| 183 unsigned num_raster_tasks, |
204 const TileTask::Vector& image_decode_tasks, | 184 const TileTask::Vector& image_decode_tasks, |
205 RasterTaskVector* raster_tasks) { | 185 RasterTaskVector* raster_tasks) { |
206 const gfx::Size size(1, 1); | 186 const gfx::Size size(1, 1); |
207 | 187 |
208 for (unsigned i = 0; i < num_raster_tasks; ++i) { | 188 for (unsigned i = 0; i < num_raster_tasks; ++i) { |
209 std::unique_ptr<ScopedResource> resource( | 189 std::unique_ptr<ScopedResource> resource( |
210 ScopedResource::Create(resource_provider_.get())); | 190 ScopedResource::Create(resource_provider_.get())); |
211 resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, | 191 resource->Allocate(size, ResourceProvider::TEXTURE_HINT_IMMUTABLE, |
212 RGBA_8888); | 192 RGBA_8888); |
213 | 193 |
| 194 // No tile ids are given to support partial updates. |
| 195 std::unique_ptr<RasterBuffer> raster_buffer; |
| 196 if (tile_task_manager) { |
| 197 raster_buffer = tile_task_manager->GetRasterBufferProvider() |
| 198 ->AcquireBufferForRaster(resource.get(), 0, 0); |
| 199 } |
214 TileTask::Vector dependencies = image_decode_tasks; | 200 TileTask::Vector dependencies = image_decode_tasks; |
215 raster_tasks->push_back( | 201 raster_tasks->push_back(new PerfRasterTaskImpl( |
216 new PerfRasterTaskImpl(std::move(resource), &dependencies)); | 202 std::move(resource), std::move(raster_buffer), &dependencies)); |
217 } | 203 } |
218 } | 204 } |
219 | 205 |
220 void BuildTileTaskGraph(TaskGraph* graph, | 206 void BuildTileTaskGraph(TaskGraph* graph, |
221 const RasterTaskVector& raster_tasks) { | 207 const RasterTaskVector& raster_tasks) { |
222 uint16_t priority = 0; | 208 uint16_t priority = 0; |
223 | 209 |
224 for (auto& raster_task : raster_tasks) { | 210 for (auto& raster_task : raster_tasks) { |
225 priority++; | 211 priority++; |
226 | 212 |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
290 break; | 276 break; |
291 } | 277 } |
292 | 278 |
293 DCHECK(raster_buffer_provider); | 279 DCHECK(raster_buffer_provider); |
294 | 280 |
295 tile_task_manager_ = TileTaskManagerImpl::Create( | 281 tile_task_manager_ = TileTaskManagerImpl::Create( |
296 std::move(raster_buffer_provider), task_graph_runner_.get()); | 282 std::move(raster_buffer_provider), task_graph_runner_.get()); |
297 } | 283 } |
298 void TearDown() override { | 284 void TearDown() override { |
299 tile_task_manager_->Shutdown(); | 285 tile_task_manager_->Shutdown(); |
300 tile_task_manager_->CheckForCompletedTasks(); | 286 CheckForCompletedTasks(); |
301 } | 287 } |
302 | 288 |
303 void RunMessageLoopUntilAllTasksHaveCompleted() { | 289 void RunMessageLoopUntilAllTasksHaveCompleted() { |
304 task_graph_runner_->RunUntilIdle(); | 290 task_graph_runner_->RunUntilIdle(); |
305 task_runner_->RunUntilIdle(); | 291 task_runner_->RunUntilIdle(); |
306 } | 292 } |
307 | 293 |
308 void RunScheduleTasksTest(const std::string& test_name, | 294 void RunScheduleTasksTest(const std::string& test_name, |
309 unsigned num_raster_tasks, | 295 unsigned num_raster_tasks, |
310 unsigned num_image_decode_tasks) { | 296 unsigned num_image_decode_tasks) { |
311 TileTask::Vector image_decode_tasks; | 297 TileTask::Vector image_decode_tasks; |
312 RasterTaskVector raster_tasks; | 298 RasterTaskVector raster_tasks; |
313 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); | 299 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); |
314 CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks); | 300 CreateRasterTasks(tile_task_manager_.get(), num_raster_tasks, |
| 301 image_decode_tasks, &raster_tasks); |
315 | 302 |
316 // Avoid unnecessary heap allocations by reusing the same graph. | 303 // Avoid unnecessary heap allocations by reusing the same graph. |
317 TaskGraph graph; | 304 TaskGraph graph; |
318 | 305 |
319 timer_.Reset(); | 306 timer_.Reset(); |
320 do { | 307 do { |
321 graph.Reset(); | 308 graph.Reset(); |
322 BuildTileTaskGraph(&graph, raster_tasks); | 309 BuildTileTaskGraph(&graph, raster_tasks); |
323 tile_task_manager_->ScheduleTasks(&graph); | 310 tile_task_manager_->ScheduleTasks(&graph); |
324 tile_task_manager_->CheckForCompletedTasks(); | 311 CheckForCompletedTasks(); |
325 timer_.NextLap(); | 312 timer_.NextLap(); |
326 } while (!timer_.HasTimeLimitExpired()); | 313 } while (!timer_.HasTimeLimitExpired()); |
327 | 314 |
328 TaskGraph empty; | 315 TaskGraph empty; |
329 tile_task_manager_->ScheduleTasks(&empty); | 316 tile_task_manager_->ScheduleTasks(&empty); |
330 RunMessageLoopUntilAllTasksHaveCompleted(); | 317 RunMessageLoopUntilAllTasksHaveCompleted(); |
331 | 318 |
332 perf_test::PrintResult("schedule_tasks", TestModifierString(), test_name, | 319 perf_test::PrintResult("schedule_tasks", TestModifierString(), test_name, |
333 timer_.LapsPerSecond(), "runs/s", true); | 320 timer_.LapsPerSecond(), "runs/s", true); |
334 } | 321 } |
335 | 322 |
336 void RunScheduleAlternateTasksTest(const std::string& test_name, | 323 void RunScheduleAlternateTasksTest(const std::string& test_name, |
337 unsigned num_raster_tasks, | 324 unsigned num_raster_tasks, |
338 unsigned num_image_decode_tasks) { | 325 unsigned num_image_decode_tasks) { |
339 const size_t kNumVersions = 2; | 326 const size_t kNumVersions = 2; |
340 TileTask::Vector image_decode_tasks[kNumVersions]; | 327 TileTask::Vector image_decode_tasks[kNumVersions]; |
341 RasterTaskVector raster_tasks[kNumVersions]; | 328 RasterTaskVector raster_tasks[kNumVersions]; |
342 for (size_t i = 0; i < kNumVersions; ++i) { | 329 for (size_t i = 0; i < kNumVersions; ++i) { |
343 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks[i]); | 330 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks[i]); |
344 CreateRasterTasks(num_raster_tasks, image_decode_tasks[i], | 331 CreateRasterTasks(tile_task_manager_.get(), num_raster_tasks, |
345 &raster_tasks[i]); | 332 image_decode_tasks[i], &raster_tasks[i]); |
346 } | 333 } |
347 | 334 |
348 // Avoid unnecessary heap allocations by reusing the same graph. | 335 // Avoid unnecessary heap allocations by reusing the same graph. |
349 TaskGraph graph; | 336 TaskGraph graph; |
350 | 337 |
351 size_t count = 0; | 338 size_t count = 0; |
352 timer_.Reset(); | 339 timer_.Reset(); |
353 do { | 340 do { |
354 graph.Reset(); | 341 graph.Reset(); |
355 BuildTileTaskGraph(&graph, raster_tasks[count % kNumVersions]); | 342 BuildTileTaskGraph(&graph, raster_tasks[count % kNumVersions]); |
356 tile_task_manager_->ScheduleTasks(&graph); | 343 tile_task_manager_->ScheduleTasks(&graph); |
357 tile_task_manager_->CheckForCompletedTasks(); | 344 CheckForCompletedTasks(); |
358 ++count; | 345 ++count; |
359 timer_.NextLap(); | 346 timer_.NextLap(); |
360 } while (!timer_.HasTimeLimitExpired()); | 347 } while (!timer_.HasTimeLimitExpired()); |
361 | 348 |
362 TaskGraph empty; | 349 TaskGraph empty; |
363 tile_task_manager_->ScheduleTasks(&empty); | 350 tile_task_manager_->ScheduleTasks(&empty); |
364 RunMessageLoopUntilAllTasksHaveCompleted(); | 351 RunMessageLoopUntilAllTasksHaveCompleted(); |
365 | 352 |
366 perf_test::PrintResult("schedule_alternate_tasks", TestModifierString(), | 353 perf_test::PrintResult("schedule_alternate_tasks", TestModifierString(), |
367 test_name, timer_.LapsPerSecond(), "runs/s", true); | 354 test_name, timer_.LapsPerSecond(), "runs/s", true); |
368 } | 355 } |
369 | 356 |
370 void RunScheduleAndExecuteTasksTest(const std::string& test_name, | 357 void RunScheduleAndExecuteTasksTest(const std::string& test_name, |
371 unsigned num_raster_tasks, | 358 unsigned num_raster_tasks, |
372 unsigned num_image_decode_tasks) { | 359 unsigned num_image_decode_tasks) { |
373 TileTask::Vector image_decode_tasks; | 360 TileTask::Vector image_decode_tasks; |
374 RasterTaskVector raster_tasks; | 361 RasterTaskVector raster_tasks; |
375 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); | 362 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); |
376 CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks); | 363 CreateRasterTasks(tile_task_manager_.get(), num_raster_tasks, |
| 364 image_decode_tasks, &raster_tasks); |
377 | 365 |
378 // Avoid unnecessary heap allocations by reusing the same graph. | 366 // Avoid unnecessary heap allocations by reusing the same graph. |
379 TaskGraph graph; | 367 TaskGraph graph; |
380 | 368 |
381 timer_.Reset(); | 369 timer_.Reset(); |
382 do { | 370 do { |
383 graph.Reset(); | 371 graph.Reset(); |
384 BuildTileTaskGraph(&graph, raster_tasks); | 372 BuildTileTaskGraph(&graph, raster_tasks); |
385 tile_task_manager_->ScheduleTasks(&graph); | 373 tile_task_manager_->ScheduleTasks(&graph); |
386 RunMessageLoopUntilAllTasksHaveCompleted(); | 374 RunMessageLoopUntilAllTasksHaveCompleted(); |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
419 return std::string("_one_copy_raster_buffer_provider"); | 407 return std::string("_one_copy_raster_buffer_provider"); |
420 case RASTER_BUFFER_PROVIDER_TYPE_GPU: | 408 case RASTER_BUFFER_PROVIDER_TYPE_GPU: |
421 return std::string("_gpu_raster_buffer_provider"); | 409 return std::string("_gpu_raster_buffer_provider"); |
422 case RASTER_BUFFER_PROVIDER_TYPE_BITMAP: | 410 case RASTER_BUFFER_PROVIDER_TYPE_BITMAP: |
423 return std::string("_bitmap_raster_buffer_provider"); | 411 return std::string("_bitmap_raster_buffer_provider"); |
424 } | 412 } |
425 NOTREACHED(); | 413 NOTREACHED(); |
426 return std::string(); | 414 return std::string(); |
427 } | 415 } |
428 | 416 |
| 417 void CheckForCompletedTasks() { |
| 418 Task::Vector completed_tasks; |
| 419 tile_task_manager_->CollectCompletedTasks(&completed_tasks); |
| 420 |
| 421 for (auto task : completed_tasks) { |
| 422 TileTask* tile_task = static_cast<TileTask*>(task.get()); |
| 423 switch (tile_task->type()) { |
| 424 case TileTask::Type::RASTER: |
| 425 OnRasterTaskCompleted(tile_task); |
| 426 break; |
| 427 case TileTask::Type::IMAGE_DECODE: |
| 428 break; |
| 429 default: |
| 430 NOTREACHED(); |
| 431 } |
| 432 |
| 433 // Instead of calling DidComplete(), call Reset() as same task would be |
| 434 // reused as if new. |
| 435 task->state().Reset(); |
| 436 } |
| 437 |
| 438 completed_tasks.clear(); |
| 439 } |
| 440 |
| 441 void OnRasterTaskCompleted(TileTask* task) { |
| 442 PerfRasterTaskImpl* raster_task = static_cast<PerfRasterTaskImpl*>(task); |
| 443 tile_task_manager_->GetRasterBufferProvider()->ReleaseBufferForRaster( |
| 444 std::move(raster_task->raster_buffer_)); |
| 445 } |
| 446 |
429 std::unique_ptr<TileTaskManager> tile_task_manager_; | 447 std::unique_ptr<TileTaskManager> tile_task_manager_; |
430 TestGpuMemoryBufferManager gpu_memory_buffer_manager_; | 448 TestGpuMemoryBufferManager gpu_memory_buffer_manager_; |
431 TestSharedBitmapManager shared_bitmap_manager_; | 449 TestSharedBitmapManager shared_bitmap_manager_; |
432 }; | 450 }; |
433 | 451 |
434 TEST_P(RasterBufferProviderPerfTest, ScheduleTasks) { | 452 TEST_P(RasterBufferProviderPerfTest, ScheduleTasks) { |
435 RunScheduleTasksTest("1_0", 1, 0); | 453 RunScheduleTasksTest("1_0", 1, 0); |
436 RunScheduleTasksTest("32_0", 32, 0); | 454 RunScheduleTasksTest("32_0", 32, 0); |
437 RunScheduleTasksTest("1_1", 1, 1); | 455 RunScheduleTasksTest("1_1", 1, 1); |
438 RunScheduleTasksTest("32_1", 32, 1); | 456 RunScheduleTasksTest("32_1", 32, 1); |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
476 resource_provider_ = | 494 resource_provider_ = |
477 FakeResourceProvider::Create(output_surface_.get(), nullptr); | 495 FakeResourceProvider::Create(output_surface_.get(), nullptr); |
478 } | 496 } |
479 | 497 |
480 void RunBuildTileTaskGraphTest(const std::string& test_name, | 498 void RunBuildTileTaskGraphTest(const std::string& test_name, |
481 unsigned num_raster_tasks, | 499 unsigned num_raster_tasks, |
482 unsigned num_image_decode_tasks) { | 500 unsigned num_image_decode_tasks) { |
483 TileTask::Vector image_decode_tasks; | 501 TileTask::Vector image_decode_tasks; |
484 RasterTaskVector raster_tasks; | 502 RasterTaskVector raster_tasks; |
485 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); | 503 CreateImageDecodeTasks(num_image_decode_tasks, &image_decode_tasks); |
486 CreateRasterTasks(num_raster_tasks, image_decode_tasks, &raster_tasks); | 504 CreateRasterTasks(nullptr, num_raster_tasks, image_decode_tasks, |
| 505 &raster_tasks); |
487 | 506 |
488 // Avoid unnecessary heap allocations by reusing the same graph. | 507 // Avoid unnecessary heap allocations by reusing the same graph. |
489 TaskGraph graph; | 508 TaskGraph graph; |
490 | 509 |
491 timer_.Reset(); | 510 timer_.Reset(); |
492 do { | 511 do { |
493 graph.Reset(); | 512 graph.Reset(); |
494 BuildTileTaskGraph(&graph, raster_tasks); | 513 BuildTileTaskGraph(&graph, raster_tasks); |
495 timer_.NextLap(); | 514 timer_.NextLap(); |
496 } while (!timer_.HasTimeLimitExpired()); | 515 } while (!timer_.HasTimeLimitExpired()); |
497 | 516 |
498 perf_test::PrintResult("build_raster_task_graph", "", test_name, | 517 perf_test::PrintResult("build_raster_task_graph", "", test_name, |
499 timer_.LapsPerSecond(), "runs/s", true); | 518 timer_.LapsPerSecond(), "runs/s", true); |
500 } | 519 } |
501 }; | 520 }; |
502 | 521 |
503 TEST_F(RasterBufferProviderCommonPerfTest, BuildTileTaskGraph) { | 522 TEST_F(RasterBufferProviderCommonPerfTest, BuildTileTaskGraph) { |
504 RunBuildTileTaskGraphTest("1_0", 1, 0); | 523 RunBuildTileTaskGraphTest("1_0", 1, 0); |
505 RunBuildTileTaskGraphTest("32_0", 32, 0); | 524 RunBuildTileTaskGraphTest("32_0", 32, 0); |
506 RunBuildTileTaskGraphTest("1_1", 1, 1); | 525 RunBuildTileTaskGraphTest("1_1", 1, 1); |
507 RunBuildTileTaskGraphTest("32_1", 32, 1); | 526 RunBuildTileTaskGraphTest("32_1", 32, 1); |
508 RunBuildTileTaskGraphTest("1_4", 1, 4); | 527 RunBuildTileTaskGraphTest("1_4", 1, 4); |
509 RunBuildTileTaskGraphTest("32_4", 32, 4); | 528 RunBuildTileTaskGraphTest("32_4", 32, 4); |
510 } | 529 } |
511 | 530 |
512 } // namespace | 531 } // namespace |
513 } // namespace cc | 532 } // namespace cc |
OLD | NEW |