[dpdk-users] segmention fault while accessing mbuf

Stephen Hemminger stephen at networkplumber.org
Mon Jun 1 18:17:29 CEST 2020


On Mon, 01 Jun 2020 15:24:25 +0200
Alex Kiselev <alex at therouter.net> wrote:

> Hello,
> 
> I've got a segmentation fault error in my data plane path.
> I am pretty sure the code where the segfault happened is ok,
> so my guess is that I somehow received a corrupted mbuf.
> How could I troubleshoot this? Is there any way?
> Is it possible that other threads of the application
> corrupted that mbuf?
> 
> I would really appriciate any advice.
> Thanks.
> 
> DPDK 18.11.3
> NIC: 82599ES
> 
> Code:
> 
> nb_rx = rte_eth_rx_burst(port_id, queue_id, pkts_burst,
> 		  MAX_PKT_BURST);
> 
> ...
> 
> for (i=0; i < vec_size; i++) {
> 	rte_prefetch0(rte_pktmbuf_mtod(m_v[i], void *));
> 
> for (i=0; i < vec_size; i++) {
> 	m = m_v[i];
> 	eth_hdr = rte_pktmbuf_mtod(m, struct ether_hdr *);
> 	eth_type = rte_be_to_cpu_16(eth_hdr->ether_type);               <--- 
> Segmentation fault
> 	...
> 
> #0  rte_arch_bswap16 (_x=<error reading variable: Cannot access memory 
> at address 0x4d80000000053010>)

Build with as many of the debug options turned on in the DPDK config,
and build with EXTRA_CFLAGS of -g.


More information about the users mailing list