Hi Surajit,
Thanks for your reactivity and your help. Like you, I thought the cpu has no ssse3 instruction, but if you take a look on the CPU flags, the SSSE3 flag is present. flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall nx mmxext fxsr_opt pdpe1gb rdtscp lm constant_tsc art rep_good nopl nonstop_tsc extd_apicid aperfmperf eagerfpu pni pclmulqdq monitor ssse3 fma cx16 sse4_1 sse4_2 x2apic movbe popcnt aes xsave avx f16c rdrand lahf_lm cmp_legacy svm extapic cr8_legacy abm sse4a misalignsse 3dnowprefetch osvw ibs skinit wdt tce topoext perfctr_core perfctr_nb bpext perfctr_l2 cpb cat_l3 cdp_l3 hw_pstate sme retpoline_amd ssbd ibrs ibpb stibp vmmcall fsgsbase bmi1 avx2 smep bmi2 cqm rdt_a rdseed adx smap clflushopt clwb sha_ni xsaveopt xsavec xgetbv1 cqm_llc cqm_occup_llc cqm_mbm_total cqm_mbm_local clzero irperf xsaveerptr arat npt lbrv svm_lock nrip_save tsc_scale vmcb_clean flushbyasid decodeassists pausefilter pfthreshold avic v_vmsave_vmload vgif umip overflow_recov succor smca I build my programm on a vitual machine (with a intel cpu) and run it on a physical machine with a AMD cpu. I use the « -march=znver2 » to generate instructions for the AMD Cpu (AMD EPYC 7402P). I need to have a maximum of performance, so, if I could do some instruction in CPU instead in the software. May be I miss something, a flag ? a library ? , if someone could help me ? I don't have many experiance about CPU instructions/optimisations. Any help will be appreciate. Best regards Nicolas De : Das, Surajit <surajit....@commscope.com> Envoyé : jeudi 4 mars 2021 18:28 À : nicolas.n...@allentis.eu; users@dpdk.org Objet : RE: [dpdk-users] Segmentation fault with -msse3 Hi Nicolas, Looks like the CPU you are running on does not have the instruction ssse3. To check the list of flags available of your cpu, you can run: lscpu | grep Flags You will find that in the list of flags, ssse3 is not available on your cpu. You can compile and run your app with the flag removed without functional issues. Only difference will be that a bunch of instructions that could have been done faster in CPU hardware using ssse3, will now be done in software. Regards, Surajit From: users <users-boun...@dpdk.org <mailto:users-boun...@dpdk.org> > On Behalf Of nicolas.n...@allentis.eu <mailto:nicolas.n...@allentis.eu> Sent: Thursday, March 4, 2021 10:27 PM To: users@dpdk.org <mailto:users@dpdk.org> Subject: [dpdk-users] Segmentation fault with -msse3 Hello dpdk users, I'm a newbie to dpdk and I try to get the list of the rss hash functions for a given port with the following code : static uint64_t get_rss_function(int port_id){ int ret; struct rte_eth_rss_conf rss_conf; ret = rte_eth_dev_rss_hash_conf_get(port_id,&rss_conf); if(ret < 0){ printf("No supported rss\n"); return 0; } return rss_conf.rss_hf; } I use dpdk version 20.11 and my code is compiled with the following flags (I 'm following the tips of the doc) : CXXFLAGS += -mssse3 -mfma -mcx16 -msse4.1 -msse4.2 -mpopcnt -mavx -mavx2 -DALLOW_EXPERIMENTAL_API I have a segmentation fault calling ret = rte_eth_dev_rss_hash_conf_get(port_id,&rss_conf) ; and the coredump tell an issue with __memcpy_ssse3(). If I remove the -mssse3 I don't have the crash. Can you help me to identify the reason of the segmentation fault and tell me if I can easily remove the < -mssse3 > flag ? (Sorry for my english) Regards Nicolas