public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Jens Axboe <axboe@suse.de>
To: "linux-os (Dick Johnson)" <linux-os@analogic.com>
Cc: "Ju, Seokmann" <Seokmann.Ju@lsil.com>,
	"Ju, Seokmann" <Seokmann.Ju@engenio.com>,
	Linux kernel <linux-kernel@vger.kernel.org>,
	linux-scsi@vger.kernel.org
Subject: Re: Question: how to map SCSI data DMA address to virtual address?
Date: Thu, 2 Mar 2006 21:14:53 +0100	[thread overview]
Message-ID: <20060302201452.GX4329@suse.de> (raw)
In-Reply-To: <Pine.LNX.4.61.0603021458060.14681@chaos.analogic.com>

On Thu, Mar 02 2006, linux-os (Dick Johnson) wrote:
> 
> On Thu, 2 Mar 2006, Jens Axboe wrote:
> 
> > On Thu, Mar 02 2006, linux-os (Dick Johnson) wrote:
> >>
> >> On Thu, 2 Mar 2006, Ju, Seokmann wrote:
> >>
> >>> Hi,
> >>>
> >>> In the 'scsi_cmnd' structure, there are two entries holding address
> >>> information for data to be transferred. One is 'request_buffer' and the
> >>> other one is 'buffer'.
> >>> In case of 'use_sg' is non-zero, those entries indicates the address of
> >>> the scatter-gather table.
> >>>
> >>> Is there way to get virtual address (so that the data could be accessed
> >>> by the driver) of the actual data in the case of 'use_sg' is non-zero?
> >>>
> >>> Any comments would be appreciated.
> >>>
> >>>
> >>> Thank you,
> >>>
> >>> Seokmann
> >>> -
> >>
> >> There is a macro for this purpose. However, for experiments, in
> >> the kernel, you can add PAGE_OFFSET (0xC00000000) to get the virtual
> >> address. The macro is __va(a), its inverse is __pa(a).
> >>
> >> Careful. These things can change.
> >
> > Bzzt no, this wont work if an iommu is involved. It also wont work if
> > the page doesn't have a virtual address mapping (think highmem).
> >
> > --

> > Jens Axboe
> >
> 
> Are you going to get DMA-able pages out of high memory? The guy is
> doing scatter-table DMA, i.e., linked DMA. I think you need to
> build that table with pages from get_dma_page(). If you use

A highmem page is a regular page, it just doesn't have a kernel virtual
mapping. You can dma to/from these pages just fine.

> highmem, somebody can program the iommu right out from under
> the DMA engine while a DMA is in progress because the CPU is
> not involved and can be executing lots of code that can do lots
> of bad things.

Nonsense. You can't have multiple iommu mappings or dma transactions
against the same highmem page of course, however that is no different
than a low mem page.

-- 
Jens Axboe


  reply	other threads:[~2006-03-02 20:15 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-03-02 16:53 Question: how to map SCSI data DMA address to virtual address? Ju, Seokmann
2006-03-02 16:58 ` Arjan van de Ven
2006-03-02 17:09 ` linux-os (Dick Johnson)
2006-03-02 18:49   ` Jens Axboe
2006-03-02 20:03     ` linux-os (Dick Johnson)
2006-03-02 20:14       ` Jens Axboe [this message]
2006-03-02 17:09 ` Christoph Hellwig
2006-03-02 17:22   ` James Bottomley
  -- strict thread matches above, loose matches on Subject: below --
2006-03-02 17:04 Ju, Seokmann
2006-03-02 17:21 Ju, Seokmann
2006-03-02 21:04 Ju, Seokmann
2006-03-02 21:32 ` linux-os (Dick Johnson)
2006-03-02 21:42 ` James Bottomley

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=20060302201452.GX4329@suse.de \
    --to=axboe@suse.de \
    --cc=Seokmann.Ju@engenio.com \
    --cc=Seokmann.Ju@lsil.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-os@analogic.com \
    --cc=linux-scsi@vger.kernel.org \
    /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: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox