Loop Id: 762 | Module: exec | Source: par_multi_interp.c:1585-1660 [...] | Coverage: 0.03% |
---|
Loop Id: 762 | Module: exec | Source: par_multi_interp.c:1585-1660 [...] | Coverage: 0.03% |
---|
0x443a03 INC %RDX |
0x443a06 CMP -0x50(%RBP),%RDX |
0x443a0a JGE 443fed |
0x443a10 MOV -0xc8(%RBP),%RAX |
0x443a17 MOV %RDX,-0x40(%RBP) |
0x443a1b MOV (%RAX,%RDX,8),%RDI |
0x443a1f MOV -0xd0(%RBP),%RAX |
0x443a26 MOV (%RAX,%RDI,8),%R8 |
0x443a2a MOV -0x70(%RBP),%RAX |
0x443a2e MOV (%RAX,%RDI,8),%RCX |
0x443a32 MOV 0x8(%RAX,%RDI,8),%RAX |
0x443a37 LEA (%RAX,%R8,1),%R9 |
0x443a3b SUB %RCX,%R9 |
0x443a3e CMP %R9,%R8 |
0x443a41 JGE 443b15 |
0x443a47 MOV -0xb8(%RBP),%RDX |
0x443a4e MOV 0x8(%RDX),%R9 |
0x443a52 SUB %RCX,%RAX |
0x443a55 CMP $0x8,%RAX |
0x443a59 JB 443ae0 |
0x443a5f MOV %RAX,%R10 |
0x443a62 SHR $0x3,%R10 |
0x443a66 LEA (%R9,%R8,8),%R11 |
0x443a6a ADD $0x38,%R11 |
0x443a6e XCHG %AX,%AX |
(770) 0x443a70 MOV -0x38(%R11),%RCX |
(770) 0x443a74 MOV (%R15,%RCX,8),%RCX |
(770) 0x443a78 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443a7d MOV -0x30(%R11),%RCX |
(770) 0x443a81 MOV (%R15,%RCX,8),%RCX |
(770) 0x443a85 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443a8a MOV -0x28(%R11),%RCX |
(770) 0x443a8e MOV (%R15,%RCX,8),%RCX |
(770) 0x443a92 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443a97 MOV -0x20(%R11),%RCX |
(770) 0x443a9b MOV (%R15,%RCX,8),%RCX |
(770) 0x443a9f MOV %RDI,(%R13,%RCX,8) |
(770) 0x443aa4 MOV -0x18(%R11),%RCX |
(770) 0x443aa8 MOV (%R15,%RCX,8),%RCX |
(770) 0x443aac MOV %RDI,(%R13,%RCX,8) |
(770) 0x443ab1 MOV -0x10(%R11),%RCX |
(770) 0x443ab5 MOV (%R15,%RCX,8),%RCX |
(770) 0x443ab9 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443abe MOV -0x8(%R11),%RCX |
(770) 0x443ac2 MOV (%R15,%RCX,8),%RCX |
(770) 0x443ac6 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443acb MOV (%R11),%RCX |
(770) 0x443ace MOV (%R15,%RCX,8),%RCX |
(770) 0x443ad2 MOV %RDI,(%R13,%RCX,8) |
(770) 0x443ad7 ADD $0x40,%R11 |
(770) 0x443adb DEC %R10 |
(770) 0x443ade JNE 443a70 |
0x443ae0 MOV %RAX,%RCX |
0x443ae3 AND $-0x8,%RCX |
0x443ae7 CMP %RAX,%RCX |
0x443aea MOV -0x58(%RBP),%R11 |
0x443aee MOV -0x48(%RBP),%R10 |
0x443af2 JAE 443b15 |
0x443af4 LEA (%R9,%R8,8),%R8 |
0x443af8 NOPL (%RAX,%RAX,1) |
(769) 0x443b00 MOV (%R8,%RCX,8),%RSI |
(769) 0x443b04 MOV (%R15,%RSI,8),%RSI |
(769) 0x443b08 MOV %RDI,(%R13,%RSI,8) |
(769) 0x443b0d INC %RCX |
(769) 0x443b10 CMP %RCX,%RAX |
(769) 0x443b13 JNE 443b00 |
0x443b15 MOV -0x70(%RBP),%RAX |
0x443b19 MOV (%RAX,%RDI,8),%R8 |
0x443b1d MOV -0x80(%RBP),%RCX |
0x443b21 MOV (%RCX,%RDI,8),%RAX |
0x443b25 MOV 0x8(%RCX,%RDI,8),%R9 |
0x443b2a INC %RAX |
0x443b2d VXORPD %XMM4,%XMM4,%XMM4 |
0x443b31 VXORPD %XMM3,%XMM3,%XMM3 |
0x443b35 JMP 443b43 |
(768) 0x443b40 INC %RAX |
(768) 0x443b43 CMP %R9,%RAX |
(768) 0x443b46 JGE 443bc0 |
(768) 0x443b48 MOV (%R10,%RAX,8),%RCX |
(768) 0x443b4c CMPQ $-0x3,(%R11,%RCX,8) |
(768) 0x443b51 JE 443b78 |
(768) 0x443b53 CMPQ $0x1,-0xa8(%RBP) |
(768) 0x443b5b JE 443b72 |
(768) 0x443b5d MOV -0x98(%RBP),%RSI |
(768) 0x443b64 MOV (%RSI,%RDI,8),%R10 |
(768) 0x443b68 CMP (%RSI,%RCX,8),%R10 |
(768) 0x443b6c MOV -0x48(%RBP),%R10 |
(768) 0x443b70 JNE 443b78 |
(768) 0x443b72 VADDSD (%R12,%RAX,8),%XMM3,%XMM3 |
(768) 0x443b78 CMP $-0x1,%RCX |
(768) 0x443b7c JE 443b40 |
(768) 0x443b7e CMP %RDI,(%R13,%RCX,8) |
(768) 0x443b83 JNE 443b40 |
(768) 0x443b85 VMOVSD (%R12,%RAX,8),%XMM5 |
(768) 0x443b8b MOV -0x30(%RBP),%RDX |
(768) 0x443b8f VMOVSD %XMM5,(%RDX,%R8,8) |
(768) 0x443b95 MOV -0x100(%RBP),%RSI |
(768) 0x443b9c MOV (%RSI,%RCX,8),%RCX |
(768) 0x443ba0 MOV -0xe8(%RBP),%RDX |
(768) 0x443ba7 MOV %RCX,(%RDX,%R8,8) |
(768) 0x443bab INC %R8 |
(768) 0x443bae VADDSD (%R12,%RAX,8),%XMM4,%XMM4 |
(768) 0x443bb4 MOV -0x80(%RBP),%RCX |
(768) 0x443bb8 MOV 0x8(%RCX,%RDI,8),%R9 |
(768) 0x443bbd JMP 443b40 |
0x443bc0 MOV -0xd8(%RBP),%RAX |
0x443bc7 MOV (%RAX,%RDI,8),%R9 |
0x443bcb MOV -0x78(%RBP),%RAX |
0x443bcf MOV (%RAX,%RDI,8),%RCX |
0x443bd3 MOV 0x8(%RAX,%RDI,8),%RAX |
0x443bd8 LEA (%RAX,%R9,1),%R10 |
0x443bdc SUB %RCX,%R10 |
0x443bdf CMP %R10,%R9 |
0x443be2 JGE 443ca4 |
0x443be8 MOV -0xc0(%RBP),%RDX |
0x443bef MOV 0x8(%RDX),%R10 |
0x443bf3 SUB %RCX,%RAX |
0x443bf6 CMP $0x8,%RAX |
0x443bfa JB 443c78 |
0x443c00 MOV %RAX,%R11 |
0x443c03 SHR $0x3,%R11 |
0x443c07 LEA (%R10,%R9,8),%RCX |
0x443c0b ADD $0x38,%RCX |
0x443c0f NOP |
(767) 0x443c10 MOV -0x38(%RCX),%RSI |
(767) 0x443c14 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c18 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c1c MOV -0x30(%RCX),%RSI |
(767) 0x443c20 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c24 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c28 MOV -0x28(%RCX),%RSI |
(767) 0x443c2c MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c30 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c34 MOV -0x20(%RCX),%RSI |
(767) 0x443c38 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c3c MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c40 MOV -0x18(%RCX),%RSI |
(767) 0x443c44 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c48 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c4c MOV -0x10(%RCX),%RSI |
(767) 0x443c50 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c54 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c58 MOV -0x8(%RCX),%RSI |
(767) 0x443c5c MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c60 MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c64 MOV (%RCX),%RSI |
(767) 0x443c67 MOV (%RBX,%RSI,8),%RSI |
(767) 0x443c6b MOV %RDI,(%R14,%RSI,8) |
(767) 0x443c6f ADD $0x40,%RCX |
(767) 0x443c73 DEC %R11 |
(767) 0x443c76 JNE 443c10 |
0x443c78 MOV %RAX,%RCX |
0x443c7b AND $-0x8,%RCX |
0x443c7f CMP %RAX,%RCX |
0x443c82 JAE 443ca4 |
0x443c84 LEA (%R10,%R9,8),%R9 |
0x443c88 NOPL (%RAX,%RAX,1) |
(766) 0x443c90 MOV (%R9,%RCX,8),%RSI |
(766) 0x443c94 MOV (%RBX,%RSI,8),%RSI |
(766) 0x443c98 MOV %RDI,(%R14,%RSI,8) |
(766) 0x443c9c INC %RCX |
(766) 0x443c9f CMP %RCX,%RAX |
(766) 0x443ca2 JNE 443c90 |
0x443ca4 MOV -0x78(%RBP),%RAX |
0x443ca8 MOV (%RAX,%RDI,8),%R9 |
0x443cac MOV -0x90(%RBP),%RAX |
0x443cb3 MOV (%RAX,%RDI,8),%R10 |
0x443cb7 MOV 0x8(%RAX,%RDI,8),%RAX |
0x443cbc CMP %RAX,%R10 |
0x443cbf JGE 443da0 |
0x443cc5 MOV -0xb0(%RBP),%RCX |
0x443ccc LEA (%RCX,%R10,8),%R11 |
0x443cd0 MOV -0x88(%RBP),%RSI |
0x443cd7 JMP 443cf0 |
(765) 0x443ce0 INC %R10 |
(765) 0x443ce3 ADD $0x8,%R11 |
(765) 0x443ce7 CMP %RAX,%R10 |
(765) 0x443cea JGE 443da0 |
(765) 0x443cf0 MOV %R11,%RCX |
(765) 0x443cf3 TEST %RSI,%RSI |
(765) 0x443cf6 JE 443d06 |
(765) 0x443cf8 MOV (%R11),%RCX |
(765) 0x443cfb MOV -0x108(%RBP),%RDX |
(765) 0x443d02 LEA (%RDX,%RCX,8),%RCX |
(765) 0x443d06 MOV (%RCX),%RCX |
(765) 0x443d09 MOV -0x110(%RBP),%RDX |
(765) 0x443d10 CMPQ $-0x3,(%RDX,%RCX,8) |
(765) 0x443d15 JE 443d4d |
(765) 0x443d17 CMPQ $0x1,-0xa8(%RBP) |
(765) 0x443d1f JE 443d40 |
(765) 0x443d21 MOV -0x98(%RBP),%RSI |
(765) 0x443d28 MOV (%RSI,%RDI,8),%RSI |
(765) 0x443d2c MOV -0xe0(%RBP),%RDX |
(765) 0x443d33 CMP (%RDX,%RCX,8),%RSI |
(765) 0x443d37 MOV -0x88(%RBP),%RSI |
(765) 0x443d3e JNE 443d4d |
(765) 0x443d40 MOV -0xa0(%RBP),%RDX |
(765) 0x443d47 VADDSD (%RDX,%R10,8),%XMM3,%XMM3 |
(765) 0x443d4d CMP $-0x1,%RCX |
(765) 0x443d51 JE 443ce0 |
(765) 0x443d53 CMP %RDI,(%R14,%RCX,8) |
(765) 0x443d57 JNE 443ce0 |
(765) 0x443d59 MOV -0xa0(%RBP),%RDX |
(765) 0x443d60 VMOVSD (%RDX,%R10,8),%XMM5 |
(765) 0x443d66 MOV -0x38(%RBP),%RAX |
(765) 0x443d6a VMOVSD %XMM5,(%RAX,%R9,8) |
(765) 0x443d70 MOV -0xf8(%RBP),%RAX |
(765) 0x443d77 MOV (%RAX,%RCX,8),%RAX |
(765) 0x443d7b MOV -0xf0(%RBP),%RCX |
(765) 0x443d82 MOV %RAX,(%RCX,%R9,8) |
(765) 0x443d86 INC %R9 |
(765) 0x443d89 VADDSD (%RDX,%R10,8),%XMM4,%XMM4 |
(765) 0x443d8f MOV -0x90(%RBP),%RAX |
(765) 0x443d96 MOV 0x8(%RAX,%RDI,8),%RAX |
(765) 0x443d9b JMP 443ce0 |
0x443da0 MOV -0x80(%RBP),%RAX |
0x443da4 MOV (%RAX,%RDI,8),%RAX |
0x443da8 VMULSD (%R12,%RAX,8),%XMM4,%XMM4 |
0x443dae VUCOMISD %XMM0,%XMM4 |
0x443db2 JE 443dbc |
0x443db4 VXORPD %XMM1,%XMM3,%XMM2 |
0x443db8 VDIVSD %XMM4,%XMM2,%XMM2 |
0x443dbc MOV -0x70(%RBP),%RAX |
0x443dc0 MOV (%RAX,%RDI,8),%R10 |
0x443dc4 SUB %R10,%R8 |
0x443dc7 MOV -0x58(%RBP),%R11 |
0x443dcb MOV -0x40(%RBP),%RDX |
0x443dcf JLE 443f05 |
0x443dd5 CMP $0x8,%R8 |
0x443dd9 JB 443e47 |
0x443ddb MOV %R8,%RAX |
0x443dde SHR $0x3,%RAX |
0x443de2 MOV -0x68(%RBP),%RCX |
0x443de6 LEA (%RCX,%R10,8),%RCX |
0x443dea NOPW (%RAX,%RAX,1) |
(764) 0x443df0 VMULSD -0x38(%RCX),%XMM2,%XMM3 |
(764) 0x443df5 VMOVSD %XMM3,-0x38(%RCX) |
(764) 0x443dfa VMULSD -0x30(%RCX),%XMM2,%XMM3 |
(764) 0x443dff VMOVSD %XMM3,-0x30(%RCX) |
(764) 0x443e04 VMULSD -0x28(%RCX),%XMM2,%XMM3 |
(764) 0x443e09 VMOVSD %XMM3,-0x28(%RCX) |
(764) 0x443e0e VMULSD -0x20(%RCX),%XMM2,%XMM3 |
(764) 0x443e13 VMOVSD %XMM3,-0x20(%RCX) |
(764) 0x443e18 VMULSD -0x18(%RCX),%XMM2,%XMM3 |
(764) 0x443e1d VMOVSD %XMM3,-0x18(%RCX) |
(764) 0x443e22 VMULSD -0x10(%RCX),%XMM2,%XMM3 |
(764) 0x443e27 VMOVSD %XMM3,-0x10(%RCX) |
(764) 0x443e2c VMULSD -0x8(%RCX),%XMM2,%XMM3 |
(764) 0x443e31 VMOVSD %XMM3,-0x8(%RCX) |
(764) 0x443e36 VMULSD (%RCX),%XMM2,%XMM3 |
(764) 0x443e3a VMOVSD %XMM3,(%RCX) |
(764) 0x443e3e ADD $0x40,%RCX |
(764) 0x443e42 DEC %RAX |
(764) 0x443e45 JNE 443df0 |
0x443e47 MOV %R8D,%EAX |
0x443e4a AND $0x7,%EAX |
0x443e4d DEC %RAX |
0x443e50 CMP $0x6,%RAX |
0x443e54 JA 443f05 |
0x443f05 MOV -0x78(%RBP),%RAX |
0x443f09 MOV (%RAX,%RDI,8),%RDI |
0x443f0d SUB %RDI,%R9 |
0x443f10 MOV -0x48(%RBP),%R10 |
0x443f14 JLE 443a03 |
0x443f1a CMP $0x8,%R9 |
0x443f1e JB 443f87 |
0x443f20 MOV %R9,%RAX |
0x443f23 SHR $0x3,%RAX |
0x443f27 MOV -0x60(%RBP),%RCX |
0x443f2b LEA (%RCX,%RDI,8),%RCX |
0x443f2f NOP |
(763) 0x443f30 VMULSD -0x38(%RCX),%XMM2,%XMM3 |
(763) 0x443f35 VMOVSD %XMM3,-0x38(%RCX) |
(763) 0x443f3a VMULSD -0x30(%RCX),%XMM2,%XMM3 |
(763) 0x443f3f VMOVSD %XMM3,-0x30(%RCX) |
(763) 0x443f44 VMULSD -0x28(%RCX),%XMM2,%XMM3 |
(763) 0x443f49 VMOVSD %XMM3,-0x28(%RCX) |
(763) 0x443f4e VMULSD -0x20(%RCX),%XMM2,%XMM3 |
(763) 0x443f53 VMOVSD %XMM3,-0x20(%RCX) |
(763) 0x443f58 VMULSD -0x18(%RCX),%XMM2,%XMM3 |
(763) 0x443f5d VMOVSD %XMM3,-0x18(%RCX) |
(763) 0x443f62 VMULSD -0x10(%RCX),%XMM2,%XMM3 |
(763) 0x443f67 VMOVSD %XMM3,-0x10(%RCX) |
(763) 0x443f6c VMULSD -0x8(%RCX),%XMM2,%XMM3 |
(763) 0x443f71 VMOVSD %XMM3,-0x8(%RCX) |
(763) 0x443f76 VMULSD (%RCX),%XMM2,%XMM3 |
(763) 0x443f7a VMOVSD %XMM3,(%RCX) |
(763) 0x443f7e ADD $0x40,%RCX |
(763) 0x443f82 DEC %RAX |
(763) 0x443f85 JNE 443f30 |
0x443f87 MOV %R9D,%EAX |
0x443f8a AND $0x7,%EAX |
0x443f8d DEC %RAX |
0x443f90 CMP $0x6,%RAX |
0x443f94 JA 443a03 |
/scratch_na/users/xoserete/qaas_runs/171-172-8218/intel/AMG/build/AMG/AMG/parcsr_ls/par_multi_interp.c: 1585 - 1660 |
-------------------------------------------------------------------------------- |
1585: if (n_fine) |
[...] |
1605: for (i=thread_start; i < thread_stop; i++) |
1606: { |
1607: i1 = pass_array[i]; |
1608: sum_C = 0; |
1609: sum_N = 0; |
1610: j_start = P_diag_start[i1]; |
1611: j_end = j_start+P_diag_i[i1+1]-P_diag_i[i1]; |
1612: for (j=j_start; j < j_end; j++) |
1613: { |
1614: k1 = P_diag_pass[1][j]; |
1615: tmp_marker[C_array[k1]] = i1; |
1616: } |
1617: cnt = P_diag_i[i1]; |
1618: for (j=A_diag_i[i1]+1; j < A_diag_i[i1+1]; j++) |
1619: { |
1620: j1 = A_diag_j[j]; |
1621: if (CF_marker[j1] != -3 && |
1622: (num_functions == 1 || dof_func[i1] == dof_func[j1])) |
1623: sum_N += A_diag_data[j]; |
1624: if (j1 != -1 && tmp_marker[j1] == i1) |
1625: { |
1626: P_diag_data[cnt] = A_diag_data[j]; |
1627: P_diag_j[cnt++] = fine_to_coarse[j1]; |
1628: sum_C += A_diag_data[j]; |
1629: } |
1630: } |
1631: j_start = P_offd_start[i1]; |
1632: j_end = j_start+P_offd_i[i1+1]-P_offd_i[i1]; |
1633: for (j=j_start; j < j_end; j++) |
1634: { |
1635: k1 = P_offd_pass[1][j]; |
1636: tmp_marker_offd[C_array_offd[k1]] = i1; |
1637: } |
1638: cnt_offd = P_offd_i[i1]; |
1639: for (j=A_offd_i[i1]; j < A_offd_i[i1+1]; j++) |
1640: { |
1641: if (col_offd_S_to_A) |
1642: j1 = map_A_to_S[A_offd_j[j]]; |
1643: else |
1644: j1 = A_offd_j[j]; |
1645: if (CF_marker_offd[j1] != -3 && |
1646: (num_functions == 1 || dof_func[i1] == dof_func_offd[j1])) |
1647: sum_N += A_offd_data[j]; |
1648: if (j1 != -1 && tmp_marker_offd[j1] == i1) |
1649: { |
1650: P_offd_data[cnt_offd] = A_offd_data[j]; |
1651: P_offd_j[cnt_offd++] = map_S_to_new[j1]; |
1652: sum_C += A_offd_data[j]; |
1653: } |
1654: } |
1655: diagonal = A_diag_data[A_diag_i[i1]]; |
1656: if (sum_C*diagonal) alfa = -sum_N/(sum_C*diagonal); |
1657: for (j=P_diag_i[i1]; j < cnt; j++) |
1658: P_diag_data[j] *= alfa; |
1659: for (j=P_offd_i[i1]; j < cnt_offd; j++) |
1660: P_offd_data[j] *= alfa; |
Path / |
Metric | Value |
---|---|
CQA speedup if no scalar integer | 2.11 |
CQA speedup if FP arith vectorized | 3.85 |
CQA speedup if fully vectorized | 8.00 |
CQA speedup if no inter-iteration dependency | NA |
CQA speedup if next bottleneck killed | 1.40 |
Bottlenecks | micro-operation queue, |
Function | hypre_BoomerAMGBuildMultipass.extracted.27 |
Source | par_multi_interp.c:1585-1585,par_multi_interp.c:1605-1607,par_multi_interp.c:1610-1614,par_multi_interp.c:1617-1618,par_multi_interp.c:1631-1635,par_multi_interp.c:1638-1639,par_multi_interp.c:1655-1659 |
Source loop unroll info | NA |
Source loop unroll confidence level | NA |
Unroll/vectorization loop type | NA |
Unroll factor | NA |
CQA cycles | 20.00 |
CQA cycles if no scalar integer | 9.50 |
CQA cycles if FP arith vectorized | 5.20 |
CQA cycles if fully vectorized | 2.50 |
Front-end cycles | 20.00 |
DIV/SQRT cycles | 10.50 |
P0 cycles | 7.80 |
P1 cycles | 14.33 |
P2 cycles | 14.33 |
P3 cycles | 0.50 |
P4 cycles | 7.60 |
P5 cycles | 10.50 |
P6 cycles | 0.50 |
P7 cycles | 0.50 |
P8 cycles | 0.50 |
P9 cycles | 7.60 |
P10 cycles | 14.33 |
P11 cycles | 4.00 |
Inter-iter dependencies cycles | NA |
FE+BE cycles (UFS) | 20.37 - 20.39 |
Stall cycles (UFS) | 0.00 |
Nb insns | 120.00 |
Nb uops | 119.00 |
Nb loads | 43.00 |
Nb stores | 1.00 |
Nb stack references | 17.00 |
FLOP/cycle | 0.10 |
Nb FLOP add-sub | 0.00 |
Nb FLOP mul | 1.00 |
Nb FLOP fma | 0.00 |
Nb FLOP div | 1.00 |
Nb FLOP rcp | 0.00 |
Nb FLOP sqrt | 0.00 |
Nb FLOP rsqrt | 0.00 |
Bytes/cycle | 17.60 |
Bytes prefetched | 0.00 |
Bytes loaded | 344.00 |
Bytes stored | 8.00 |
Stride 0 | NA |
Stride 1 | NA |
Stride n | NA |
Stride unknown | NA |
Stride indirect | NA |
Vectorization ratio all | 12.50 |
Vectorization ratio load | 0.00 |
Vectorization ratio store | 0.00 |
Vectorization ratio mul | 0.00 |
Vectorization ratio add_sub | 0.00 |
Vectorization ratio fma | NA |
Vectorization ratio div_sqrt | 0.00 |
Vectorization ratio other | 17.65 |
Vector-efficiency ratio all | 14.06 |
Vector-efficiency ratio load | 12.50 |
Vector-efficiency ratio store | 12.50 |
Vector-efficiency ratio mul | 12.50 |
Vector-efficiency ratio add_sub | 12.50 |
Vector-efficiency ratio fma | NA |
Vector-efficiency ratio div_sqrt | 12.50 |
Vector-efficiency ratio other | 14.71 |
Metric | Value |
---|---|
CQA speedup if no scalar integer | 2.11 |
CQA speedup if FP arith vectorized | 3.85 |
CQA speedup if fully vectorized | 8.00 |
CQA speedup if no inter-iteration dependency | NA |
CQA speedup if next bottleneck killed | 1.40 |
Bottlenecks | micro-operation queue, |
Function | hypre_BoomerAMGBuildMultipass.extracted.27 |
Source | par_multi_interp.c:1585-1585,par_multi_interp.c:1605-1607,par_multi_interp.c:1610-1614,par_multi_interp.c:1617-1618,par_multi_interp.c:1631-1635,par_multi_interp.c:1638-1639,par_multi_interp.c:1655-1659 |
Source loop unroll info | NA |
Source loop unroll confidence level | NA |
Unroll/vectorization loop type | NA |
Unroll factor | NA |
CQA cycles | 20.00 |
CQA cycles if no scalar integer | 9.50 |
CQA cycles if FP arith vectorized | 5.20 |
CQA cycles if fully vectorized | 2.50 |
Front-end cycles | 20.00 |
DIV/SQRT cycles | 10.50 |
P0 cycles | 7.80 |
P1 cycles | 14.33 |
P2 cycles | 14.33 |
P3 cycles | 0.50 |
P4 cycles | 7.60 |
P5 cycles | 10.50 |
P6 cycles | 0.50 |
P7 cycles | 0.50 |
P8 cycles | 0.50 |
P9 cycles | 7.60 |
P10 cycles | 14.33 |
P11 cycles | 4.00 |
Inter-iter dependencies cycles | NA |
FE+BE cycles (UFS) | 20.37 - 20.39 |
Stall cycles (UFS) | 0.00 |
Nb insns | 120.00 |
Nb uops | 119.00 |
Nb loads | 43.00 |
Nb stores | 1.00 |
Nb stack references | 17.00 |
FLOP/cycle | 0.10 |
Nb FLOP add-sub | 0.00 |
Nb FLOP mul | 1.00 |
Nb FLOP fma | 0.00 |
Nb FLOP div | 1.00 |
Nb FLOP rcp | 0.00 |
Nb FLOP sqrt | 0.00 |
Nb FLOP rsqrt | 0.00 |
Bytes/cycle | 17.60 |
Bytes prefetched | 0.00 |
Bytes loaded | 344.00 |
Bytes stored | 8.00 |
Stride 0 | NA |
Stride 1 | NA |
Stride n | NA |
Stride unknown | NA |
Stride indirect | NA |
Vectorization ratio all | 12.50 |
Vectorization ratio load | 0.00 |
Vectorization ratio store | 0.00 |
Vectorization ratio mul | 0.00 |
Vectorization ratio add_sub | 0.00 |
Vectorization ratio fma | NA |
Vectorization ratio div_sqrt | 0.00 |
Vectorization ratio other | 17.65 |
Vector-efficiency ratio all | 14.06 |
Vector-efficiency ratio load | 12.50 |
Vector-efficiency ratio store | 12.50 |
Vector-efficiency ratio mul | 12.50 |
Vector-efficiency ratio add_sub | 12.50 |
Vector-efficiency ratio fma | NA |
Vector-efficiency ratio div_sqrt | 12.50 |
Vector-efficiency ratio other | 14.71 |
Path / |
Function | hypre_BoomerAMGBuildMultipass.extracted.27 |
Source file and lines | par_multi_interp.c:1585-1660 |
Module | exec |
nb instructions | 120 |
nb uops | 119 |
loop length | 493 |
used x86 registers | 11 |
used mmx registers | 0 |
used xmm registers | 5 |
used ymm registers | 0 |
used zmm registers | 0 |
nb stack references | 17 |
micro-operation queue | 20.00 cycles |
front end | 20.00 cycles |
P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|
uops | 10.50 | 7.80 | 14.33 | 14.33 | 0.50 | 7.60 | 10.50 | 0.50 | 0.50 | 0.50 | 7.60 | 14.33 |
cycles | 10.50 | 7.80 | 14.33 | 14.33 | 0.50 | 7.60 | 10.50 | 0.50 | 0.50 | 0.50 | 7.60 | 14.33 |
Cycles executing div or sqrt instructions | 4.00 |
FE+BE cycles | 20.37-20.39 |
Stall cycles | 0.00 |
Front-end | 20.00 |
Dispatch | 14.33 |
DIV/SQRT | 4.00 |
Overall L1 | 20.00 |
all | 0% |
load | 0% |
store | 0% |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
other | 0% |
all | 50% |
load | 0% |
store | NA (no store vectorizable/vectorized instructions) |
mul | 0% |
add-sub | NA (no add-sub vectorizable/vectorized instructions) |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 0% |
other | 75% |
all | 12% |
load | 0% |
store | 0% |
mul | 0% |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 0% |
other | 17% |
all | 12% |
load | 12% |
store | 12% |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 12% |
fma | NA (no fma vectorizable/vectorized instructions) |
other | 12% |
all | 18% |
load | 12% |
store | NA (no store vectorizable/vectorized instructions) |
mul | 12% |
add-sub | NA (no add-sub vectorizable/vectorized instructions) |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 12% |
other | 21% |
all | 14% |
load | 12% |
store | 12% |
mul | 12% |
add-sub | 12% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 12% |
other | 14% |
Instruction | Nb FU | P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | Latency | Recip. throughput |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
INC %RDX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP -0x50(%RBP),%RDX | 1 | 0.20 | 0.20 | 0.33 | 0.33 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.33 | 1 | 0.33 |
JGE 443fed <hypre_BoomerAMGBuildMultipass.extracted.27+0x8ad> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xc8(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV %RDX,-0x40(%RBP) | 1 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0.50 | 0.50 | 0.50 | 0 | 0 | 1 | 0.50 |
MOV (%RAX,%RDX,8),%RDI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0xd0(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R8 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RAX,%R8,1),%R9 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
SUB %RCX,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP %R9,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443b15 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3d5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xb8(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RDX),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RCX,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP $0x8,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443ae0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3a0> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %RAX,%R10 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%R10 | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
LEA (%R9,%R8,8),%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
ADD $0x38,%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
XCHG %AX,%AX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %RAX,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $-0x8,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
CMP %RAX,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x58(%RBP),%R11 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x48(%RBP),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JAE 443b15 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3d5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
LEA (%R9,%R8,8),%R8 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPL (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R8 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x80(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RCX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RCX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
INC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
VXORPD %XMM4,%XMM4,%XMM4 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
VXORPD %XMM3,%XMM3,%XMM3 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
JMP 443b43 <hypre_BoomerAMGBuildMultipass.extracted.27+0x403> | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 5.84 |
MOV -0xd8(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RAX,%R9,1),%R10 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
SUB %RCX,%R10 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP %R10,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443ca4 <hypre_BoomerAMGBuildMultipass.extracted.27+0x564> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xc0(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RDX),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RCX,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP $0x8,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443c78 <hypre_BoomerAMGBuildMultipass.extracted.27+0x538> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %RAX,%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%R11 | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
LEA (%R10,%R9,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
ADD $0x38,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
NOP | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %RAX,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $-0x8,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
CMP %RAX,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JAE 443ca4 <hypre_BoomerAMGBuildMultipass.extracted.27+0x564> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
LEA (%R10,%R9,8),%R9 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPL (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x90(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
CMP %RAX,%R10 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443da0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x660> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xb0(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%R10,8),%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x88(%RBP),%RSI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JMP 443cf0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x5b0> | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 5.84 |
MOV -0x80(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
VMULSD (%R12,%RAX,8),%XMM4,%XMM4 | 1 | 0.50 | 0.50 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 4 | 0.50 |
VUCOMISD %XMM0,%XMM4 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 3 | 1 |
JE 443dbc <hypre_BoomerAMGBuildMultipass.extracted.27+0x67c> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
VXORPD %XMM1,%XMM3,%XMM2 | 1 | 0.33 | 0.33 | 0 | 0 | 0 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0-1 | 0.33 |
VDIVSD %XMM4,%XMM2,%XMM2 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 13-15 | 4 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %R10,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x58(%RBP),%R11 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x40(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JLE 443f05 <hypre_BoomerAMGBuildMultipass.extracted.27+0x7c5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
CMP $0x8,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443e47 <hypre_BoomerAMGBuildMultipass.extracted.27+0x707> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %R8,%RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%RAX | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
MOV -0x68(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%R10,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPW (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %R8D,%EAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $0x7,%EAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
DEC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP $0x6,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JA 443f05 <hypre_BoomerAMGBuildMultipass.extracted.27+0x7c5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RDI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RDI,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x48(%RBP),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JLE 443a03 <hypre_BoomerAMGBuildMultipass.extracted.27+0x2c3> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
CMP $0x8,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443f87 <hypre_BoomerAMGBuildMultipass.extracted.27+0x847> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %R9,%RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%RAX | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
MOV -0x60(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%RDI,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOP | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %R9D,%EAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $0x7,%EAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
DEC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP $0x6,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JA 443a03 <hypre_BoomerAMGBuildMultipass.extracted.27+0x2c3> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
Function | hypre_BoomerAMGBuildMultipass.extracted.27 |
Source file and lines | par_multi_interp.c:1585-1660 |
Module | exec |
nb instructions | 120 |
nb uops | 119 |
loop length | 493 |
used x86 registers | 11 |
used mmx registers | 0 |
used xmm registers | 5 |
used ymm registers | 0 |
used zmm registers | 0 |
nb stack references | 17 |
micro-operation queue | 20.00 cycles |
front end | 20.00 cycles |
P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|
uops | 10.50 | 7.80 | 14.33 | 14.33 | 0.50 | 7.60 | 10.50 | 0.50 | 0.50 | 0.50 | 7.60 | 14.33 |
cycles | 10.50 | 7.80 | 14.33 | 14.33 | 0.50 | 7.60 | 10.50 | 0.50 | 0.50 | 0.50 | 7.60 | 14.33 |
Cycles executing div or sqrt instructions | 4.00 |
FE+BE cycles | 20.37-20.39 |
Stall cycles | 0.00 |
Front-end | 20.00 |
Dispatch | 14.33 |
DIV/SQRT | 4.00 |
Overall L1 | 20.00 |
all | 0% |
load | 0% |
store | 0% |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
other | 0% |
all | 50% |
load | 0% |
store | NA (no store vectorizable/vectorized instructions) |
mul | 0% |
add-sub | NA (no add-sub vectorizable/vectorized instructions) |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 0% |
other | 75% |
all | 12% |
load | 0% |
store | 0% |
mul | 0% |
add-sub | 0% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 0% |
other | 17% |
all | 12% |
load | 12% |
store | 12% |
mul | NA (no mul vectorizable/vectorized instructions) |
add-sub | 12% |
fma | NA (no fma vectorizable/vectorized instructions) |
other | 12% |
all | 18% |
load | 12% |
store | NA (no store vectorizable/vectorized instructions) |
mul | 12% |
add-sub | NA (no add-sub vectorizable/vectorized instructions) |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 12% |
other | 21% |
all | 14% |
load | 12% |
store | 12% |
mul | 12% |
add-sub | 12% |
fma | NA (no fma vectorizable/vectorized instructions) |
div/sqrt | 12% |
other | 14% |
Instruction | Nb FU | P0 | P1 | P2 | P3 | P4 | P5 | P6 | P7 | P8 | P9 | P10 | P11 | Latency | Recip. throughput |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
INC %RDX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP -0x50(%RBP),%RDX | 1 | 0.20 | 0.20 | 0.33 | 0.33 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.33 | 1 | 0.33 |
JGE 443fed <hypre_BoomerAMGBuildMultipass.extracted.27+0x8ad> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xc8(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV %RDX,-0x40(%RBP) | 1 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0.50 | 0.50 | 0.50 | 0 | 0 | 1 | 0.50 |
MOV (%RAX,%RDX,8),%RDI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0xd0(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R8 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RAX,%R8,1),%R9 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
SUB %RCX,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP %R9,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443b15 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3d5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xb8(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RDX),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RCX,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP $0x8,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443ae0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3a0> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %RAX,%R10 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%R10 | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
LEA (%R9,%R8,8),%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
ADD $0x38,%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
XCHG %AX,%AX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %RAX,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $-0x8,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
CMP %RAX,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x58(%RBP),%R11 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x48(%RBP),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JAE 443b15 <hypre_BoomerAMGBuildMultipass.extracted.27+0x3d5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
LEA (%R9,%R8,8),%R8 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPL (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R8 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x80(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RCX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RCX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
INC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
VXORPD %XMM4,%XMM4,%XMM4 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
VXORPD %XMM3,%XMM3,%XMM3 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
JMP 443b43 <hypre_BoomerAMGBuildMultipass.extracted.27+0x403> | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 5.84 |
MOV -0xd8(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RAX,%R9,1),%R10 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
SUB %RCX,%R10 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP %R10,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443ca4 <hypre_BoomerAMGBuildMultipass.extracted.27+0x564> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xc0(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RDX),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RCX,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
CMP $0x8,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443c78 <hypre_BoomerAMGBuildMultipass.extracted.27+0x538> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %RAX,%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%R11 | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
LEA (%R10,%R9,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
ADD $0x38,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
NOP | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %RAX,%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $-0x8,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
CMP %RAX,%RCX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JAE 443ca4 <hypre_BoomerAMGBuildMultipass.extracted.27+0x564> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
LEA (%R10,%R9,8),%R9 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPL (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R9 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x90(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV 0x8(%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
CMP %RAX,%R10 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JGE 443da0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x660> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0xb0(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%R10,8),%R11 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV -0x88(%RBP),%RSI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JMP 443cf0 <hypre_BoomerAMGBuildMultipass.extracted.27+0x5b0> | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 5.84 |
MOV -0x80(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
VMULSD (%R12,%RAX,8),%XMM4,%XMM4 | 1 | 0.50 | 0.50 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 4 | 0.50 |
VUCOMISD %XMM0,%XMM4 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 3 | 1 |
JE 443dbc <hypre_BoomerAMGBuildMultipass.extracted.27+0x67c> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
VXORPD %XMM1,%XMM3,%XMM2 | 1 | 0.33 | 0.33 | 0 | 0 | 0 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0-1 | 0.33 |
VDIVSD %XMM4,%XMM2,%XMM2 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 13-15 | 4 |
MOV -0x70(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %R10,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x58(%RBP),%R11 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV -0x40(%RBP),%RDX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JLE 443f05 <hypre_BoomerAMGBuildMultipass.extracted.27+0x7c5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
CMP $0x8,%R8 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443e47 <hypre_BoomerAMGBuildMultipass.extracted.27+0x707> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %R8,%RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%RAX | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
MOV -0x68(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%R10,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOPW (%RAX,%RAX,1) | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %R8D,%EAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $0x7,%EAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
DEC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP $0x6,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JA 443f05 <hypre_BoomerAMGBuildMultipass.extracted.27+0x7c5> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV -0x78(%RBP),%RAX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
MOV (%RAX,%RDI,8),%RDI | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
SUB %RDI,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
MOV -0x48(%RBP),%R10 | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
JLE 443a03 <hypre_BoomerAMGBuildMultipass.extracted.27+0x2c3> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
CMP $0x8,%R9 | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JB 443f87 <hypre_BoomerAMGBuildMultipass.extracted.27+0x847> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |
MOV %R9,%RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
SHR $0x3,%RAX | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0-2 | 0.50 |
MOV -0x60(%RBP),%RCX | 1 | 0 | 0 | 0.33 | 0.33 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.33 | 1 | 0.33 |
LEA (%RCX,%RDI,8),%RCX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
NOP | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0.17 |
MOV %R9D,%EAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
AND $0x7,%EAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1-2 | 0.20 |
DEC %RAX | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0.17 |
CMP $0x6,%RAX | 1 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0.20 | 0 | 0 | 0 | 0.20 | 0 | 1 | 0.20 |
JA 443a03 <hypre_BoomerAMGBuildMultipass.extracted.27+0x2c3> | 1 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0.50 | 0 | 0 | 0 | 0 | 0 | 0 | 0.50 |