summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdgpu/cik_sdma.c
diff options
context:
space:
mode:
authorSong Liu <song@kernel.org>2024-08-29 11:22:13 -0700
committerSong Liu <song@kernel.org>2024-08-29 11:22:13 -0700
commitfb16787b396c46158e46b588d357dea4e090020b (patch)
tree8ead8ea006ad07ad4f13880e9d7d49dddebbcdef /drivers/gpu/drm/amd/amdgpu/cik_sdma.c
parent7f67fdae3372c323ad02601ab65502c9e488a521 (diff)
parent6f039cc42f21985ef0c31eb315a84f2364bcb396 (diff)
Merge branch 'md-6.12-raid5-opt' into md-6.12
From Artur: The wait_for_overlap wait queue is currently used in two cases, which are not really related: - waiting for actual overlapping bios, which uses R5_Overlap bit, - waiting for events related to reshape. Handling every write request in raid5_make_request() involves adding to and removing from this wait queue, which uses a spinlock. With fast storage and multiple submitting threads the contention on this lock is noticeable. This patch series aims to resolve this by separating the two cases mentioned above and using this wait queue only when reshape is in progress. The results when testing 4k random writes on raid5 with null_blk (8 jobs, qd=64, group_thread_cnt=8): before: 463k IOPS after: 523k IOPS The improvement is not huge with this series alone but it is just one of the bottlenecks. When applied onto some other changes I'm working on, it allowed to go from 845k IOPS to 975k IOPS on the same test. * md-6.12-raid5-opt: md/raid5: rename wait_for_overlap to wait_for_reshape md/raid5: only add to wq if reshape is in progress md/raid5: use wait_on_bit() for R5_Overlap Signed-off-by: Song Liu <song@kernel.org>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/cik_sdma.c')
0 files changed, 0 insertions, 0 deletions