<div dir="ltr">AFAIK.<br><br><div>1) as we know pci_alloc_consistent allocates dma buffers which is visible to DMA controller as well as CPU.</div>
<div>    virt_add = pci_alloc_consistent(pdev, size, dma_addr_t bus_adrr);</div><div><br></div><div>here it will allocate a buffer and return its virtual address and corresponding bus address.</div><div>
<br></div><div>My question is do these two address ultimately point to similar location but from different perspectives ?.<br><br></div><div>Avinash: Yes both virtual and physical addresses point to same location. BAR at the enumeration of PCI devices allocates specific address for PCI devices from RAM and your alloc_consistent uses these addresses.<br>
</div><div><br></div><div>2) After allocating these address, how do we proceed given that i have a ASIC register which has the dma_rx_desc_start address ?</div>
<div>Avinash: Here is a link which can help you for creating rings, creating your ISR which handles different vendor specific interrupts etc<br><br><a href="http://netsecinfo.blogspot.in/search?q=PCIe">http://netsecinfo.blogspot.in/search?q=PCIe</a><br>
<br></div><div>Avinash: <br></div><div>3) Also does all the HW&#39;s which support dma have the
 descriptor data structures by provided by Vender or is there any 
specific format that dev has to be aware of for designing such 
descriptor for that particular driver ?<br></div><div>Avinash: These structures are vendor specific which may contain physical address, length etc.<br></div>

<br></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Thu, Mar 28, 2013 at 1:14 AM, Dhananjay Maske <span dir="ltr">&lt;<a href="mailto:dhananjay.maske87@gmail.com" target="_blank">dhananjay.maske87@gmail.com</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Hi All,<div>     I am fairly New to Linux kernel Programming and i have few questions with respect to pci_alloc_consistent .</div>
<div><br></div><div>1) as we know pci_alloc_consistent allocates dma buffers which is visible to DMA controller as well as CPU.</div>
<div>    virt_add = pci_alloc_consistent(pdev, size, dma_addr_t bus_adrr);</div><div><br></div><div>here it will allocate a buffer and return its virtual address and corresponding bus address.</div><div>
<br></div><div>My question is do these two address ultimately point to similar location but from different perspectives ?.</div><div><br></div><div>2) After allocating these address, how do we proceed given that i have a ASIC register which has the dma_rx_desc_start address ?</div>

<div><br></div><div>3) Also does all the HW&#39;s which support dma have the descriptor data structures by provided by Vender or is there any specific format that dev has to be aware of for designing such descriptor for that particular driver ?</div>

</div>
<br>_______________________________________________<br>
Kernelnewbies mailing list<br>
<a href="mailto:Kernelnewbies@kernelnewbies.org">Kernelnewbies@kernelnewbies.org</a><br>
<a href="http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies" target="_blank">http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies</a><br>
<br></blockquote></div><br></div>