In 64K pagesize system, DPDK will read the size NIC need in 
uio/uio1/maps/map1/size,  when the size small than pagesize(e.g.,82599 is 16K), 
dev->mem_resource[i].len will be 16K, but the mmap function applies for at 
least 1 page size, which is 64K. 
Then second NIC mmap, start address is first NIC address + 16K, which already 
used by first NIC.
So if change the size to first NIC address + 64K, problem solved.

-----邮件原件-----
发件人: David Marchand [mailto:david.march...@redhat.com]
发送时间: 2019年11月5日 22:33
收件人: Wangyu (Turing Solution Development Dep) <seven.wan...@huawei.com>
抄送: dev@dpdk.org; ferruh.yi...@intel.com; Linuxarm <linux...@huawei.com>; humin 
(Q) <humi...@huawei.com>; Liyuan (Larry) <larr...@huawei.com>; dengxiaofeng 
<dengxiaof...@huawei.com>
主题: Re: [dpdk-dev] [PATCH v2] bus/pci: resolve multiple NICs address conflicts

On Tue, Nov 5, 2019 at 8:27 AM Wangyu (Turing Solution Development
Dep) <seven.wan...@huawei.com> wrote:
>
>
> NIC address conflicts on 64K pagesize when using multiple NICs, as 
> system will mmap 64K pagesize for NIC, but dev->mem_resource[i].len is 
> 16K.

Please, can you describe the problem you want to fix?
Is this a problem specific to a pci device you are using?

Thanks.

>
> Signed-off-by: Beard-627 <dengxiaof...@huawei.com>
> Signed-off-by: Eric wang <seven.wan...@huawei.com>
> Acked-by: Wei Hu <xavier.hu...@huawei.com>
> Acked-by: Min Hu <humi...@huawei.com>
> ---
>  drivers/bus/pci/linux/pci.c | 5 +++++
>  1 file changed, 5 insertions(+)
>
> diff --git a/drivers/bus/pci/linux/pci.c b/drivers/bus/pci/linux/pci.c 
> index 43debaa..afaa68d 100644
> --- a/drivers/bus/pci/linux/pci.c
> +++ b/drivers/bus/pci/linux/pci.c
> @@ -201,6 +201,11 @@
>                 if (flags & IORESOURCE_MEM) {
>                         dev->mem_resource[i].phys_addr = phys_addr;
>                         dev->mem_resource[i].len = end_addr - 
> phys_addr + 1;
> +                       if (dev->mem_resource[i].len <
> +                               (unsigned int)getpagesize())
> +
> +                               dev->mem_resource[i].len =
> +                                       (unsigned int)getpagesize();
>                         /* not mapped for now */
>                         dev->mem_resource[i].addr = NULL;
>                 }
> --
> 1.8.3.1


--
David Marchand

Reply via email to