Function: sortAtomsById | Module: exec | Source: haloExchange.c:653-661 | Coverage: 0.08% |
---|
Function: sortAtomsById | Module: exec | Source: haloExchange.c:653-661 | Coverage: 0.08% |
---|
/home/hbollore/qaas-runs/170-265-5545/intel/CoMD/build/CoMD/CoMD/src-openmp/haloExchange.c: 653 - 661 |
-------------------------------------------------------------------------------- |
653: { |
654: int aId = ((AtomMsg*) a)->gid; |
655: int bId = ((AtomMsg*) b)->gid; |
656: assert(aId != bId); |
657: |
658: if (aId < bId) |
659: return -1; |
660: return 1; |
661: } |
0x406920 STP X29, X30, [SP, #1008]! |
0x406924 ADD X29, SP, #0 |
0x406928 LDR W8, [X0] |
0x40692c LDR W9, [X1] |
0x406930 CMP W8, W9 |
0x406934 B.EQ 406948 |
0x406938 MOVN W8, #0 |
0x40693c CSNEG W0, W8, W8, #11 |
0x406940 LDP X29, X30, [SP], #16 |
0x406944 RET |
0x406948 ADRP X0, |
0x40694c ADD X0, X0, #3081 |
0x406950 ADRP X1, |
0x406954 ADD X1, X1, #2632 |
0x406958 ADRP X3, |
0x40695c ADD X3, X3, #3092 |
0x406960 MOVZ W2, #656 |
0x406964 BL 4023a0 |
0x406968 HINT #0 |
0x40696c HINT #0 |
0x406970 HINT #0 |
0x406974 HINT #0 |
0x406978 HINT #0 |
0x40697c HINT #0 |
Coverage (%) | Name | Source Location | Module |
---|---|---|---|
►13.33+ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►8.33+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►8.33+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►7.78+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►7.78+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►6.11+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►5.00+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►5.00+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►5.00+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►4.44+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►4.44+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►3.89+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►3.33+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►2.78+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►2.78+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►2.22+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►1.67+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so | |
►1.11+ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | bsearch | libc-2.31.so | |
○ | qsort_r | libc-2.31.so | |
○ | sortAtomsInCell | haloExchange.c:632 | exec |
○ | .omp_outlined..6#0x40b790 | timestep.c:153 | exec |
○ | __kmp_invoke_microtask | libomp.so |
Path / |
Source file and lines | haloExchange.c:653-661 |
Module | exec |
nb instructions | 22 |
loop length | 88 |
nb stack references | 0 |
front end | 2.00 cycles |
P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | P12 | P13 | P14 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
uops | 1.25 | 1.25 | 3.00 | 3.00 | 3.00 | 3.00 | 0.00 | 0.00 | 0.00 | 0.00 | 1.33 | 1.00 | 1.17 | 0.50 | 0.50 |
cycles | 1.25 | 1.25 | 3.00 | 3.00 | 3.00 | 3.00 | 0.00 | 0.00 | 0.00 | 0.00 | 1.33 | 1.00 | 1.17 | 0.50 | 0.50 |
Cycles executing div or sqrt instructions | NA |
Front-end | 2.00 |
Overall L1 | 3.00 |
all | 0% |
load | NA (no load vectorizable/vectorized instructions) |
store | NA (no store vectorizable/vectorized instructions) |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | NA (no div/sqrt vectorizable/vectorized instructions) |
other | 0% |
Source file and lines | haloExchange.c:653-661 |
Module | exec |
nb instructions | 24 |
loop length | 96 |
nb stack references | 0 |
front end | 2.25 cycles |
P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | P12 | P13 | P14 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
uops | 1.50 | 1.50 | 3.25 | 3.25 | 3.25 | 3.25 | 0.00 | 0.00 | 0.00 | 0.00 | 1.50 | 1.17 | 1.33 | 0.50 | 0.50 |
cycles | 1.50 | 1.50 | 3.25 | 3.25 | 3.25 | 3.25 | 0.00 | 0.00 | 0.00 | 0.00 | 1.50 | 1.17 | 1.33 | 0.50 | 0.50 |
Cycles executing div or sqrt instructions | NA |
Front-end | 2.25 |
Overall L1 | 3.25 |
all | 0% |
load | NA (no load vectorizable/vectorized instructions) |
store | NA (no store vectorizable/vectorized instructions) |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | NA (no div/sqrt vectorizable/vectorized instructions) |
other | 0% |
Instruction | Nb FU | P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | P12 | P13 | P14 | Latency | Recip. throughput |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
STP X29, X30, [SP, #1008]! | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0.50 | 0.50 | 0 | 0.50 | 0.50 | 1 | 0.50 |
ADD X29, SP, #0 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
LDR W8, [X0] | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 0.33 | 0.33 | 0 | 0 | 4 | 0.33 |
LDR W9, [X1] | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 0.33 | 0.33 | 0 | 0 | 4 | 0.33 |
CMP W8, W9 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.33 |
B.EQ 406948 <sortAtomsById+0x28> | 1 | 0.50 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.50 |
MOVN W8, #0 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
CSNEG W0, W8, W8, #11 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
LDP X29, X30, [SP], #16 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 0.33 | 0.33 | 0 | 0 | 4 | 1 |
RET | 1 | 0.50 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.50 |
ADRP X0, <40c948> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X0, X0, #3081 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADRP X1, <40c950> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X1, X1, #2632 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADRP X3, <40c958> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X3, X3, #3092 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
MOVZ W2, #656 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
BL 4023a0 <@plt_start@+0x190> | 1 | 0.50 | 0.50 | 0.50 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.50 |
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 |
Source file and lines | haloExchange.c:653-661 |
Module | exec |
nb instructions | 20 |
loop length | 80 |
nb stack references | 0 |
front end | 1.75 cycles |
P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | P12 | P13 | P14 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
uops | 1.00 | 1.00 | 2.75 | 2.75 | 2.75 | 2.75 | 0.00 | 0.00 | 0.00 | 0.00 | 1.17 | 0.83 | 1.00 | 0.50 | 0.50 |
cycles | 1.00 | 1.00 | 2.75 | 2.75 | 2.75 | 2.75 | 0.00 | 0.00 | 0.00 | 0.00 | 1.17 | 0.83 | 1.00 | 0.50 | 0.50 |
Cycles executing div or sqrt instructions | NA |
Front-end | 1.75 |
Overall L1 | 2.75 |
all | 0% |
load | NA (no load vectorizable/vectorized instructions) |
store | NA (no store vectorizable/vectorized instructions) |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | NA (no div/sqrt vectorizable/vectorized instructions) |
other | 0% |
Instruction | Nb FU | P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | P12 | P13 | P14 | Latency | Recip. throughput |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
STP X29, X30, [SP, #1008]! | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0.50 | 0.50 | 0 | 0.50 | 0.50 | 1 | 0.50 |
ADD X29, SP, #0 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
LDR W8, [X0] | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 0.33 | 0.33 | 0 | 0 | 4 | 0.33 |
LDR W9, [X1] | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 0.33 | 0.33 | 0 | 0 | 4 | 0.33 |
CMP W8, W9 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.33 |
B.EQ 406948 <sortAtomsById+0x28> | 1 | 0.50 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.50 |
ADRP X0, <40c948> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X0, X0, #3081 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADRP X1, <40c950> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X1, X1, #2632 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADRP X3, <40c958> | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
ADD X3, X3, #3092 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
MOVZ W2, #656 | 1 | 0 | 0 | 0.25 | 0.25 | 0.25 | 0.25 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.25 |
BL 4023a0 <@plt_start@+0x190> | 1 | 0.50 | 0.50 | 0.50 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.50 |
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 | ||||||||||||||||||
HINT #0 |
Name | Coverage (%) | Time (s) |
---|---|---|
○sortAtomsById | 0.08 | 0.01 |