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
next prev parent 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