Feature #13867
closed
Copy offloading in IO.copy_stream
Added by Glass_saga (Masaki Matsushita) over 7 years ago.
Updated about 7 years ago.
Description
In linux 4.5, the copy offloading feature with copy_file_range(2) was introduced.
This patch enables IO.copy_stream to use it.
If "offload" keyword argument is specified, IO.copy_stream will try copy offloading.
IO.copy_stream("src", "dst", offload: true)
If copy offloading is not available on the system, "offload" option will be ignored.
When "src" and "dst" are not in the same filesystem, copy_file_range(2) must fail with EXDEV.
In this case, IO.copy_steram will fallback to another method (sendfile(2) or read/write) silently.
It depends on the filesystem what offloading techniques will be used.
Copy offloading is optional in IO.copy_stream because some techniques may change the current behavior.
Files
patch.diff (7.21 KB)
patch.diff |
|
Glass_saga (Masaki Matsushita), 09/05/2017 09:06 AM
|
|
patch2.diff (3.35 KB)
patch2.diff |
use copy_file_range(2) without keyword arguments |
Glass_saga (Masaki Matsushita), 10/21/2017 06:26 AM
|
|
glass.saga@gmail.com wrote:
In linux 4.5, the copy offloading feature with copy_file_range(2) was introduced.
This patch enables IO.copy_stream to use it.
Cool.
If "offload" keyword argument is specified, IO.copy_stream will try copy offloading.
Is a new keyword arg necessary? Since this is Linux-only, and
we already do fstat tests on both FDs in the sendfile checking:
We can try using copy_file_range if both src and dst are both
regular files with identical .st_dev, and fall back to using
sendfile on ENOSYS.
Thanks.
We took a look at this issue at yesterday's developer meeting and agreed with Eric here; it can be automatically applied whenever possible. Seems there are no practical reasons to disable this feature.
- File patch2.diff patch2.diff added
- Status changed from Open to Assigned
- Assignee set to Glass_saga (Masaki Matsushita)
This patch makes IO.copy_stream use copy_file_range(2) without keyword arguments.
- Status changed from Assigned to Closed
Also available in: Atom
PDF
Like0
Like0Like0Like0Like0Like0