Re: bus_to_virt equivalent

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Matthew,

Thanks for the reply.
I can store the returned dma_addr from
pci_map_sg/single or pci_map_page in a driver
structure.

struct page *page =
virt_to_page(Cmnd->request_buffer);
                unsigned long offset = ((unsigned
long)Cmnd->request_buffer &
                                        ~PAGE_MASK);
                dma_addr_t busaddr =
pci_map_page(hostdata->pci_dev,
                                                 
page, offset,
                                                 
Cmnd->request_bufflen,
                                                 
scsi_to_pci_dma_dir(Cmnd->sc_data_direction));

But how do I convert this returned "busaddr" into a
virtual addr?

regards,
Anil

--- Matthew Wilcox <[email protected]> wrote:

> On Mon, Nov 07, 2005 at 03:52:47PM -0800, Anil kumar
> wrote:
> > Hi,
> > 
> > I am trying to port bus_to_virt and virt_to_bus to
> the
> > DMA-mapping scheme.
> > I found a way to move virt_to_bus() as follows:
> > page = virt_to_page(cmd->request_buffer);
> > offset = (unsigned long)address & ~PAGE_MASK;
> > dma_addr_t addr = pci_map_page(dev, page, offset,
> > size,direction);
> > 
> > But now I want to get virtual address for
> dma_addr_t.
> 
> Did you *read* DMA-mapping.txt?
> 
>   Drivers converted fully to this interface should
> not use virt_to_bus
>   any longer, nor should they use bus_to_virt. Some
> drivers have to
>   be changed a little bit, because
>   *there is no longer an equivalent to bus_to_virt
> in the dynamic
>   DMA mapping scheme*
>   - you have to always store the DMA addresses
> returned by the
>   pci_alloc_consistent, pci_pool_alloc, and
> pci_map_single calls
>   (pci_map_sg stores them in the scatterlist itself
> if the platform
>   supports dynamic DMA mapping in hardware) in your
> driver structures
>   and/or in the card registers.
> 
> The reason for this is that there may be many
> physical addresses which
> correspond to the same bus address.  For example
> (this is on an HP rx8620)
> the bus address c001b000 maps to 00000f000001b000
> for device 00:03.0,
> 00000f010001b000 for device 40:03.0,
> 00000f020001b000 for device 80:03.0
> and 00000f030001b000 for device c0:03.0.
> 
> Now, maybe we should add a function:
> 
> unsigned long device_bus_addr_to_phys(struct device
> *dev, dma_addr_t handle);
> 
> but we don't have one yet.  So you have to follow
> the rules above.
> 



	
		
__________________________________ 
Yahoo! Mail - PC Magazine Editors' Choice 2005 
http://mail.yahoo.com
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

[Index of Archives]     [Kernel Newbies]     [Netfilter]     [Bugtraq]     [Photo]     [Stuff]     [Gimp]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Video 4 Linux]     [Linux for the blind]     [Linux Resources]
  Powered by Linux