public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Question: how to map SCSI data DMA address to virtual address?
@ 2006-03-02 16:53 Ju, Seokmann
  2006-03-02 16:58 ` Arjan van de Ven
                   ` (2 more replies)
  0 siblings, 3 replies; 13+ messages in thread
From: Ju, Seokmann @ 2006-03-02 16:53 UTC (permalink / raw)
  To: Ju, Seokmann; +Cc: linux-kernel, linux-scsi

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

^ permalink raw reply	[flat|nested] 13+ messages in thread
* RE: Question: how to map SCSI data DMA address to virtual address?
@ 2006-03-02 17:04 Ju, Seokmann
  0 siblings, 0 replies; 13+ messages in thread
From: Ju, Seokmann @ 2006-03-02 17:04 UTC (permalink / raw)
  To: Arjan van de Ven; +Cc: linux-kernel, linux-scsi

Hi,

On Thursday, March 02, 2006 11:58 AM Arjan van de Ven wrote:
> Why do you need to do this? It's generally bad for drivers to snoop
> data! 
I understood that is bad. I am trying to make sure the data written to disk drive are identical with the data from upper layer by comparing actual data in the driver.
This is a part of debugging only not for release driver, obviously.
So, is it completely unable to get this done?
Any tricky solution?

Thank you,

> -----Original Message-----
> From: Arjan van de Ven [mailto:arjan@infradead.org] 
> Sent: Thursday, March 02, 2006 11:58 AM
> To: Ju, Seokmann
> Cc: Ju, Seokmann; linux-kernel@vger.kernel.org; 
> linux-scsi@vger.kernel.org
> Subject: Re: Question: how to map SCSI data DMA address to 
> virtual address?
> 
> On Thu, 2006-03-02 at 09:53 -0700, 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.
> 
> use_sg is never non-zero so that's easy
> 
> > 
> > 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?
> 
> not really; unless you mapped it. The physical address may 
> already been
> translated by the iommu... at which point there is no direct 
> mapping to
> kernel memory.
> 
> Why do you need to do this? It's generally bad for drivers to snoop
> data! 
> 
> 

^ permalink raw reply	[flat|nested] 13+ messages in thread
* RE: Question: how to map SCSI data DMA address to virtual address?
@ 2006-03-02 17:21 Ju, Seokmann
  0 siblings, 0 replies; 13+ messages in thread
From: Ju, Seokmann @ 2006-03-02 17:21 UTC (permalink / raw)
  To: Christoph Hellwig; +Cc: linux-kernel, linux-scsi

Hi,

Thursday, March 02, 2006 12:09 PM Christoph Hellwig wrote:
> For each sg list entry do something like:
> 
> 	buffer = kmap_atomic(sg->page, KM_USER0) + sg->offset;
> 	<access buffer>
> 	kunmap_atomic(buffer - sg->offset, KM_USER0);
Thank you for your comment!
I'll try with this.

Thank you again.

^ permalink raw reply	[flat|nested] 13+ messages in thread
* RE: Question: how to map SCSI data DMA address to virtual address?
@ 2006-03-02 21:04 Ju, Seokmann
  2006-03-02 21:32 ` linux-os (Dick Johnson)
  2006-03-02 21:42 ` James Bottomley
  0 siblings, 2 replies; 13+ messages in thread
From: Ju, Seokmann @ 2006-03-02 21:04 UTC (permalink / raw)
  To: linux-os (Dick Johnson), Jens Axboe; +Cc: Linux kernel, linux-scsi

Hi,

On Thursday, March 02, 2006 3:04 PM 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
> 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.
Thank you for your valueable comment. One good thing is that the system does 2 GB memory so that highmem won't come into picture. I am implementing the feature with suggestions.

Thank you again,

Seokmann


^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2006-03-02 21:42 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
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
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

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox