tcmu data area double copy overhead

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



hi,

I'm a newcomer to tcmu or iscsi subsystem, and have spent several days to learn
iSCSI and tcmu, so if my question looks fool, forgive me :)

One of our customers is using tcmu to visit remote distributed filesystem and finds that there's obvious copy overhead in tcmu while doing read operations, so I spent time to find the reason and see whether can optimize a bit. Now according to my understanding about tcmu kernel codes, tcmu allocates internal data pages for data area, use these data pages as temporary storage between user-space backstore and tcmu. For iSCSI initiator's write request, tcmu first copy sg page's content to internal data pages, then user-space backstore moves mmaped data area for these data pages to backstore; for iSCSI initiator's read request, tcmu also allocates internal data pages, backstore copies distributed filesystem's data to these data pages, later tcmu copy data pages' content to sg's pages. That means for both read and write requests, it
exists one extra data copy.

So my question is that whether we don't allocate internal data pages in tcmu, just make sg's pages to be mmaped in data area, so we can reduce one extra copy, which I think it can improve throughput. Or is there any special security issues that we can not do
this way? Thanks.


Regards,
Xiaoguang Wang



[Index of Archives]     [Linux SCSI]     [Kernel Newbies]     [Linux SCSI Target Infrastructure]     [Share Photos]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Device Mapper]

  Powered by Linux