T12641: Refactor KFileProtocol::copy

Méven Car noreply at phabricator.kde.org
Mon Feb 3 02:55:40 GMT 2020


meven created this task.
meven triaged this task as "Normal" priority.
meven added projects: Frameworks, Dolphin.

TASK DESCRIPTION
  Our man file copy function has some glaring issues that I'd like to tackle in a few steps:
  
  - Split the sendfile and read/write code path to function, to make evolution easier
  - Then Make those function io calls  (read, write, sendfile) O_NONBLOCK and use select/poll freeing user space CPU time to for instance notify the user of progressand  and reducing chances of blocking in both ways (file io blocking or socket/ksmserver blocking)
  - Then make the sendFile/write operation O_DIRECT and O_SYNC (https://linux.die.net/man/2/open), perhaps by default, or option or depending on the fs destination. Fixing https://bugs.kde.org/show_bug.cgi?id=281270 `Inconsistent notifications during/after file operations (copying, moving, deleting, compressing, extracting) depending on amount of data/items involved` (another to fix this is to mount usb sticks with the sync mount option)
  
  Then if needed :
  
  - Tune the parameters of the sendFile code path to copy data by chunks bigger than 32kB, I am thinking 128/512 to keep granular progress reporting,
  - Tune the read/write (it reads and write by chunks of 32kB at the moment
  
  Bonus steps
  
  - Add a io_uring (https://lwn.net/Articles/778411/) code path for recent linux kernels
  
  All of those steps should make the code more async, maintainable and performant, and fix a few longstanding bugs.
  
  It should help on 
   *`Ridiculously slow file copy (multiple small files)` https://bugs.kde.org/show_bug.cgi?id=342056

TASK DETAIL
  https://phabricator.kde.org/T12641

To: meven
Cc: apol, dfaure, #frameworks, #dolphin, ognarb, broulik, meven, pberestov, iasensio, fprice, LeGast00n, MrPepe, fbampaloukas, alexde, GB_2, Codezela, feverfew, michaelh, spoorun, navarromorales, firef, ngraham, andrebarros, bruns, emmanuelp, mikesomov
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20200203/0f67159b/attachment-0001.html>


More information about the Kde-frameworks-devel mailing list