[dpdk-users] Segmentation fault with -msse3
nicolas.neel at allentis.eu
nicolas.neel at allentis.eu
Fri Mar 5 12:25:34 CET 2021
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.Das at commscope.com>
Envoyé : jeudi 4 mars 2021 18:28
À : nicolas.neel at allentis.eu; users at 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-bounces at dpdk.org <mailto:users-bounces at dpdk.org> > On
Behalf Of nicolas.neel at allentis.eu <mailto:nicolas.neel at allentis.eu>
Sent: Thursday, March 4, 2021 10:27 PM
To: users at dpdk.org <mailto:users at 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
More information about the users
mailing list