1 /* 2 * Copyright © 2016 Intel Corporation 3 * 4 * Permission is hereby granted, free of charge, to any person obtaining a 5 * copy of this software and associated documentation files (the "Software"), 6 * to deal in the Software without restriction, including without limitation 7 * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8 * and/or sell copies of the Software, and to permit persons to whom the 9 * Software is furnished to do so, subject to the following conditions: 10 * 11 * The above copyright notice and this permission notice (including the next 12 * paragraph) shall be included in all copies or substantial portions of the 13 * Software. 14 * 15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21 * IN THE SOFTWARE. 22 * 23 */ 24 25 #include <linux/list_sort.h> 26 #include <linux/prime_numbers.h> 27 28 #include "../i915_selftest.h" 29 #include "i915_random.h" 30 31 #include "mock_context.h" 32 #include "mock_drm.h" 33 #include "mock_gem_device.h" 34 35 static void cleanup_freed_objects(struct drm_i915_private *i915) 36 { 37 /* 38 * As we may hold onto the struct_mutex for inordinate lengths of 39 * time, the NMI khungtaskd detector may fire for the free objects 40 * worker. 41 */ 42 mutex_unlock(&i915->drm.struct_mutex); 43 44 i915_gem_drain_freed_objects(i915); 45 46 mutex_lock(&i915->drm.struct_mutex); 47 } 48 49 static void fake_free_pages(struct drm_i915_gem_object *obj, 50 struct sg_table *pages) 51 { 52 sg_free_table(pages); 53 kfree(pages); 54 } 55 56 static int fake_get_pages(struct drm_i915_gem_object *obj) 57 { 58 #define GFP (GFP_KERNEL | __GFP_NOWARN | __GFP_NORETRY) 59 #define PFN_BIAS 0x1000 60 struct sg_table *pages; 61 struct scatterlist *sg; 62 unsigned int sg_page_sizes; 63 typeof(obj->base.size) rem; 64 65 pages = kmalloc(sizeof(*pages), GFP); 66 if (!pages) 67 return -ENOMEM; 68 69 rem = round_up(obj->base.size, BIT(31)) >> 31; 70 if (sg_alloc_table(pages, rem, GFP)) { 71 kfree(pages); 72 return -ENOMEM; 73 } 74 75 sg_page_sizes = 0; 76 rem = obj->base.size; 77 for (sg = pages->sgl; sg; sg = sg_next(sg)) { 78 unsigned long len = min_t(typeof(rem), rem, BIT(31)); 79 80 GEM_BUG_ON(!len); 81 sg_set_page(sg, pfn_to_page(PFN_BIAS), len, 0); 82 sg_dma_address(sg) = page_to_phys(sg_page(sg)); 83 sg_dma_len(sg) = len; 84 sg_page_sizes |= len; 85 86 rem -= len; 87 } 88 GEM_BUG_ON(rem); 89 90 obj->mm.madv = I915_MADV_DONTNEED; 91 92 __i915_gem_object_set_pages(obj, pages, sg_page_sizes); 93 94 return 0; 95 #undef GFP 96 } 97 98 static void fake_put_pages(struct drm_i915_gem_object *obj, 99 struct sg_table *pages) 100 { 101 fake_free_pages(obj, pages); 102 obj->mm.dirty = false; 103 obj->mm.madv = I915_MADV_WILLNEED; 104 } 105 106 static const struct drm_i915_gem_object_ops fake_ops = { 107 .flags = I915_GEM_OBJECT_IS_SHRINKABLE, 108 .get_pages = fake_get_pages, 109 .put_pages = fake_put_pages, 110 }; 111 112 static struct drm_i915_gem_object * 113 fake_dma_object(struct drm_i915_private *i915, u64 size) 114 { 115 struct drm_i915_gem_object *obj; 116 117 GEM_BUG_ON(!size); 118 GEM_BUG_ON(!IS_ALIGNED(size, I915_GTT_PAGE_SIZE)); 119 120 if (overflows_type(size, obj->base.size)) 121 return ERR_PTR(-E2BIG); 122 123 obj = i915_gem_object_alloc(i915); 124 if (!obj) 125 goto err; 126 127 drm_gem_private_object_init(&i915->drm, &obj->base, size); 128 i915_gem_object_init(obj, &fake_ops); 129 130 obj->write_domain = I915_GEM_DOMAIN_CPU; 131 obj->read_domains = I915_GEM_DOMAIN_CPU; 132 obj->cache_level = I915_CACHE_NONE; 133 134 /* Preallocate the "backing storage" */ 135 if (i915_gem_object_pin_pages(obj)) 136 goto err_obj; 137 138 i915_gem_object_unpin_pages(obj); 139 return obj; 140 141 err_obj: 142 i915_gem_object_put(obj); 143 err: 144 return ERR_PTR(-ENOMEM); 145 } 146 147 static int igt_ppgtt_alloc(void *arg) 148 { 149 struct drm_i915_private *dev_priv = arg; 150 struct i915_hw_ppgtt *ppgtt; 151 u64 size, last, limit; 152 int err = 0; 153 154 /* Allocate a ppggt and try to fill the entire range */ 155 156 if (!USES_PPGTT(dev_priv)) 157 return 0; 158 159 ppgtt = __hw_ppgtt_create(dev_priv); 160 if (IS_ERR(ppgtt)) 161 return PTR_ERR(ppgtt); 162 163 if (!ppgtt->vm.allocate_va_range) 164 goto err_ppgtt_cleanup; 165 166 /* 167 * While we only allocate the page tables here and so we could 168 * address a much larger GTT than we could actually fit into 169 * RAM, a practical limit is the amount of physical pages in the system. 170 * This should ensure that we do not run into the oomkiller during 171 * the test and take down the machine wilfully. 172 */ 173 limit = totalram_pages << PAGE_SHIFT; 174 limit = min(ppgtt->vm.total, limit); 175 176 /* Check we can allocate the entire range */ 177 for (size = 4096; size <= limit; size <<= 2) { 178 err = ppgtt->vm.allocate_va_range(&ppgtt->vm, 0, size); 179 if (err) { 180 if (err == -ENOMEM) { 181 pr_info("[1] Ran out of memory for va_range [0 + %llx] [bit %d]\n", 182 size, ilog2(size)); 183 err = 0; /* virtual space too large! */ 184 } 185 goto err_ppgtt_cleanup; 186 } 187 188 cond_resched(); 189 190 ppgtt->vm.clear_range(&ppgtt->vm, 0, size); 191 } 192 193 /* Check we can incrementally allocate the entire range */ 194 for (last = 0, size = 4096; size <= limit; last = size, size <<= 2) { 195 err = ppgtt->vm.allocate_va_range(&ppgtt->vm, 196 last, size - last); 197 if (err) { 198 if (err == -ENOMEM) { 199 pr_info("[2] Ran out of memory for va_range [%llx + %llx] [bit %d]\n", 200 last, size - last, ilog2(size)); 201 err = 0; /* virtual space too large! */ 202 } 203 goto err_ppgtt_cleanup; 204 } 205 206 cond_resched(); 207 } 208 209 err_ppgtt_cleanup: 210 mutex_lock(&dev_priv->drm.struct_mutex); 211 i915_ppgtt_put(ppgtt); 212 mutex_unlock(&dev_priv->drm.struct_mutex); 213 return err; 214 } 215 216 static int lowlevel_hole(struct drm_i915_private *i915, 217 struct i915_address_space *vm, 218 u64 hole_start, u64 hole_end, 219 unsigned long end_time) 220 { 221 I915_RND_STATE(seed_prng); 222 unsigned int size; 223 struct i915_vma mock_vma; 224 225 memset(&mock_vma, 0, sizeof(struct i915_vma)); 226 227 /* Keep creating larger objects until one cannot fit into the hole */ 228 for (size = 12; (hole_end - hole_start) >> size; size++) { 229 I915_RND_SUBSTATE(prng, seed_prng); 230 struct drm_i915_gem_object *obj; 231 unsigned int *order, count, n; 232 u64 hole_size; 233 234 hole_size = (hole_end - hole_start) >> size; 235 if (hole_size > KMALLOC_MAX_SIZE / sizeof(u32)) 236 hole_size = KMALLOC_MAX_SIZE / sizeof(u32); 237 count = hole_size >> 1; 238 if (!count) { 239 pr_debug("%s: hole is too small [%llx - %llx] >> %d: %lld\n", 240 __func__, hole_start, hole_end, size, hole_size); 241 break; 242 } 243 244 do { 245 order = i915_random_order(count, &prng); 246 if (order) 247 break; 248 } while (count >>= 1); 249 if (!count) 250 return -ENOMEM; 251 GEM_BUG_ON(!order); 252 253 GEM_BUG_ON(count * BIT_ULL(size) > vm->total); 254 GEM_BUG_ON(hole_start + count * BIT_ULL(size) > hole_end); 255 256 /* Ignore allocation failures (i.e. don't report them as 257 * a test failure) as we are purposefully allocating very 258 * large objects without checking that we have sufficient 259 * memory. We expect to hit -ENOMEM. 260 */ 261 262 obj = fake_dma_object(i915, BIT_ULL(size)); 263 if (IS_ERR(obj)) { 264 kfree(order); 265 break; 266 } 267 268 GEM_BUG_ON(obj->base.size != BIT_ULL(size)); 269 270 if (i915_gem_object_pin_pages(obj)) { 271 i915_gem_object_put(obj); 272 kfree(order); 273 break; 274 } 275 276 for (n = 0; n < count; n++) { 277 u64 addr = hole_start + order[n] * BIT_ULL(size); 278 279 GEM_BUG_ON(addr + BIT_ULL(size) > vm->total); 280 281 if (igt_timeout(end_time, 282 "%s timed out before %d/%d\n", 283 __func__, n, count)) { 284 hole_end = hole_start; /* quit */ 285 break; 286 } 287 288 if (vm->allocate_va_range && 289 vm->allocate_va_range(vm, addr, BIT_ULL(size))) 290 break; 291 292 mock_vma.pages = obj->mm.pages; 293 mock_vma.node.size = BIT_ULL(size); 294 mock_vma.node.start = addr; 295 296 intel_runtime_pm_get(i915); 297 vm->insert_entries(vm, &mock_vma, I915_CACHE_NONE, 0); 298 intel_runtime_pm_put(i915); 299 } 300 count = n; 301 302 i915_random_reorder(order, count, &prng); 303 for (n = 0; n < count; n++) { 304 u64 addr = hole_start + order[n] * BIT_ULL(size); 305 306 GEM_BUG_ON(addr + BIT_ULL(size) > vm->total); 307 vm->clear_range(vm, addr, BIT_ULL(size)); 308 } 309 310 i915_gem_object_unpin_pages(obj); 311 i915_gem_object_put(obj); 312 313 kfree(order); 314 315 cleanup_freed_objects(i915); 316 } 317 318 return 0; 319 } 320 321 static void close_object_list(struct list_head *objects, 322 struct i915_address_space *vm) 323 { 324 struct drm_i915_gem_object *obj, *on; 325 int ignored; 326 327 list_for_each_entry_safe(obj, on, objects, st_link) { 328 struct i915_vma *vma; 329 330 vma = i915_vma_instance(obj, vm, NULL); 331 if (!IS_ERR(vma)) 332 ignored = i915_vma_unbind(vma); 333 /* Only ppgtt vma may be closed before the object is freed */ 334 if (!IS_ERR(vma) && !i915_vma_is_ggtt(vma)) 335 i915_vma_close(vma); 336 337 list_del(&obj->st_link); 338 i915_gem_object_put(obj); 339 } 340 } 341 342 static int fill_hole(struct drm_i915_private *i915, 343 struct i915_address_space *vm, 344 u64 hole_start, u64 hole_end, 345 unsigned long end_time) 346 { 347 const u64 hole_size = hole_end - hole_start; 348 struct drm_i915_gem_object *obj; 349 const unsigned long max_pages = 350 min_t(u64, ULONG_MAX - 1, hole_size/2 >> PAGE_SHIFT); 351 const unsigned long max_step = max(int_sqrt(max_pages), 2UL); 352 unsigned long npages, prime, flags; 353 struct i915_vma *vma; 354 LIST_HEAD(objects); 355 int err; 356 357 /* Try binding many VMA working inwards from either edge */ 358 359 flags = PIN_OFFSET_FIXED | PIN_USER; 360 if (i915_is_ggtt(vm)) 361 flags |= PIN_GLOBAL; 362 363 for_each_prime_number_from(prime, 2, max_step) { 364 for (npages = 1; npages <= max_pages; npages *= prime) { 365 const u64 full_size = npages << PAGE_SHIFT; 366 const struct { 367 const char *name; 368 u64 offset; 369 int step; 370 } phases[] = { 371 { "top-down", hole_end, -1, }, 372 { "bottom-up", hole_start, 1, }, 373 { } 374 }, *p; 375 376 obj = fake_dma_object(i915, full_size); 377 if (IS_ERR(obj)) 378 break; 379 380 list_add(&obj->st_link, &objects); 381 382 /* Align differing sized objects against the edges, and 383 * check we don't walk off into the void when binding 384 * them into the GTT. 385 */ 386 for (p = phases; p->name; p++) { 387 u64 offset; 388 389 offset = p->offset; 390 list_for_each_entry(obj, &objects, st_link) { 391 vma = i915_vma_instance(obj, vm, NULL); 392 if (IS_ERR(vma)) 393 continue; 394 395 if (p->step < 0) { 396 if (offset < hole_start + obj->base.size) 397 break; 398 offset -= obj->base.size; 399 } 400 401 err = i915_vma_pin(vma, 0, 0, offset | flags); 402 if (err) { 403 pr_err("%s(%s) pin (forward) failed with err=%d on size=%lu pages (prime=%lu), offset=%llx\n", 404 __func__, p->name, err, npages, prime, offset); 405 goto err; 406 } 407 408 if (!drm_mm_node_allocated(&vma->node) || 409 i915_vma_misplaced(vma, 0, 0, offset | flags)) { 410 pr_err("%s(%s) (forward) insert failed: vma.node=%llx + %llx [allocated? %d], expected offset %llx\n", 411 __func__, p->name, vma->node.start, vma->node.size, drm_mm_node_allocated(&vma->node), 412 offset); 413 err = -EINVAL; 414 goto err; 415 } 416 417 i915_vma_unpin(vma); 418 419 if (p->step > 0) { 420 if (offset + obj->base.size > hole_end) 421 break; 422 offset += obj->base.size; 423 } 424 } 425 426 offset = p->offset; 427 list_for_each_entry(obj, &objects, st_link) { 428 vma = i915_vma_instance(obj, vm, NULL); 429 if (IS_ERR(vma)) 430 continue; 431 432 if (p->step < 0) { 433 if (offset < hole_start + obj->base.size) 434 break; 435 offset -= obj->base.size; 436 } 437 438 if (!drm_mm_node_allocated(&vma->node) || 439 i915_vma_misplaced(vma, 0, 0, offset | flags)) { 440 pr_err("%s(%s) (forward) moved vma.node=%llx + %llx, expected offset %llx\n", 441 __func__, p->name, vma->node.start, vma->node.size, 442 offset); 443 err = -EINVAL; 444 goto err; 445 } 446 447 err = i915_vma_unbind(vma); 448 if (err) { 449 pr_err("%s(%s) (forward) unbind of vma.node=%llx + %llx failed with err=%d\n", 450 __func__, p->name, vma->node.start, vma->node.size, 451 err); 452 goto err; 453 } 454 455 if (p->step > 0) { 456 if (offset + obj->base.size > hole_end) 457 break; 458 offset += obj->base.size; 459 } 460 } 461 462 offset = p->offset; 463 list_for_each_entry_reverse(obj, &objects, st_link) { 464 vma = i915_vma_instance(obj, vm, NULL); 465 if (IS_ERR(vma)) 466 continue; 467 468 if (p->step < 0) { 469 if (offset < hole_start + obj->base.size) 470 break; 471 offset -= obj->base.size; 472 } 473 474 err = i915_vma_pin(vma, 0, 0, offset | flags); 475 if (err) { 476 pr_err("%s(%s) pin (backward) failed with err=%d on size=%lu pages (prime=%lu), offset=%llx\n", 477 __func__, p->name, err, npages, prime, offset); 478 goto err; 479 } 480 481 if (!drm_mm_node_allocated(&vma->node) || 482 i915_vma_misplaced(vma, 0, 0, offset | flags)) { 483 pr_err("%s(%s) (backward) insert failed: vma.node=%llx + %llx [allocated? %d], expected offset %llx\n", 484 __func__, p->name, vma->node.start, vma->node.size, drm_mm_node_allocated(&vma->node), 485 offset); 486 err = -EINVAL; 487 goto err; 488 } 489 490 i915_vma_unpin(vma); 491 492 if (p->step > 0) { 493 if (offset + obj->base.size > hole_end) 494 break; 495 offset += obj->base.size; 496 } 497 } 498 499 offset = p->offset; 500 list_for_each_entry_reverse(obj, &objects, st_link) { 501 vma = i915_vma_instance(obj, vm, NULL); 502 if (IS_ERR(vma)) 503 continue; 504 505 if (p->step < 0) { 506 if (offset < hole_start + obj->base.size) 507 break; 508 offset -= obj->base.size; 509 } 510 511 if (!drm_mm_node_allocated(&vma->node) || 512 i915_vma_misplaced(vma, 0, 0, offset | flags)) { 513 pr_err("%s(%s) (backward) moved vma.node=%llx + %llx [allocated? %d], expected offset %llx\n", 514 __func__, p->name, vma->node.start, vma->node.size, drm_mm_node_allocated(&vma->node), 515 offset); 516 err = -EINVAL; 517 goto err; 518 } 519 520 err = i915_vma_unbind(vma); 521 if (err) { 522 pr_err("%s(%s) (backward) unbind of vma.node=%llx + %llx failed with err=%d\n", 523 __func__, p->name, vma->node.start, vma->node.size, 524 err); 525 goto err; 526 } 527 528 if (p->step > 0) { 529 if (offset + obj->base.size > hole_end) 530 break; 531 offset += obj->base.size; 532 } 533 } 534 } 535 536 if (igt_timeout(end_time, "%s timed out (npages=%lu, prime=%lu)\n", 537 __func__, npages, prime)) { 538 err = -EINTR; 539 goto err; 540 } 541 } 542 543 close_object_list(&objects, vm); 544 cleanup_freed_objects(i915); 545 } 546 547 return 0; 548 549 err: 550 close_object_list(&objects, vm); 551 return err; 552 } 553 554 static int walk_hole(struct drm_i915_private *i915, 555 struct i915_address_space *vm, 556 u64 hole_start, u64 hole_end, 557 unsigned long end_time) 558 { 559 const u64 hole_size = hole_end - hole_start; 560 const unsigned long max_pages = 561 min_t(u64, ULONG_MAX - 1, hole_size >> PAGE_SHIFT); 562 unsigned long flags; 563 u64 size; 564 565 /* Try binding a single VMA in different positions within the hole */ 566 567 flags = PIN_OFFSET_FIXED | PIN_USER; 568 if (i915_is_ggtt(vm)) 569 flags |= PIN_GLOBAL; 570 571 for_each_prime_number_from(size, 1, max_pages) { 572 struct drm_i915_gem_object *obj; 573 struct i915_vma *vma; 574 u64 addr; 575 int err = 0; 576 577 obj = fake_dma_object(i915, size << PAGE_SHIFT); 578 if (IS_ERR(obj)) 579 break; 580 581 vma = i915_vma_instance(obj, vm, NULL); 582 if (IS_ERR(vma)) { 583 err = PTR_ERR(vma); 584 goto err_put; 585 } 586 587 for (addr = hole_start; 588 addr + obj->base.size < hole_end; 589 addr += obj->base.size) { 590 err = i915_vma_pin(vma, 0, 0, addr | flags); 591 if (err) { 592 pr_err("%s bind failed at %llx + %llx [hole %llx- %llx] with err=%d\n", 593 __func__, addr, vma->size, 594 hole_start, hole_end, err); 595 goto err_close; 596 } 597 i915_vma_unpin(vma); 598 599 if (!drm_mm_node_allocated(&vma->node) || 600 i915_vma_misplaced(vma, 0, 0, addr | flags)) { 601 pr_err("%s incorrect at %llx + %llx\n", 602 __func__, addr, vma->size); 603 err = -EINVAL; 604 goto err_close; 605 } 606 607 err = i915_vma_unbind(vma); 608 if (err) { 609 pr_err("%s unbind failed at %llx + %llx with err=%d\n", 610 __func__, addr, vma->size, err); 611 goto err_close; 612 } 613 614 GEM_BUG_ON(drm_mm_node_allocated(&vma->node)); 615 616 if (igt_timeout(end_time, 617 "%s timed out at %llx\n", 618 __func__, addr)) { 619 err = -EINTR; 620 goto err_close; 621 } 622 } 623 624 err_close: 625 if (!i915_vma_is_ggtt(vma)) 626 i915_vma_close(vma); 627 err_put: 628 i915_gem_object_put(obj); 629 if (err) 630 return err; 631 632 cleanup_freed_objects(i915); 633 } 634 635 return 0; 636 } 637 638 static int pot_hole(struct drm_i915_private *i915, 639 struct i915_address_space *vm, 640 u64 hole_start, u64 hole_end, 641 unsigned long end_time) 642 { 643 struct drm_i915_gem_object *obj; 644 struct i915_vma *vma; 645 unsigned long flags; 646 unsigned int pot; 647 int err = 0; 648 649 flags = PIN_OFFSET_FIXED | PIN_USER; 650 if (i915_is_ggtt(vm)) 651 flags |= PIN_GLOBAL; 652 653 obj = i915_gem_object_create_internal(i915, 2 * I915_GTT_PAGE_SIZE); 654 if (IS_ERR(obj)) 655 return PTR_ERR(obj); 656 657 vma = i915_vma_instance(obj, vm, NULL); 658 if (IS_ERR(vma)) { 659 err = PTR_ERR(vma); 660 goto err_obj; 661 } 662 663 /* Insert a pair of pages across every pot boundary within the hole */ 664 for (pot = fls64(hole_end - 1) - 1; 665 pot > ilog2(2 * I915_GTT_PAGE_SIZE); 666 pot--) { 667 u64 step = BIT_ULL(pot); 668 u64 addr; 669 670 for (addr = round_up(hole_start + I915_GTT_PAGE_SIZE, step) - I915_GTT_PAGE_SIZE; 671 addr <= round_down(hole_end - 2*I915_GTT_PAGE_SIZE, step) - I915_GTT_PAGE_SIZE; 672 addr += step) { 673 err = i915_vma_pin(vma, 0, 0, addr | flags); 674 if (err) { 675 pr_err("%s failed to pin object at %llx in hole [%llx - %llx], with err=%d\n", 676 __func__, 677 addr, 678 hole_start, hole_end, 679 err); 680 goto err; 681 } 682 683 if (!drm_mm_node_allocated(&vma->node) || 684 i915_vma_misplaced(vma, 0, 0, addr | flags)) { 685 pr_err("%s incorrect at %llx + %llx\n", 686 __func__, addr, vma->size); 687 i915_vma_unpin(vma); 688 err = i915_vma_unbind(vma); 689 err = -EINVAL; 690 goto err; 691 } 692 693 i915_vma_unpin(vma); 694 err = i915_vma_unbind(vma); 695 GEM_BUG_ON(err); 696 } 697 698 if (igt_timeout(end_time, 699 "%s timed out after %d/%d\n", 700 __func__, pot, fls64(hole_end - 1) - 1)) { 701 err = -EINTR; 702 goto err; 703 } 704 } 705 706 err: 707 if (!i915_vma_is_ggtt(vma)) 708 i915_vma_close(vma); 709 err_obj: 710 i915_gem_object_put(obj); 711 return err; 712 } 713 714 static int drunk_hole(struct drm_i915_private *i915, 715 struct i915_address_space *vm, 716 u64 hole_start, u64 hole_end, 717 unsigned long end_time) 718 { 719 I915_RND_STATE(prng); 720 unsigned int size; 721 unsigned long flags; 722 723 flags = PIN_OFFSET_FIXED | PIN_USER; 724 if (i915_is_ggtt(vm)) 725 flags |= PIN_GLOBAL; 726 727 /* Keep creating larger objects until one cannot fit into the hole */ 728 for (size = 12; (hole_end - hole_start) >> size; size++) { 729 struct drm_i915_gem_object *obj; 730 unsigned int *order, count, n; 731 struct i915_vma *vma; 732 u64 hole_size; 733 int err = -ENODEV; 734 735 hole_size = (hole_end - hole_start) >> size; 736 if (hole_size > KMALLOC_MAX_SIZE / sizeof(u32)) 737 hole_size = KMALLOC_MAX_SIZE / sizeof(u32); 738 count = hole_size >> 1; 739 if (!count) { 740 pr_debug("%s: hole is too small [%llx - %llx] >> %d: %lld\n", 741 __func__, hole_start, hole_end, size, hole_size); 742 break; 743 } 744 745 do { 746 order = i915_random_order(count, &prng); 747 if (order) 748 break; 749 } while (count >>= 1); 750 if (!count) 751 return -ENOMEM; 752 GEM_BUG_ON(!order); 753 754 /* Ignore allocation failures (i.e. don't report them as 755 * a test failure) as we are purposefully allocating very 756 * large objects without checking that we have sufficient 757 * memory. We expect to hit -ENOMEM. 758 */ 759 760 obj = fake_dma_object(i915, BIT_ULL(size)); 761 if (IS_ERR(obj)) { 762 kfree(order); 763 break; 764 } 765 766 vma = i915_vma_instance(obj, vm, NULL); 767 if (IS_ERR(vma)) { 768 err = PTR_ERR(vma); 769 goto err_obj; 770 } 771 772 GEM_BUG_ON(vma->size != BIT_ULL(size)); 773 774 for (n = 0; n < count; n++) { 775 u64 addr = hole_start + order[n] * BIT_ULL(size); 776 777 err = i915_vma_pin(vma, 0, 0, addr | flags); 778 if (err) { 779 pr_err("%s failed to pin object at %llx + %llx in hole [%llx - %llx], with err=%d\n", 780 __func__, 781 addr, BIT_ULL(size), 782 hole_start, hole_end, 783 err); 784 goto err; 785 } 786 787 if (!drm_mm_node_allocated(&vma->node) || 788 i915_vma_misplaced(vma, 0, 0, addr | flags)) { 789 pr_err("%s incorrect at %llx + %llx\n", 790 __func__, addr, BIT_ULL(size)); 791 i915_vma_unpin(vma); 792 err = i915_vma_unbind(vma); 793 err = -EINVAL; 794 goto err; 795 } 796 797 i915_vma_unpin(vma); 798 err = i915_vma_unbind(vma); 799 GEM_BUG_ON(err); 800 801 if (igt_timeout(end_time, 802 "%s timed out after %d/%d\n", 803 __func__, n, count)) { 804 err = -EINTR; 805 goto err; 806 } 807 } 808 809 err: 810 if (!i915_vma_is_ggtt(vma)) 811 i915_vma_close(vma); 812 err_obj: 813 i915_gem_object_put(obj); 814 kfree(order); 815 if (err) 816 return err; 817 818 cleanup_freed_objects(i915); 819 } 820 821 return 0; 822 } 823 824 static int __shrink_hole(struct drm_i915_private *i915, 825 struct i915_address_space *vm, 826 u64 hole_start, u64 hole_end, 827 unsigned long end_time) 828 { 829 struct drm_i915_gem_object *obj; 830 unsigned long flags = PIN_OFFSET_FIXED | PIN_USER; 831 unsigned int order = 12; 832 LIST_HEAD(objects); 833 int err = 0; 834 u64 addr; 835 836 /* Keep creating larger objects until one cannot fit into the hole */ 837 for (addr = hole_start; addr < hole_end; ) { 838 struct i915_vma *vma; 839 u64 size = BIT_ULL(order++); 840 841 size = min(size, hole_end - addr); 842 obj = fake_dma_object(i915, size); 843 if (IS_ERR(obj)) { 844 err = PTR_ERR(obj); 845 break; 846 } 847 848 list_add(&obj->st_link, &objects); 849 850 vma = i915_vma_instance(obj, vm, NULL); 851 if (IS_ERR(vma)) { 852 err = PTR_ERR(vma); 853 break; 854 } 855 856 GEM_BUG_ON(vma->size != size); 857 858 err = i915_vma_pin(vma, 0, 0, addr | flags); 859 if (err) { 860 pr_err("%s failed to pin object at %llx + %llx in hole [%llx - %llx], with err=%d\n", 861 __func__, addr, size, hole_start, hole_end, err); 862 break; 863 } 864 865 if (!drm_mm_node_allocated(&vma->node) || 866 i915_vma_misplaced(vma, 0, 0, addr | flags)) { 867 pr_err("%s incorrect at %llx + %llx\n", 868 __func__, addr, size); 869 i915_vma_unpin(vma); 870 err = i915_vma_unbind(vma); 871 err = -EINVAL; 872 break; 873 } 874 875 i915_vma_unpin(vma); 876 addr += size; 877 878 if (igt_timeout(end_time, 879 "%s timed out at ofset %llx [%llx - %llx]\n", 880 __func__, addr, hole_start, hole_end)) { 881 err = -EINTR; 882 break; 883 } 884 } 885 886 close_object_list(&objects, vm); 887 cleanup_freed_objects(i915); 888 return err; 889 } 890 891 static int shrink_hole(struct drm_i915_private *i915, 892 struct i915_address_space *vm, 893 u64 hole_start, u64 hole_end, 894 unsigned long end_time) 895 { 896 unsigned long prime; 897 int err; 898 899 vm->fault_attr.probability = 999; 900 atomic_set(&vm->fault_attr.times, -1); 901 902 for_each_prime_number_from(prime, 0, ULONG_MAX - 1) { 903 vm->fault_attr.interval = prime; 904 err = __shrink_hole(i915, vm, hole_start, hole_end, end_time); 905 if (err) 906 break; 907 } 908 909 memset(&vm->fault_attr, 0, sizeof(vm->fault_attr)); 910 911 return err; 912 } 913 914 static int shrink_boom(struct drm_i915_private *i915, 915 struct i915_address_space *vm, 916 u64 hole_start, u64 hole_end, 917 unsigned long end_time) 918 { 919 unsigned int sizes[] = { SZ_2M, SZ_1G }; 920 struct drm_i915_gem_object *purge; 921 struct drm_i915_gem_object *explode; 922 int err; 923 int i; 924 925 /* 926 * Catch the case which shrink_hole seems to miss. The setup here 927 * requires invoking the shrinker as we do the alloc_pt/alloc_pd, while 928 * ensuring that all vma assiocated with the respective pd/pdp are 929 * unpinned at the time. 930 */ 931 932 for (i = 0; i < ARRAY_SIZE(sizes); ++i) { 933 unsigned int flags = PIN_USER | PIN_OFFSET_FIXED; 934 unsigned int size = sizes[i]; 935 struct i915_vma *vma; 936 937 purge = fake_dma_object(i915, size); 938 if (IS_ERR(purge)) 939 return PTR_ERR(purge); 940 941 vma = i915_vma_instance(purge, vm, NULL); 942 if (IS_ERR(vma)) { 943 err = PTR_ERR(vma); 944 goto err_purge; 945 } 946 947 err = i915_vma_pin(vma, 0, 0, flags); 948 if (err) 949 goto err_purge; 950 951 /* Should now be ripe for purging */ 952 i915_vma_unpin(vma); 953 954 explode = fake_dma_object(i915, size); 955 if (IS_ERR(explode)) { 956 err = PTR_ERR(explode); 957 goto err_purge; 958 } 959 960 vm->fault_attr.probability = 100; 961 vm->fault_attr.interval = 1; 962 atomic_set(&vm->fault_attr.times, -1); 963 964 vma = i915_vma_instance(explode, vm, NULL); 965 if (IS_ERR(vma)) { 966 err = PTR_ERR(vma); 967 goto err_explode; 968 } 969 970 err = i915_vma_pin(vma, 0, 0, flags | size); 971 if (err) 972 goto err_explode; 973 974 i915_vma_unpin(vma); 975 976 i915_gem_object_put(purge); 977 i915_gem_object_put(explode); 978 979 memset(&vm->fault_attr, 0, sizeof(vm->fault_attr)); 980 cleanup_freed_objects(i915); 981 } 982 983 return 0; 984 985 err_explode: 986 i915_gem_object_put(explode); 987 err_purge: 988 i915_gem_object_put(purge); 989 memset(&vm->fault_attr, 0, sizeof(vm->fault_attr)); 990 return err; 991 } 992 993 static int exercise_ppgtt(struct drm_i915_private *dev_priv, 994 int (*func)(struct drm_i915_private *i915, 995 struct i915_address_space *vm, 996 u64 hole_start, u64 hole_end, 997 unsigned long end_time)) 998 { 999 struct drm_file *file; 1000 struct i915_hw_ppgtt *ppgtt; 1001 IGT_TIMEOUT(end_time); 1002 int err; 1003 1004 if (!USES_FULL_PPGTT(dev_priv)) 1005 return 0; 1006 1007 file = mock_file(dev_priv); 1008 if (IS_ERR(file)) 1009 return PTR_ERR(file); 1010 1011 mutex_lock(&dev_priv->drm.struct_mutex); 1012 ppgtt = i915_ppgtt_create(dev_priv, file->driver_priv); 1013 if (IS_ERR(ppgtt)) { 1014 err = PTR_ERR(ppgtt); 1015 goto out_unlock; 1016 } 1017 GEM_BUG_ON(offset_in_page(ppgtt->vm.total)); 1018 GEM_BUG_ON(ppgtt->vm.closed); 1019 1020 err = func(dev_priv, &ppgtt->vm, 0, ppgtt->vm.total, end_time); 1021 1022 i915_ppgtt_close(&ppgtt->vm); 1023 i915_ppgtt_put(ppgtt); 1024 out_unlock: 1025 mutex_unlock(&dev_priv->drm.struct_mutex); 1026 1027 mock_file_free(dev_priv, file); 1028 return err; 1029 } 1030 1031 static int igt_ppgtt_fill(void *arg) 1032 { 1033 return exercise_ppgtt(arg, fill_hole); 1034 } 1035 1036 static int igt_ppgtt_walk(void *arg) 1037 { 1038 return exercise_ppgtt(arg, walk_hole); 1039 } 1040 1041 static int igt_ppgtt_pot(void *arg) 1042 { 1043 return exercise_ppgtt(arg, pot_hole); 1044 } 1045 1046 static int igt_ppgtt_drunk(void *arg) 1047 { 1048 return exercise_ppgtt(arg, drunk_hole); 1049 } 1050 1051 static int igt_ppgtt_lowlevel(void *arg) 1052 { 1053 return exercise_ppgtt(arg, lowlevel_hole); 1054 } 1055 1056 static int igt_ppgtt_shrink(void *arg) 1057 { 1058 return exercise_ppgtt(arg, shrink_hole); 1059 } 1060 1061 static int igt_ppgtt_shrink_boom(void *arg) 1062 { 1063 return exercise_ppgtt(arg, shrink_boom); 1064 } 1065 1066 static int sort_holes(void *priv, struct list_head *A, struct list_head *B) 1067 { 1068 struct drm_mm_node *a = list_entry(A, typeof(*a), hole_stack); 1069 struct drm_mm_node *b = list_entry(B, typeof(*b), hole_stack); 1070 1071 if (a->start < b->start) 1072 return -1; 1073 else 1074 return 1; 1075 } 1076 1077 static int exercise_ggtt(struct drm_i915_private *i915, 1078 int (*func)(struct drm_i915_private *i915, 1079 struct i915_address_space *vm, 1080 u64 hole_start, u64 hole_end, 1081 unsigned long end_time)) 1082 { 1083 struct i915_ggtt *ggtt = &i915->ggtt; 1084 u64 hole_start, hole_end, last = 0; 1085 struct drm_mm_node *node; 1086 IGT_TIMEOUT(end_time); 1087 int err = 0; 1088 1089 mutex_lock(&i915->drm.struct_mutex); 1090 restart: 1091 list_sort(NULL, &ggtt->vm.mm.hole_stack, sort_holes); 1092 drm_mm_for_each_hole(node, &ggtt->vm.mm, hole_start, hole_end) { 1093 if (hole_start < last) 1094 continue; 1095 1096 if (ggtt->vm.mm.color_adjust) 1097 ggtt->vm.mm.color_adjust(node, 0, 1098 &hole_start, &hole_end); 1099 if (hole_start >= hole_end) 1100 continue; 1101 1102 err = func(i915, &ggtt->vm, hole_start, hole_end, end_time); 1103 if (err) 1104 break; 1105 1106 /* As we have manipulated the drm_mm, the list may be corrupt */ 1107 last = hole_end; 1108 goto restart; 1109 } 1110 mutex_unlock(&i915->drm.struct_mutex); 1111 1112 return err; 1113 } 1114 1115 static int igt_ggtt_fill(void *arg) 1116 { 1117 return exercise_ggtt(arg, fill_hole); 1118 } 1119 1120 static int igt_ggtt_walk(void *arg) 1121 { 1122 return exercise_ggtt(arg, walk_hole); 1123 } 1124 1125 static int igt_ggtt_pot(void *arg) 1126 { 1127 return exercise_ggtt(arg, pot_hole); 1128 } 1129 1130 static int igt_ggtt_drunk(void *arg) 1131 { 1132 return exercise_ggtt(arg, drunk_hole); 1133 } 1134 1135 static int igt_ggtt_lowlevel(void *arg) 1136 { 1137 return exercise_ggtt(arg, lowlevel_hole); 1138 } 1139 1140 static int igt_ggtt_page(void *arg) 1141 { 1142 const unsigned int count = PAGE_SIZE/sizeof(u32); 1143 I915_RND_STATE(prng); 1144 struct drm_i915_private *i915 = arg; 1145 struct i915_ggtt *ggtt = &i915->ggtt; 1146 struct drm_i915_gem_object *obj; 1147 struct drm_mm_node tmp; 1148 unsigned int *order, n; 1149 int err; 1150 1151 mutex_lock(&i915->drm.struct_mutex); 1152 1153 obj = i915_gem_object_create_internal(i915, PAGE_SIZE); 1154 if (IS_ERR(obj)) { 1155 err = PTR_ERR(obj); 1156 goto out_unlock; 1157 } 1158 1159 err = i915_gem_object_pin_pages(obj); 1160 if (err) 1161 goto out_free; 1162 1163 memset(&tmp, 0, sizeof(tmp)); 1164 err = drm_mm_insert_node_in_range(&ggtt->vm.mm, &tmp, 1165 count * PAGE_SIZE, 0, 1166 I915_COLOR_UNEVICTABLE, 1167 0, ggtt->mappable_end, 1168 DRM_MM_INSERT_LOW); 1169 if (err) 1170 goto out_unpin; 1171 1172 intel_runtime_pm_get(i915); 1173 1174 for (n = 0; n < count; n++) { 1175 u64 offset = tmp.start + n * PAGE_SIZE; 1176 1177 ggtt->vm.insert_page(&ggtt->vm, 1178 i915_gem_object_get_dma_address(obj, 0), 1179 offset, I915_CACHE_NONE, 0); 1180 } 1181 1182 order = i915_random_order(count, &prng); 1183 if (!order) { 1184 err = -ENOMEM; 1185 goto out_remove; 1186 } 1187 1188 for (n = 0; n < count; n++) { 1189 u64 offset = tmp.start + order[n] * PAGE_SIZE; 1190 u32 __iomem *vaddr; 1191 1192 vaddr = io_mapping_map_atomic_wc(&ggtt->iomap, offset); 1193 iowrite32(n, vaddr + n); 1194 io_mapping_unmap_atomic(vaddr); 1195 } 1196 i915_gem_flush_ggtt_writes(i915); 1197 1198 i915_random_reorder(order, count, &prng); 1199 for (n = 0; n < count; n++) { 1200 u64 offset = tmp.start + order[n] * PAGE_SIZE; 1201 u32 __iomem *vaddr; 1202 u32 val; 1203 1204 vaddr = io_mapping_map_atomic_wc(&ggtt->iomap, offset); 1205 val = ioread32(vaddr + n); 1206 io_mapping_unmap_atomic(vaddr); 1207 1208 if (val != n) { 1209 pr_err("insert page failed: found %d, expected %d\n", 1210 val, n); 1211 err = -EINVAL; 1212 break; 1213 } 1214 } 1215 1216 kfree(order); 1217 out_remove: 1218 ggtt->vm.clear_range(&ggtt->vm, tmp.start, tmp.size); 1219 intel_runtime_pm_put(i915); 1220 drm_mm_remove_node(&tmp); 1221 out_unpin: 1222 i915_gem_object_unpin_pages(obj); 1223 out_free: 1224 i915_gem_object_put(obj); 1225 out_unlock: 1226 mutex_unlock(&i915->drm.struct_mutex); 1227 return err; 1228 } 1229 1230 static void track_vma_bind(struct i915_vma *vma) 1231 { 1232 struct drm_i915_gem_object *obj = vma->obj; 1233 1234 obj->bind_count++; /* track for eviction later */ 1235 __i915_gem_object_pin_pages(obj); 1236 1237 vma->pages = obj->mm.pages; 1238 list_move_tail(&vma->vm_link, &vma->vm->inactive_list); 1239 } 1240 1241 static int exercise_mock(struct drm_i915_private *i915, 1242 int (*func)(struct drm_i915_private *i915, 1243 struct i915_address_space *vm, 1244 u64 hole_start, u64 hole_end, 1245 unsigned long end_time)) 1246 { 1247 const u64 limit = totalram_pages << PAGE_SHIFT; 1248 struct i915_gem_context *ctx; 1249 struct i915_hw_ppgtt *ppgtt; 1250 IGT_TIMEOUT(end_time); 1251 int err; 1252 1253 ctx = mock_context(i915, "mock"); 1254 if (!ctx) 1255 return -ENOMEM; 1256 1257 ppgtt = ctx->ppgtt; 1258 GEM_BUG_ON(!ppgtt); 1259 1260 err = func(i915, &ppgtt->vm, 0, min(ppgtt->vm.total, limit), end_time); 1261 1262 mock_context_close(ctx); 1263 return err; 1264 } 1265 1266 static int igt_mock_fill(void *arg) 1267 { 1268 return exercise_mock(arg, fill_hole); 1269 } 1270 1271 static int igt_mock_walk(void *arg) 1272 { 1273 return exercise_mock(arg, walk_hole); 1274 } 1275 1276 static int igt_mock_pot(void *arg) 1277 { 1278 return exercise_mock(arg, pot_hole); 1279 } 1280 1281 static int igt_mock_drunk(void *arg) 1282 { 1283 return exercise_mock(arg, drunk_hole); 1284 } 1285 1286 static int igt_gtt_reserve(void *arg) 1287 { 1288 struct drm_i915_private *i915 = arg; 1289 struct drm_i915_gem_object *obj, *on; 1290 LIST_HEAD(objects); 1291 u64 total; 1292 int err = -ENODEV; 1293 1294 /* i915_gem_gtt_reserve() tries to reserve the precise range 1295 * for the node, and evicts if it has to. So our test checks that 1296 * it can give us the requsted space and prevent overlaps. 1297 */ 1298 1299 /* Start by filling the GGTT */ 1300 for (total = 0; 1301 total + 2*I915_GTT_PAGE_SIZE <= i915->ggtt.vm.total; 1302 total += 2*I915_GTT_PAGE_SIZE) { 1303 struct i915_vma *vma; 1304 1305 obj = i915_gem_object_create_internal(i915, 2*PAGE_SIZE); 1306 if (IS_ERR(obj)) { 1307 err = PTR_ERR(obj); 1308 goto out; 1309 } 1310 1311 err = i915_gem_object_pin_pages(obj); 1312 if (err) { 1313 i915_gem_object_put(obj); 1314 goto out; 1315 } 1316 1317 list_add(&obj->st_link, &objects); 1318 1319 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1320 if (IS_ERR(vma)) { 1321 err = PTR_ERR(vma); 1322 goto out; 1323 } 1324 1325 err = i915_gem_gtt_reserve(&i915->ggtt.vm, &vma->node, 1326 obj->base.size, 1327 total, 1328 obj->cache_level, 1329 0); 1330 if (err) { 1331 pr_err("i915_gem_gtt_reserve (pass 1) failed at %llu/%llu with err=%d\n", 1332 total, i915->ggtt.vm.total, err); 1333 goto out; 1334 } 1335 track_vma_bind(vma); 1336 1337 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1338 if (vma->node.start != total || 1339 vma->node.size != 2*I915_GTT_PAGE_SIZE) { 1340 pr_err("i915_gem_gtt_reserve (pass 1) placement failed, found (%llx + %llx), expected (%llx + %llx)\n", 1341 vma->node.start, vma->node.size, 1342 total, 2*I915_GTT_PAGE_SIZE); 1343 err = -EINVAL; 1344 goto out; 1345 } 1346 } 1347 1348 /* Now we start forcing evictions */ 1349 for (total = I915_GTT_PAGE_SIZE; 1350 total + 2*I915_GTT_PAGE_SIZE <= i915->ggtt.vm.total; 1351 total += 2*I915_GTT_PAGE_SIZE) { 1352 struct i915_vma *vma; 1353 1354 obj = i915_gem_object_create_internal(i915, 2*PAGE_SIZE); 1355 if (IS_ERR(obj)) { 1356 err = PTR_ERR(obj); 1357 goto out; 1358 } 1359 1360 err = i915_gem_object_pin_pages(obj); 1361 if (err) { 1362 i915_gem_object_put(obj); 1363 goto out; 1364 } 1365 1366 list_add(&obj->st_link, &objects); 1367 1368 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1369 if (IS_ERR(vma)) { 1370 err = PTR_ERR(vma); 1371 goto out; 1372 } 1373 1374 err = i915_gem_gtt_reserve(&i915->ggtt.vm, &vma->node, 1375 obj->base.size, 1376 total, 1377 obj->cache_level, 1378 0); 1379 if (err) { 1380 pr_err("i915_gem_gtt_reserve (pass 2) failed at %llu/%llu with err=%d\n", 1381 total, i915->ggtt.vm.total, err); 1382 goto out; 1383 } 1384 track_vma_bind(vma); 1385 1386 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1387 if (vma->node.start != total || 1388 vma->node.size != 2*I915_GTT_PAGE_SIZE) { 1389 pr_err("i915_gem_gtt_reserve (pass 2) placement failed, found (%llx + %llx), expected (%llx + %llx)\n", 1390 vma->node.start, vma->node.size, 1391 total, 2*I915_GTT_PAGE_SIZE); 1392 err = -EINVAL; 1393 goto out; 1394 } 1395 } 1396 1397 /* And then try at random */ 1398 list_for_each_entry_safe(obj, on, &objects, st_link) { 1399 struct i915_vma *vma; 1400 u64 offset; 1401 1402 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1403 if (IS_ERR(vma)) { 1404 err = PTR_ERR(vma); 1405 goto out; 1406 } 1407 1408 err = i915_vma_unbind(vma); 1409 if (err) { 1410 pr_err("i915_vma_unbind failed with err=%d!\n", err); 1411 goto out; 1412 } 1413 1414 offset = random_offset(0, i915->ggtt.vm.total, 1415 2*I915_GTT_PAGE_SIZE, 1416 I915_GTT_MIN_ALIGNMENT); 1417 1418 err = i915_gem_gtt_reserve(&i915->ggtt.vm, &vma->node, 1419 obj->base.size, 1420 offset, 1421 obj->cache_level, 1422 0); 1423 if (err) { 1424 pr_err("i915_gem_gtt_reserve (pass 3) failed at %llu/%llu with err=%d\n", 1425 total, i915->ggtt.vm.total, err); 1426 goto out; 1427 } 1428 track_vma_bind(vma); 1429 1430 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1431 if (vma->node.start != offset || 1432 vma->node.size != 2*I915_GTT_PAGE_SIZE) { 1433 pr_err("i915_gem_gtt_reserve (pass 3) placement failed, found (%llx + %llx), expected (%llx + %llx)\n", 1434 vma->node.start, vma->node.size, 1435 offset, 2*I915_GTT_PAGE_SIZE); 1436 err = -EINVAL; 1437 goto out; 1438 } 1439 } 1440 1441 out: 1442 list_for_each_entry_safe(obj, on, &objects, st_link) { 1443 i915_gem_object_unpin_pages(obj); 1444 i915_gem_object_put(obj); 1445 } 1446 return err; 1447 } 1448 1449 static int igt_gtt_insert(void *arg) 1450 { 1451 struct drm_i915_private *i915 = arg; 1452 struct drm_i915_gem_object *obj, *on; 1453 struct drm_mm_node tmp = {}; 1454 const struct invalid_insert { 1455 u64 size; 1456 u64 alignment; 1457 u64 start, end; 1458 } invalid_insert[] = { 1459 { 1460 i915->ggtt.vm.total + I915_GTT_PAGE_SIZE, 0, 1461 0, i915->ggtt.vm.total, 1462 }, 1463 { 1464 2*I915_GTT_PAGE_SIZE, 0, 1465 0, I915_GTT_PAGE_SIZE, 1466 }, 1467 { 1468 -(u64)I915_GTT_PAGE_SIZE, 0, 1469 0, 4*I915_GTT_PAGE_SIZE, 1470 }, 1471 { 1472 -(u64)2*I915_GTT_PAGE_SIZE, 2*I915_GTT_PAGE_SIZE, 1473 0, 4*I915_GTT_PAGE_SIZE, 1474 }, 1475 { 1476 I915_GTT_PAGE_SIZE, I915_GTT_MIN_ALIGNMENT << 1, 1477 I915_GTT_MIN_ALIGNMENT, I915_GTT_MIN_ALIGNMENT << 1, 1478 }, 1479 {} 1480 }, *ii; 1481 LIST_HEAD(objects); 1482 u64 total; 1483 int err = -ENODEV; 1484 1485 /* i915_gem_gtt_insert() tries to allocate some free space in the GTT 1486 * to the node, evicting if required. 1487 */ 1488 1489 /* Check a couple of obviously invalid requests */ 1490 for (ii = invalid_insert; ii->size; ii++) { 1491 err = i915_gem_gtt_insert(&i915->ggtt.vm, &tmp, 1492 ii->size, ii->alignment, 1493 I915_COLOR_UNEVICTABLE, 1494 ii->start, ii->end, 1495 0); 1496 if (err != -ENOSPC) { 1497 pr_err("Invalid i915_gem_gtt_insert(.size=%llx, .alignment=%llx, .start=%llx, .end=%llx) succeeded (err=%d)\n", 1498 ii->size, ii->alignment, ii->start, ii->end, 1499 err); 1500 return -EINVAL; 1501 } 1502 } 1503 1504 /* Start by filling the GGTT */ 1505 for (total = 0; 1506 total + I915_GTT_PAGE_SIZE <= i915->ggtt.vm.total; 1507 total += I915_GTT_PAGE_SIZE) { 1508 struct i915_vma *vma; 1509 1510 obj = i915_gem_object_create_internal(i915, I915_GTT_PAGE_SIZE); 1511 if (IS_ERR(obj)) { 1512 err = PTR_ERR(obj); 1513 goto out; 1514 } 1515 1516 err = i915_gem_object_pin_pages(obj); 1517 if (err) { 1518 i915_gem_object_put(obj); 1519 goto out; 1520 } 1521 1522 list_add(&obj->st_link, &objects); 1523 1524 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1525 if (IS_ERR(vma)) { 1526 err = PTR_ERR(vma); 1527 goto out; 1528 } 1529 1530 err = i915_gem_gtt_insert(&i915->ggtt.vm, &vma->node, 1531 obj->base.size, 0, obj->cache_level, 1532 0, i915->ggtt.vm.total, 1533 0); 1534 if (err == -ENOSPC) { 1535 /* maxed out the GGTT space */ 1536 i915_gem_object_put(obj); 1537 break; 1538 } 1539 if (err) { 1540 pr_err("i915_gem_gtt_insert (pass 1) failed at %llu/%llu with err=%d\n", 1541 total, i915->ggtt.vm.total, err); 1542 goto out; 1543 } 1544 track_vma_bind(vma); 1545 __i915_vma_pin(vma); 1546 1547 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1548 } 1549 1550 list_for_each_entry(obj, &objects, st_link) { 1551 struct i915_vma *vma; 1552 1553 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1554 if (IS_ERR(vma)) { 1555 err = PTR_ERR(vma); 1556 goto out; 1557 } 1558 1559 if (!drm_mm_node_allocated(&vma->node)) { 1560 pr_err("VMA was unexpectedly evicted!\n"); 1561 err = -EINVAL; 1562 goto out; 1563 } 1564 1565 __i915_vma_unpin(vma); 1566 } 1567 1568 /* If we then reinsert, we should find the same hole */ 1569 list_for_each_entry_safe(obj, on, &objects, st_link) { 1570 struct i915_vma *vma; 1571 u64 offset; 1572 1573 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1574 if (IS_ERR(vma)) { 1575 err = PTR_ERR(vma); 1576 goto out; 1577 } 1578 1579 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1580 offset = vma->node.start; 1581 1582 err = i915_vma_unbind(vma); 1583 if (err) { 1584 pr_err("i915_vma_unbind failed with err=%d!\n", err); 1585 goto out; 1586 } 1587 1588 err = i915_gem_gtt_insert(&i915->ggtt.vm, &vma->node, 1589 obj->base.size, 0, obj->cache_level, 1590 0, i915->ggtt.vm.total, 1591 0); 1592 if (err) { 1593 pr_err("i915_gem_gtt_insert (pass 2) failed at %llu/%llu with err=%d\n", 1594 total, i915->ggtt.vm.total, err); 1595 goto out; 1596 } 1597 track_vma_bind(vma); 1598 1599 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1600 if (vma->node.start != offset) { 1601 pr_err("i915_gem_gtt_insert did not return node to its previous location (the only hole), expected address %llx, found %llx\n", 1602 offset, vma->node.start); 1603 err = -EINVAL; 1604 goto out; 1605 } 1606 } 1607 1608 /* And then force evictions */ 1609 for (total = 0; 1610 total + 2*I915_GTT_PAGE_SIZE <= i915->ggtt.vm.total; 1611 total += 2*I915_GTT_PAGE_SIZE) { 1612 struct i915_vma *vma; 1613 1614 obj = i915_gem_object_create_internal(i915, 2*I915_GTT_PAGE_SIZE); 1615 if (IS_ERR(obj)) { 1616 err = PTR_ERR(obj); 1617 goto out; 1618 } 1619 1620 err = i915_gem_object_pin_pages(obj); 1621 if (err) { 1622 i915_gem_object_put(obj); 1623 goto out; 1624 } 1625 1626 list_add(&obj->st_link, &objects); 1627 1628 vma = i915_vma_instance(obj, &i915->ggtt.vm, NULL); 1629 if (IS_ERR(vma)) { 1630 err = PTR_ERR(vma); 1631 goto out; 1632 } 1633 1634 err = i915_gem_gtt_insert(&i915->ggtt.vm, &vma->node, 1635 obj->base.size, 0, obj->cache_level, 1636 0, i915->ggtt.vm.total, 1637 0); 1638 if (err) { 1639 pr_err("i915_gem_gtt_insert (pass 3) failed at %llu/%llu with err=%d\n", 1640 total, i915->ggtt.vm.total, err); 1641 goto out; 1642 } 1643 track_vma_bind(vma); 1644 1645 GEM_BUG_ON(!drm_mm_node_allocated(&vma->node)); 1646 } 1647 1648 out: 1649 list_for_each_entry_safe(obj, on, &objects, st_link) { 1650 i915_gem_object_unpin_pages(obj); 1651 i915_gem_object_put(obj); 1652 } 1653 return err; 1654 } 1655 1656 int i915_gem_gtt_mock_selftests(void) 1657 { 1658 static const struct i915_subtest tests[] = { 1659 SUBTEST(igt_mock_drunk), 1660 SUBTEST(igt_mock_walk), 1661 SUBTEST(igt_mock_pot), 1662 SUBTEST(igt_mock_fill), 1663 SUBTEST(igt_gtt_reserve), 1664 SUBTEST(igt_gtt_insert), 1665 }; 1666 struct drm_i915_private *i915; 1667 int err; 1668 1669 i915 = mock_gem_device(); 1670 if (!i915) 1671 return -ENOMEM; 1672 1673 mutex_lock(&i915->drm.struct_mutex); 1674 err = i915_subtests(tests, i915); 1675 mutex_unlock(&i915->drm.struct_mutex); 1676 1677 drm_dev_put(&i915->drm); 1678 return err; 1679 } 1680 1681 int i915_gem_gtt_live_selftests(struct drm_i915_private *i915) 1682 { 1683 static const struct i915_subtest tests[] = { 1684 SUBTEST(igt_ppgtt_alloc), 1685 SUBTEST(igt_ppgtt_lowlevel), 1686 SUBTEST(igt_ppgtt_drunk), 1687 SUBTEST(igt_ppgtt_walk), 1688 SUBTEST(igt_ppgtt_pot), 1689 SUBTEST(igt_ppgtt_fill), 1690 SUBTEST(igt_ppgtt_shrink), 1691 SUBTEST(igt_ppgtt_shrink_boom), 1692 SUBTEST(igt_ggtt_lowlevel), 1693 SUBTEST(igt_ggtt_drunk), 1694 SUBTEST(igt_ggtt_walk), 1695 SUBTEST(igt_ggtt_pot), 1696 SUBTEST(igt_ggtt_fill), 1697 SUBTEST(igt_ggtt_page), 1698 }; 1699 1700 GEM_BUG_ON(offset_in_page(i915->ggtt.vm.total)); 1701 1702 return i915_subtests(tests, i915); 1703 } 1704