lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <a00f0b55-0681-4e9c-b75e-e7e3d4110471@arm.com>
Date: Fri, 1 Mar 2024 12:42:39 +0000
From: Robin Murphy <robin.murphy@....com>
To: "Michael S. Tsirkin" <mst@...hat.com>
Cc: Xuan Zhuo <xuanzhuo@...ux.alibaba.com>, linux-kernel@...r.kernel.org,
 Joerg Roedel <joro@...tes.org>, Will Deacon <will@...nel.org>,
 Christoph Hellwig <hch@....de>, Marek Szyprowski <m.szyprowski@...sung.com>,
 iommu@...ts.linux.dev, Zelin Deng <zelin.deng@...ux.alibaba.com>
Subject: Re: [RFC] dma-mapping: introduce dma_can_skip_unmap()

On 2024-03-01 11:50 am, Michael S. Tsirkin wrote:
> On Fri, Mar 01, 2024 at 11:38:25AM +0000, Robin Murphy wrote:
>> Not only is this idea not viable, the entire premise seems flawed - the
>> reasons for virtio needing to use the DMA API at all are highly likely to be
>> the same reasons for it needing to use the DMA API *properly* anyway.
> 
> The idea has nothing to do with virtio per se

Sure, I can see that, but if virtio is presented as the justification 
for doing this then it's the justification I'm going to look at first. 
And the fact is that it *does* seem to have particular significance, 
since having up to 19 DMA addresses involved in a single transfer is 
very much an outlier compared to typical hardware drivers. Furthermore 
the fact that DMA API support was retrofitted to the established virtio 
design means I would always expect it to run up against more challenges 
than a hardware driver designed around the expectation that DMA buffers 
have DMA addresses.

> - we are likely not the
> only driver that wastes a lot of memory (hot in cache, too) keeping DMA
> addresses around for the sole purpose of calling DMA unmap.  On a bunch
> of systems unmap is always a nop and we could save some memory if there
> was a way to find out. What is proposed is an API extension allowing
> that for anyone - not just virtio.

And the point I'm making is that that "always" is a big assumption, and 
in fact for the situations where it is robustly true we already have the 
DEFINE_DMA_UNMAP_{ADDR,LEN} mechanism. I'd consider it rare for DMA 
addresses to be stored in isolation, as opposed to being part of some 
kind of buffer descriptor (or indeed struct scatterlist, for an obvious 
example) that a driver or subsystem still has to keep track of anyway, 
so in general I believe the scope for saving decidedly small amounts of 
memory at runtime is also considerably less than you might be imagining.

Thanks,
Robin.

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ