[dpdk-users] RTE Hash addition results to segmentation fault
Jatin Sahu
jatin152 at gmail.com
Fri Oct 23 13:10:24 CEST 2020
Hello guyz,
Any reference to resolve this issue?
On Thu, 22 Oct, 2020, 5:33 pm Jatin Sahu, <jatin152 at gmail.com> wrote:
> Hi,
>
> I am using DPDK's RTE hash data structure in a test application.
> The RTE initlilization and hash creation are successful but adding key to
> hash results in segmentation fault.
>
> Please find the details of code snipped, output and stack trace.
> I have written this code using example "server_node_efd/node/node.c" as
> reference.
> Please advise if there is any issue in usage or configuration.
>
> *Version: *dpdk-stable-18.11.6
>
> *Output:*
> [roamware at loadtestsrv dpdk-hash]$ ./Test
> EAL: Detected 72 lcore(s)
> EAL: Detected 2 NUMA nodes
> EAL: Multi-process socket /run/user/1000/dpdk/rte/mp_socket
> EAL: Probing VFIO support...
> EAL: Started without hugepages support, physical addresses not available
> Hash table created. Count:0
> Inserting key:d2040000 KeyAddr:0x7ffc2b1761fc
> Segmentation fault (core dumped)
>
> *Stack trace:*
> (gdb) where
> #0 0x000000000000007f in ?? ()
> #1 0x00000000004f0c48 in rte_hash_add_key ()
> #2 0x000000000047b08c in test () at HashTest.cpp:47
>
> *Code snippet:*
>
>> *void test()*
>> *{*
>> * /* rte init */*
>> * int argc = 4;*
>> * char *argv[] = {*
>> * "HashTest",*
>> * "-c",*
>> * "0x2",*
>> * "--no-huge"*
>> * };*
>> * int rc = rte_eal_init(argc, argv);*
>> * if(rc < 0)*
>> * rte_exit(EXIT_FAILURE, "RTE init failed \n");*
>>
>>
>> * /* create hash table */*
>> * uint32_t num_flows_node = 10;*
>> * char name[100];*
>> * struct rte_hash *h;*
>> * struct rte_hash_parameters hash_params;*
>> * int node_id=0;*
>> * hash_params.entries = num_flows_node * 2; /* table load = 50% */*
>> * hash_params.key_len = sizeof(uint32_t); /* Store IPv4 dest IP
>> address */*
>> * hash_params.socket_id = rte_socket_id();*
>> * hash_params.hash_func_init_val = 0;*
>> * snprintf(name, sizeof(name), "hash_table");*
>> * hash_params.name <http://hash_params.name> = name;*
>> * h = rte_hash_create(&hash_params);*
>> * if (h == NULL)*
>> * rte_exit(EXIT_FAILURE, "Problem creating the hash table
>> for node %d\n", node_id);*
>> * else*
>> * fprintf(stderr, "Hash table created. Count:%d\n",
>> rte_hash_count(h));*
>>
>>
>> * /* insert record to hash table */*
>> * unsigned int i=1234;*
>> * int32_t ret;*
>> * uint32_t ip_dst;*
>> * ip_dst = rte_cpu_to_be_32(i);*
>> * fprintf(stderr, "Inserting key:%x KeyAddr:%p\n", ip_dst,
>> &ip_dst);*
>> * ret = rte_hash_add_key(h, (void *) &ip_dst);*
>> * if (ret < 0)*
>> * rte_exit(EXIT_FAILURE, "Unable to add entry %u in hash
>> table\n", i);*
>> *}*
>
>
> Regards,
> Jatin
>
More information about the users
mailing list