Apple Microarchitecture Research by Dougall Johnson

M1/A14 P-core (Firestorm): Overview | Base Instructions | SIMD and FP Instructions
M1/A14 E-core (Icestorm):  Overview | Base Instructions | SIMD and FP Instructions

FMLSL2 (by element, 2S)

Test 1: uops

Code:

  fmlsl2 v0.2s, v1.2h, v2.h[1]
  movi v0.16b, 1
  movi v1.16b, 2
  movi v2.16b, 3

(no loop instructions)

1000 unrolls and 1 iteration

Retires: 1.000

Issues: 1.000

Integer unit issues: 0.001

Load/store unit issues: 0.000

SIMD/FP unit issues: 1.000

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch simd uop (57)ldst uops in schedulers (5b)dispatch uop (78)map simd uop (7e)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10054066100511004103010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000
10044033100111000100010155710001000300011000

Test 2: Latency 1->1

Code:

  fmlsl2 v0.2s, v1.2h, v2.h[1]
  movi v0.16b, 1
  movi v1.16b, 2
  movi v2.16b, 3

(fused SUBS/B.cc loop)

100 unrolls and 100 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100

1000 unrolls and 10 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010

Test 3: Latency 1->2

Code:

  fmlsl2 v0.2s, v0.2h, v1.h[1]
  movi v0.16b, 1
  movi v1.16b, 2

(fused SUBS/B.cc loop)

100 unrolls and 100 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
10204400331010110110000100100003001028557101002001000620030018110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028904101302001004420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100
10204400331010110110000100100003001028557101002001000420030012110000100

1000 unrolls and 10 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)schedule ldst uop (55)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030129111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010
1002440033100212110000020100007010285571002020100002030000111000010

Test 4: Latency 1->3

Code:

  fmlsl2 v0.2s, v1.2h, v0.h[1]
  movi v0.16b, 1
  movi v1.16b, 2

(fused SUBS/B.cc loop)

100 unrolls and 100 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)schedule ldst uop (55)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
102044003310101101100000100100003001028557101002001000620030018110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100
102044003310101101100000100100003001028557101002001000420030012110000100

1000 unrolls and 10 iterations

Result (median cycles for code): 4.0033

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100006510285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010
100244003310021211000020100007010285571002020100002030000111000010

Test 5: throughput

Count: 8

Code:

  movi v0.16b, 0
  fmlsl2 v0.2s, v8.2h, v9.h[1]
  movi v1.16b, 0
  fmlsl2 v1.2s, v8.2h, v9.h[1]
  movi v2.16b, 0
  fmlsl2 v2.2s, v8.2h, v9.h[1]
  movi v3.16b, 0
  fmlsl2 v3.2s, v8.2h, v9.h[1]
  movi v4.16b, 0
  fmlsl2 v4.2s, v8.2h, v9.h[1]
  movi v5.16b, 0
  fmlsl2 v5.2s, v8.2h, v9.h[1]
  movi v6.16b, 0
  fmlsl2 v6.2s, v8.2h, v9.h[1]
  movi v7.16b, 0
  fmlsl2 v7.2s, v8.2h, v9.h[1]
  movi v8.16b, 9
  movi v9.16b, 10

(fused SUBS/B.cc loop)

100 unrolls and 100 iterations

Result (median cycles for code divided by count): 0.5011

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)schedule ldst uop (55)dispatch int uop (56)dispatch simd uop (57)dispatch ldst uop (58)int uops in schedulers (59)simd uops in schedulers (5a)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map ldst uop (7d)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
16020440534801091018000801008001203000320056801132000800132002400391160000100
16020440469801101018000901008001303000320056801132000800132002400391160000100
162194446768214613808004472213408004803000320052801122000800122002400361160000100
16020540188801451018004401008004803000320052801122000800122002400361160000100
2161021762071300732685782940202762728582959513107274411320222814151210597800522002400361160000100
16020440151801101018000901008001303000320056801132000800132002400391160000100
16020440098801101018000901008001303000320052801122000800122002400361160000100
16020440086801091018000801008001203000320052801122000800122002400361160000100
16020440086801091018000801008001203000320052801122000800122002400361160000100
16020440086801091018000801008001203000320052801122000800122002400361160000100

1000 unrolls and 10 iterations

Result (median cycles for code divided by count): 0.5056

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)schedule ldst uop (55)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
16002443843800201180009010800133032005680023208001320240000116000010
16002441377800111180000010800003032000080010208000020240000116000010
16002440470800111180000010800003032000080010208000020240000116000010
16002440416800111180000010800003032000080010208000020240000116000010
16002440408800111180000010800003032000080010208000020240000116000010
16002540538800551180044010800483032000080010208000020240000116000010
16002440427800111180000010800003032000080010208000020240000116000010
16002440403800111180000010800003032000080010208000020240000116000010
16002440422800111180000010800003032000080010208000020240000116000010
16002440414800111180000010800003032000080010208000020240000116000010

Test 6: throughput

Count: 12

Code:

  fmlsl2 v0.2s, v12.2h, v13.h[1]
  fmlsl2 v1.2s, v12.2h, v13.h[1]
  fmlsl2 v2.2s, v12.2h, v13.h[1]
  fmlsl2 v3.2s, v12.2h, v13.h[1]
  fmlsl2 v4.2s, v12.2h, v13.h[1]
  fmlsl2 v5.2s, v12.2h, v13.h[1]
  fmlsl2 v6.2s, v12.2h, v13.h[1]
  fmlsl2 v7.2s, v12.2h, v13.h[1]
  fmlsl2 v8.2s, v12.2h, v13.h[1]
  fmlsl2 v9.2s, v12.2h, v13.h[1]
  fmlsl2 v10.2s, v12.2h, v13.h[1]
  fmlsl2 v11.2s, v12.2h, v13.h[1]
  movi v12.16b, 13
  movi v13.16b, 14

(fused SUBS/B.cc loop)

100 unrolls and 100 iterations

Result (median cycles for code divided by count): 0.5003

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)dispatch ldst uop (58)int uops in schedulers (59)simd uops in schedulers (5a)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map ldst uop (7d)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
120204600671201051011200041001200080300048004412011020001200142023609752120000100
1202046003612010710112000610012001027614282022833480478126397508032831200872003600391120000100
1202046003612010510112000410012000846092513591383942459837095181895616608132003600421120000100
120204600361201051011200041001200080300048003612010820001200122003600361120000100
120204600361201051011200041001200080300048065212026220001201662003600361120000100
120204600361201051011200041001200080300048003612010820001200122003602011120000100
120204600361201051011200041001200080300048003612010820001200122003600361120000100
120204600361201071011200061001200100300048003612010820001200122003600361120000100
120204600361201051011200041001200080300048003612010820001200122003600361120000100
120204600361201051011200041001200080300048003612010820001200122003600361120000100

1000 unrolls and 10 iterations

Result (median cycles for code divided by count): 0.5003

retire uop (01)cycle (02)schedule uop (52)schedule int uop (53)schedule simd uop (54)dispatch int uop (56)dispatch simd uop (57)int uops in schedulers (59)ldst uops in schedulers (5b)dispatch uop (78)map int uop (7c)map simd uop (7e)map int uop inputs (7f)map simd uop inputs (81)? int output thing (e9)? simd retires (ee)? int retires (ef)
120024601471200151112000410120008304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360000112000010
120024600361200111112000010120000304800001200102012000020360192112000010
120024600361200111112000010120000304800001200102012000020360000112000010