summaryrefslogtreecommitdiff
path: root/tools/perf/scripts/python/compaction-times.py
diff options
context:
space:
mode:
authorOleg Nesterov <oleg@redhat.com>2025-02-10 14:40:39 +0300
committerChristian Brauner <brauner@kernel.org>2025-02-12 17:34:56 +0300
commitee5eda8ea59546af2e8f192c060fbf29862d7cbd (patch)
tree6329df5bbbe459f65e538f5c6ae34c823a2fe035 /tools/perf/scripts/python/compaction-times.py
parentf2ffc48de2017c690f3e7cb34ae7acf40842babc (diff)
downloadlinux-ee5eda8ea59546af2e8f192c060fbf29862d7cbd.tar.xz
pipe: change pipe_write() to never add a zero-sized buffer
a194dfe6e6f6 ("pipe: Rearrange sequence in pipe_write() to preallocate slot") changed pipe_write() to increment pipe->head in advance. IIUC to avoid the race with the post_one_notification()-like code which can add another buffer under pipe->rd_wait.lock without pipe->mutex. This is no longer necessary after c73be61cede5 ("pipe: Add general notification queue support"), pipe_write() checks pipe_has_watch_queue() and returns -EXDEV at the start. And can't help in any case, pipe_write() no longer takes this rd_wait.lock spinlock. Change pipe_write() to call copy_page_from_iter() first and do nothing if it fails. This way pipe_write() can't add a zero-sized buffer and we can simplify pipe_read() which currently has to take care of this very unlikely case. Also, with this patch we can probably kill eat_empty_buffer() and more "is this buffer empty" checks in fs/splice.c later. Link: https://lore.kernel.org/all/20250209150718.GA17013@redhat.com/ Signed-off-by: Oleg Nesterov <oleg@redhat.com> Link: https://lore.kernel.org/r/20250210114039.GA3588@redhat.com Tested-by: K Prateek Nayak <kprateek.nayak@amd.com> Signed-off-by: Christian Brauner <brauner@kernel.org>
Diffstat (limited to 'tools/perf/scripts/python/compaction-times.py')
0 files changed, 0 insertions, 0 deletions