A kernel driver uses a dma mask specifying the memory address range supported by the device for DMA operations. With DPDK there is no possibility for doing the same thing so it could lead to problems with those devices not being able to use all the available physical memory.
This patchset adds support for a PMD setting a device dma mask. If this dma mask is set this will imply a call for checking hugepages allocated are within the supported device range. First patch adds the checking function. If there is a hugepage (memseg) out of the device supported range an error is raised. Nothing really we can do as any other available hugepage (and not allocated) will be also out of range as hugepages are ordered by physical address before allocating. Second patch adds call to the checking function if device dma mask is set during PMD initialization. Depending on how hugepages are created and the amount of them the checking could slow down initialization. If a device has not addressing limitations the checking is not done. Third patch adds support for setting dma mask in the PMD NFP. Current NFP card just supports 40 bits. Future versions will support 64 bits. Alejandro Lucero (3): eal/linux: add function for checking hugepages within device supported address range eth_dev: add support for device dma mask nfp: set device dma mask drivers/net/nfp/nfp_net.c | 11 +++++++++++ lib/librte_eal/common/include/rte_memory.h | 6 ++++++ lib/librte_eal/linuxapp/eal/eal_memory.c | 27 +++++++++++++++++++++++++++ lib/librte_ether/rte_ethdev.c | 7 +++++++ lib/librte_ether/rte_ethdev.h | 1 + 5 files changed, 52 insertions(+) -- 1.9.1