From: Jason Gunthorpe <jgg@nvidia.com> To: Jacob Pan <jacob.jun.pan@linux.intel.com> Cc: Barry Song <21cnbao@gmail.com>, iommu@lists.linux-foundation.org, LKML <linux-kernel@vger.kernel.org>, Joerg Roedel <joro@8bytes.org>, Christoph Hellwig <hch@infradead.org>, Lu Baolu <baolu.lu@linux.intel.com>, Raj Ashok <ashok.raj@intel.com>, "Kumar, Sanjay K" <sanjay.k.kumar@intel.com>, Dave Jiang <dave.jiang@intel.com>, Tony Luck <tony.luck@intel.com>, mike.campin@intel.com, Yi Liu <yi.l.liu@intel.com>, "Tian, Kevin" <kevin.tian@intel.com> Subject: Re: [RFC 0/7] Support in-kernel DMA with PASID and SVA Date: Mon, 4 Oct 2021 15:21:42 -0300 [thread overview] Message-ID: <20211004182142.GM964074@nvidia.com> (raw) In-Reply-To: <20211004094003.527222e5@jacob-builder> On Mon, Oct 04, 2021 at 09:40:03AM -0700, Jacob Pan wrote: > Hi Barry, > > On Sat, 2 Oct 2021 01:45:59 +1300, Barry Song <21cnbao@gmail.com> wrote: > > > > > > > > I assume KVA mode can avoid this iotlb flush as the device is using > > > > the page table of the kernel and sharing the whole kernel space. But > > > > will users be glad to accept this mode? > > > > > > You can avoid the lock be identity mapping the physical address space > > > of the kernel and maping map/unmap a NOP. > > > > > > KVA is just a different way to achive this identity map with slightly > > > different security properties than the normal way, but it doesn't > > > reach to the same security level as proper map/unmap. > > > > > > I'm not sure anyone who cares about DMA security would see value in > > > the slight difference between KVA and a normal identity map. > > > > yes. This is an important question. if users want a high security level, > > kva might not their choice; if users don't want the security, they are > > using iommu passthrough. So when will users choose KVA? > Right, KVAs sit in the middle in terms of performance and security. > Performance is better than IOVA due to IOTLB flush as you mentioned. Also > not too far behind of pass-through. The IOTLB flush is not on a DMA path but on a vmap path, so it is very hard to compare the two things.. Maybe vmap can be made to do lazy IOTLB flush or something and it could be closer > Security-wise, KVA respects kernel mapping. So permissions are better > enforced than pass-through and identity mapping. Is this meaningful? Isn't the entire physical map still in the KVA and isn't it entirely RW ? Jason
WARNING: multiple messages have this Message-ID (diff)
From: Jason Gunthorpe via iommu <iommu@lists.linux-foundation.org> To: Jacob Pan <jacob.jun.pan@linux.intel.com> Cc: "Tian, Kevin" <kevin.tian@intel.com>, Tony Luck <tony.luck@intel.com>, Dave Jiang <dave.jiang@intel.com>, Raj Ashok <ashok.raj@intel.com>, "Kumar, Sanjay K" <sanjay.k.kumar@intel.com>, Barry Song <21cnbao@gmail.com>, LKML <linux-kernel@vger.kernel.org>, Christoph Hellwig <hch@infradead.org>, iommu@lists.linux-foundation.org, mike.campin@intel.com Subject: Re: [RFC 0/7] Support in-kernel DMA with PASID and SVA Date: Mon, 4 Oct 2021 15:21:42 -0300 [thread overview] Message-ID: <20211004182142.GM964074@nvidia.com> (raw) In-Reply-To: <20211004094003.527222e5@jacob-builder> On Mon, Oct 04, 2021 at 09:40:03AM -0700, Jacob Pan wrote: > Hi Barry, > > On Sat, 2 Oct 2021 01:45:59 +1300, Barry Song <21cnbao@gmail.com> wrote: > > > > > > > > I assume KVA mode can avoid this iotlb flush as the device is using > > > > the page table of the kernel and sharing the whole kernel space. But > > > > will users be glad to accept this mode? > > > > > > You can avoid the lock be identity mapping the physical address space > > > of the kernel and maping map/unmap a NOP. > > > > > > KVA is just a different way to achive this identity map with slightly > > > different security properties than the normal way, but it doesn't > > > reach to the same security level as proper map/unmap. > > > > > > I'm not sure anyone who cares about DMA security would see value in > > > the slight difference between KVA and a normal identity map. > > > > yes. This is an important question. if users want a high security level, > > kva might not their choice; if users don't want the security, they are > > using iommu passthrough. So when will users choose KVA? > Right, KVAs sit in the middle in terms of performance and security. > Performance is better than IOVA due to IOTLB flush as you mentioned. Also > not too far behind of pass-through. The IOTLB flush is not on a DMA path but on a vmap path, so it is very hard to compare the two things.. Maybe vmap can be made to do lazy IOTLB flush or something and it could be closer > Security-wise, KVA respects kernel mapping. So permissions are better > enforced than pass-through and identity mapping. Is this meaningful? Isn't the entire physical map still in the KVA and isn't it entirely RW ? Jason _______________________________________________ iommu mailing list iommu@lists.linux-foundation.org https://lists.linuxfoundation.org/mailman/listinfo/iommu
next prev parent reply other threads:[~2021-10-04 18:21 UTC|newest] Thread overview: 58+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-09-21 20:29 [RFC 0/7] Support in-kernel DMA with PASID and SVA Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 1/7] ioasid: reserve special PASID for in-kernel DMA Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 2/7] dma-iommu: Add API for DMA request with PASID Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 3/7] iommu/vt-d: Add DMA w/ PASID support for PA and IOVA Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 4/7] dma-iommu: Add support for DMA w/ PASID in KVA Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 5/7] iommu/vt-d: Add support for KVA PASID mode Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 6/7] iommu: Add KVA map API Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-21 20:29 ` [RFC 7/7] dma/idxd: Use dma-iommu PASID API instead of SVA lib Jacob Pan 2021-09-21 20:29 ` Jacob Pan 2021-09-22 17:04 ` [RFC 0/7] Support in-kernel DMA with PASID and SVA Jason Gunthorpe 2021-09-22 17:04 ` Jason Gunthorpe via iommu 2021-09-29 19:37 ` Jacob Pan 2021-09-29 19:37 ` Jacob Pan 2021-09-29 19:39 ` Jason Gunthorpe 2021-09-29 19:39 ` Jason Gunthorpe via iommu 2021-09-29 22:57 ` Jacob Pan 2021-09-29 22:57 ` Jacob Pan 2021-09-29 23:43 ` Jason Gunthorpe 2021-09-29 23:43 ` Jason Gunthorpe via iommu 2021-09-30 14:22 ` Campin, Mike 2021-09-30 14:22 ` Campin, Mike 2021-09-30 15:21 ` Jacob Pan 2021-09-30 15:21 ` Jacob Pan 2021-10-01 12:24 ` Barry Song 2021-10-01 12:24 ` Barry Song 2021-10-01 12:36 ` Jason Gunthorpe 2021-10-01 12:36 ` Jason Gunthorpe via iommu 2021-10-01 12:45 ` Barry Song 2021-10-01 12:45 ` Barry Song 2021-10-04 16:40 ` Jacob Pan 2021-10-04 16:40 ` Jacob Pan 2021-10-04 18:21 ` Jason Gunthorpe [this message] 2021-10-04 18:21 ` Jason Gunthorpe via iommu 2021-10-07 5:43 ` Barry Song 2021-10-07 5:43 ` Barry Song 2021-10-07 11:32 ` Jason Gunthorpe 2021-10-07 11:32 ` Jason Gunthorpe via iommu 2021-10-07 11:54 ` Barry Song 2021-10-07 11:54 ` Barry Song 2021-10-07 11:59 ` Jason Gunthorpe 2021-10-07 11:59 ` Jason Gunthorpe via iommu 2021-10-07 17:50 ` Jacob Pan 2021-10-07 17:50 ` Jacob Pan 2021-10-07 17:48 ` Jason Gunthorpe 2021-10-07 17:48 ` Jason Gunthorpe via iommu 2021-10-07 18:08 ` Jacob Pan 2021-10-07 18:08 ` Jacob Pan 2021-10-07 19:11 ` Jacob Pan 2021-10-07 19:11 ` Jacob Pan 2021-10-07 19:10 ` Jason Gunthorpe 2021-10-07 19:10 ` Jason Gunthorpe via iommu
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20211004182142.GM964074@nvidia.com \ --to=jgg@nvidia.com \ --cc=21cnbao@gmail.com \ --cc=ashok.raj@intel.com \ --cc=baolu.lu@linux.intel.com \ --cc=dave.jiang@intel.com \ --cc=hch@infradead.org \ --cc=iommu@lists.linux-foundation.org \ --cc=jacob.jun.pan@linux.intel.com \ --cc=joro@8bytes.org \ --cc=kevin.tian@intel.com \ --cc=linux-kernel@vger.kernel.org \ --cc=mike.campin@intel.com \ --cc=sanjay.k.kumar@intel.com \ --cc=tony.luck@intel.com \ --cc=yi.l.liu@intel.com \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.