Commit 51f9574
vdpa/mlx5: Improve mr update flow
The current flow for updating an mr works directly on mvdev->mr which
makes it cumbersome to handle multiple new mr structs.
This patch makes the flow more straightforward by having
mlx5_vdpa_create_mr return a new mr which will update the old mr (if
any). The old mr will be deleted and unlinked from mvdev. For the case
when the iotlb is empty (not NULL), the old mr will be cleared.
This change paves the way for adding mrs for different ASIDs.
The initialized bool is no longer needed as mr is now a pointer in the
mlx5_vdpa_dev struct which will be NULL when not initialized.
Acked-by: Eugenio Pérez <eperezma@redhat.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Signed-off-by: Dragos Tatulea <dtatulea@nvidia.com>
Message-Id: <20231018171456.1624030-14-dtatulea@nvidia.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>1 parent f9fcb38 commit 51f9574
3 files changed
Lines changed: 82 additions & 72 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
31 | 31 | | |
32 | 32 | | |
33 | 33 | | |
34 | | - | |
35 | | - | |
36 | 34 | | |
37 | 35 | | |
38 | 36 | | |
| |||
91 | 89 | | |
92 | 90 | | |
93 | 91 | | |
94 | | - | |
| 92 | + | |
95 | 93 | | |
96 | 94 | | |
97 | 95 | | |
| |||
114 | 112 | | |
115 | 113 | | |
116 | 114 | | |
117 | | - | |
118 | | - | |
119 | | - | |
120 | | - | |
121 | | - | |
| 115 | + | |
| 116 | + | |
122 | 117 | | |
123 | 118 | | |
124 | 119 | | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
125 | 123 | | |
126 | 124 | | |
127 | 125 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
495 | 495 | | |
496 | 496 | | |
497 | 497 | | |
498 | | - | |
499 | | - | |
500 | | - | |
501 | 498 | | |
502 | 499 | | |
503 | 500 | | |
504 | 501 | | |
505 | | - | |
506 | | - | |
507 | 502 | | |
508 | 503 | | |
509 | 504 | | |
510 | 505 | | |
511 | 506 | | |
| 507 | + | |
| 508 | + | |
| 509 | + | |
512 | 510 | | |
513 | 511 | | |
514 | 512 | | |
515 | 513 | | |
| 514 | + | |
| 515 | + | |
| 516 | + | |
| 517 | + | |
| 518 | + | |
| 519 | + | |
| 520 | + | |
| 521 | + | |
| 522 | + | |
| 523 | + | |
| 524 | + | |
| 525 | + | |
| 526 | + | |
| 527 | + | |
| 528 | + | |
| 529 | + | |
| 530 | + | |
| 531 | + | |
| 532 | + | |
| 533 | + | |
| 534 | + | |
| 535 | + | |
516 | 536 | | |
| 537 | + | |
517 | 538 | | |
518 | 539 | | |
519 | 540 | | |
520 | 541 | | |
521 | | - | |
| 542 | + | |
522 | 543 | | |
523 | 544 | | |
524 | 545 | | |
| |||
528 | 549 | | |
529 | 550 | | |
530 | 551 | | |
531 | | - | |
532 | | - | |
533 | | - | |
534 | 552 | | |
535 | 553 | | |
536 | 554 | | |
537 | 555 | | |
538 | 556 | | |
539 | | - | |
540 | | - | |
541 | | - | |
542 | | - | |
543 | | - | |
544 | | - | |
| 557 | + | |
545 | 558 | | |
546 | 559 | | |
547 | | - | |
548 | | - | |
549 | | - | |
| 560 | + | |
| 561 | + | |
550 | 562 | | |
| 563 | + | |
551 | 564 | | |
552 | 565 | | |
| 566 | + | |
| 567 | + | |
| 568 | + | |
| 569 | + | |
553 | 570 | | |
554 | 571 | | |
555 | 572 | | |
556 | 573 | | |
557 | | - | |
558 | | - | |
559 | | - | |
560 | | - | |
561 | | - | |
562 | | - | |
563 | | - | |
564 | | - | |
| 574 | + | |
| 575 | + | |
565 | 576 | | |
566 | | - | |
567 | | - | |
568 | | - | |
569 | | - | |
570 | | - | |
571 | | - | |
572 | | - | |
573 | | - | |
574 | | - | |
| 577 | + | |
575 | 578 | | |
576 | | - | |
| 579 | + | |
| 580 | + | |
| 581 | + | |
577 | 582 | | |
578 | 583 | | |
579 | 584 | | |
| |||
597 | 602 | | |
598 | 603 | | |
599 | 604 | | |
600 | | - | |
| 605 | + | |
601 | 606 | | |
602 | | - | |
603 | | - | |
604 | | - | |
| 607 | + | |
| 608 | + | |
| 609 | + | |
| 610 | + | |
| 611 | + | |
605 | 612 | | |
606 | 613 | | |
607 | 614 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
914 | 914 | | |
915 | 915 | | |
916 | 916 | | |
917 | | - | |
| 917 | + | |
918 | 918 | | |
919 | 919 | | |
920 | 920 | | |
| |||
2679 | 2679 | | |
2680 | 2680 | | |
2681 | 2681 | | |
2682 | | - | |
| 2682 | + | |
2683 | 2683 | | |
2684 | 2684 | | |
2685 | 2685 | | |
2686 | 2686 | | |
2687 | 2687 | | |
2688 | 2688 | | |
2689 | 2689 | | |
2690 | | - | |
| 2690 | + | |
2691 | 2691 | | |
2692 | 2692 | | |
2693 | | - | |
2694 | | - | |
2695 | | - | |
2696 | | - | |
| 2693 | + | |
| 2694 | + | |
2697 | 2695 | | |
2698 | 2696 | | |
2699 | | - | |
| 2697 | + | |
2700 | 2698 | | |
2701 | 2699 | | |
2702 | 2700 | | |
2703 | | - | |
2704 | | - | |
2705 | | - | |
2706 | | - | |
2707 | 2701 | | |
2708 | | - | |
2709 | | - | |
2710 | | - | |
2711 | 2702 | | |
2712 | 2703 | | |
2713 | 2704 | | |
| |||
2925 | 2916 | | |
2926 | 2917 | | |
2927 | 2918 | | |
2928 | | - | |
| 2919 | + | |
2929 | 2920 | | |
2930 | 2921 | | |
2931 | 2922 | | |
2932 | 2923 | | |
2933 | 2924 | | |
2934 | | - | |
2935 | | - | |
2936 | | - | |
2937 | | - | |
| 2925 | + | |
| 2926 | + | |
| 2927 | + | |
| 2928 | + | |
| 2929 | + | |
| 2930 | + | |
| 2931 | + | |
| 2932 | + | |
| 2933 | + | |
| 2934 | + | |
2938 | 2935 | | |
2939 | 2936 | | |
2940 | | - | |
2941 | | - | |
2942 | | - | |
2943 | | - | |
| 2937 | + | |
| 2938 | + | |
| 2939 | + | |
| 2940 | + | |
| 2941 | + | |
| 2942 | + | |
| 2943 | + | |
| 2944 | + | |
2944 | 2945 | | |
2945 | 2946 | | |
2946 | 2947 | | |
2947 | 2948 | | |
| 2949 | + | |
| 2950 | + | |
| 2951 | + | |
| 2952 | + | |
2948 | 2953 | | |
2949 | 2954 | | |
2950 | 2955 | | |
| |||
0 commit comments