|
11 | 11 | //
|
12 | 12 | //===----------------------------------------------------------------------===//
|
13 | 13 |
|
14 |
| -let SchedModel = SandyBridgeModel in { |
15 |
| -def SBCycleCounter : PfmCycleCounter<"unhalted_core_cycles">; |
16 |
| -def SBPort0Counter : PfmIssueCounter<SBPort0, ["uops_dispatched_port:port_0"]>; |
17 |
| -def SBPort1Counter : PfmIssueCounter<SBPort1, ["uops_dispatched_port:port_1"]>; |
18 |
| -def SBPort23Counter : PfmIssueCounter<SBPort23, |
19 |
| - ["uops_dispatched_port:port_2", |
20 |
| - "uops_dispatched_port:port_3"]>; |
21 |
| -def SBPort4Counter : PfmIssueCounter<SBPort4, ["uops_dispatched_port:port_4"]>; |
22 |
| -def SBPort5Counter : PfmIssueCounter<SBPort5, ["uops_dispatched_port:port_5"]>; |
23 |
| -def SBUopsCounter : PfmUopsCounter<"uops_issued:any">; |
| 14 | +def UnhaltedCoreCyclesPfmCounter : PfmCounter<"unhalted_core_cycles">; |
| 15 | +def UopsIssuedPfmCounter : PfmCounter<"uops_issued:any">; |
| 16 | + |
| 17 | +def SandyBridgePfmCounters : ProcPfmCounters { |
| 18 | + let CycleCounter = UnhaltedCoreCyclesPfmCounter; |
| 19 | + let UopsCounter = UopsIssuedPfmCounter; |
| 20 | + let IssueCounters = [ |
| 21 | + PfmIssueCounter<"SBPort0", "uops_dispatched_port:port_0">, |
| 22 | + PfmIssueCounter<"SBPort1", "uops_dispatched_port:port_1">, |
| 23 | + PfmIssueCounter<"SBPort23", "uops_dispatched_port:port_2 + uops_dispatched_port:port_3">, |
| 24 | + PfmIssueCounter<"SBPort4", "uops_dispatched_port:port_4">, |
| 25 | + PfmIssueCounter<"SBPort5", "uops_dispatched_port:port_5"> |
| 26 | + ]; |
24 | 27 | }
|
| 28 | +def : PfmCountersBinding<"sandybridge", SandyBridgePfmCounters>; |
25 | 29 |
|
26 |
| -let SchedModel = HaswellModel in { |
27 |
| -def HWCycleCounter : PfmCycleCounter<"unhalted_core_cycles">; |
28 |
| -def HWPort0Counter : PfmIssueCounter<HWPort0, ["uops_dispatched_port:port_0"]>; |
29 |
| -def HWPort1Counter : PfmIssueCounter<HWPort1, ["uops_dispatched_port:port_1"]>; |
30 |
| -def HWPort2Counter : PfmIssueCounter<HWPort2, ["uops_dispatched_port:port_2"]>; |
31 |
| -def HWPort3Counter : PfmIssueCounter<HWPort3, ["uops_dispatched_port:port_3"]>; |
32 |
| -def HWPort4Counter : PfmIssueCounter<HWPort4, ["uops_dispatched_port:port_4"]>; |
33 |
| -def HWPort5Counter : PfmIssueCounter<HWPort5, ["uops_dispatched_port:port_5"]>; |
34 |
| -def HWPort6Counter : PfmIssueCounter<HWPort6, ["uops_dispatched_port:port_6"]>; |
35 |
| -def HWPort7Counter : PfmIssueCounter<HWPort7, ["uops_dispatched_port:port_7"]>; |
36 |
| -def HWUopsCounter : PfmUopsCounter<"uops_issued:any">; |
| 30 | +def HaswellPfmCounters : ProcPfmCounters { |
| 31 | + let CycleCounter = UnhaltedCoreCyclesPfmCounter; |
| 32 | + let UopsCounter = UopsIssuedPfmCounter; |
| 33 | + let IssueCounters = [ |
| 34 | + PfmIssueCounter<"HWPort0", "uops_dispatched_port:port_0">, |
| 35 | + PfmIssueCounter<"HWPort1", "uops_dispatched_port:port_1">, |
| 36 | + PfmIssueCounter<"HWPort2", "uops_dispatched_port:port_2">, |
| 37 | + PfmIssueCounter<"HWPort3", "uops_dispatched_port:port_3">, |
| 38 | + PfmIssueCounter<"HWPort4", "uops_dispatched_port:port_4">, |
| 39 | + PfmIssueCounter<"HWPort5", "uops_dispatched_port:port_5">, |
| 40 | + PfmIssueCounter<"HWPort6", "uops_dispatched_port:port_6">, |
| 41 | + PfmIssueCounter<"HWPort7", "uops_dispatched_port:port_7"> |
| 42 | + ]; |
37 | 43 | }
|
| 44 | +def : PfmCountersBinding<"haswell", HaswellPfmCounters>; |
38 | 45 |
|
39 |
| -let SchedModel = BroadwellModel in { |
40 |
| -def BWCycleCounter : PfmCycleCounter<"unhalted_core_cycles">; |
41 |
| -def BWPort0Counter : PfmIssueCounter<BWPort0, ["uops_executed_port:port_0"]>; |
42 |
| -def BWPort1Counter : PfmIssueCounter<BWPort1, ["uops_executed_port:port_1"]>; |
43 |
| -def BWPort2Counter : PfmIssueCounter<BWPort2, ["uops_executed_port:port_2"]>; |
44 |
| -def BWPort3Counter : PfmIssueCounter<BWPort3, ["uops_executed_port:port_3"]>; |
45 |
| -def BWPort4Counter : PfmIssueCounter<BWPort4, ["uops_executed_port:port_4"]>; |
46 |
| -def BWPort5Counter : PfmIssueCounter<BWPort5, ["uops_executed_port:port_5"]>; |
47 |
| -def BWPort6Counter : PfmIssueCounter<BWPort6, ["uops_executed_port:port_6"]>; |
48 |
| -def BWPort7Counter : PfmIssueCounter<BWPort7, ["uops_executed_port:port_7"]>; |
49 |
| -def BWUopsCounter : PfmUopsCounter<"uops_issued:any">; |
| 46 | +def BroadwellPfmCounters : ProcPfmCounters { |
| 47 | + let CycleCounter = UnhaltedCoreCyclesPfmCounter; |
| 48 | + let UopsCounter = UopsIssuedPfmCounter; |
| 49 | + let IssueCounters = [ |
| 50 | + PfmIssueCounter<"BWPort0", "uops_executed_port:port_0">, |
| 51 | + PfmIssueCounter<"BWPort1", "uops_executed_port:port_1">, |
| 52 | + PfmIssueCounter<"BWPort2", "uops_executed_port:port_2">, |
| 53 | + PfmIssueCounter<"BWPort3", "uops_executed_port:port_3">, |
| 54 | + PfmIssueCounter<"BWPort4", "uops_executed_port:port_4">, |
| 55 | + PfmIssueCounter<"BWPort5", "uops_executed_port:port_5">, |
| 56 | + PfmIssueCounter<"BWPort6", "uops_executed_port:port_6">, |
| 57 | + PfmIssueCounter<"BWPort7", "uops_executed_port:port_7"> |
| 58 | + ]; |
50 | 59 | }
|
| 60 | +def : PfmCountersBinding<"broadwell", BroadwellPfmCounters>; |
51 | 61 |
|
52 |
| -let SchedModel = SkylakeClientModel in { |
53 |
| -def SKLCycleCounter : PfmCycleCounter<"unhalted_core_cycles">; |
54 |
| -def SKLPort0Counter : PfmIssueCounter<SKLPort0, ["uops_dispatched_port:port_0"]>; |
55 |
| -def SKLPort1Counter : PfmIssueCounter<SKLPort1, ["uops_dispatched_port:port_1"]>; |
56 |
| -def SKLPort2Counter : PfmIssueCounter<SKLPort2, ["uops_dispatched_port:port_2"]>; |
57 |
| -def SKLPort3Counter : PfmIssueCounter<SKLPort3, ["uops_dispatched_port:port_3"]>; |
58 |
| -def SKLPort4Counter : PfmIssueCounter<SKLPort4, ["uops_dispatched_port:port_4"]>; |
59 |
| -def SKLPort5Counter : PfmIssueCounter<SKLPort5, ["uops_dispatched_port:port_5"]>; |
60 |
| -def SKLPort6Counter : PfmIssueCounter<SKLPort6, ["uops_dispatched_port:port_6"]>; |
61 |
| -def SKLPort7Counter : PfmIssueCounter<SKLPort7, ["uops_dispatched_port:port_7"]>; |
62 |
| -def SKLUopsCounter : PfmUopsCounter<"uops_issued:any">; |
| 62 | +def SkylakeClientPfmCounters : ProcPfmCounters { |
| 63 | + let CycleCounter = UnhaltedCoreCyclesPfmCounter; |
| 64 | + let UopsCounter = UopsIssuedPfmCounter; |
| 65 | + let IssueCounters = [ |
| 66 | + PfmIssueCounter<"SKLPort0", "uops_dispatched_port:port_0">, |
| 67 | + PfmIssueCounter<"SKLPort1", "uops_dispatched_port:port_1">, |
| 68 | + PfmIssueCounter<"SKLPort2", "uops_dispatched_port:port_2">, |
| 69 | + PfmIssueCounter<"SKLPort3", "uops_dispatched_port:port_3">, |
| 70 | + PfmIssueCounter<"SKLPort4", "uops_dispatched_port:port_4">, |
| 71 | + PfmIssueCounter<"SKLPort5", "uops_dispatched_port:port_5">, |
| 72 | + PfmIssueCounter<"SKLPort6", "uops_dispatched_port:port_6">, |
| 73 | + PfmIssueCounter<"SKLPort7", "uops_dispatched_port:port_7"> |
| 74 | + ]; |
63 | 75 | }
|
| 76 | +def : PfmCountersBinding<"skylake", SkylakeClientPfmCounters>; |
64 | 77 |
|
65 |
| -let SchedModel = SkylakeServerModel in { |
66 |
| -def SKXCycleCounter : PfmCycleCounter<"unhalted_core_cycles">; |
67 |
| -def SKXPort0Counter : PfmIssueCounter<SKXPort0, ["uops_dispatched_port:port_0"]>; |
68 |
| -def SKXPort1Counter : PfmIssueCounter<SKXPort1, ["uops_dispatched_port:port_1"]>; |
69 |
| -def SKXPort2Counter : PfmIssueCounter<SKXPort2, ["uops_dispatched_port:port_2"]>; |
70 |
| -def SKXPort3Counter : PfmIssueCounter<SKXPort3, ["uops_dispatched_port:port_3"]>; |
71 |
| -def SKXPort4Counter : PfmIssueCounter<SKXPort4, ["uops_dispatched_port:port_4"]>; |
72 |
| -def SKXPort5Counter : PfmIssueCounter<SKXPort5, ["uops_dispatched_port:port_5"]>; |
73 |
| -def SKXPort6Counter : PfmIssueCounter<SKXPort6, ["uops_dispatched_port:port_6"]>; |
74 |
| -def SKXPort7Counter : PfmIssueCounter<SKXPort7, ["uops_dispatched_port:port_7"]>; |
75 |
| -def SKXUopsCounter : PfmUopsCounter<"uops_issued:any">; |
| 78 | +def SkylakeServerPfmCounters : ProcPfmCounters { |
| 79 | + let CycleCounter = UnhaltedCoreCyclesPfmCounter; |
| 80 | + let UopsCounter = UopsIssuedPfmCounter; |
| 81 | + let IssueCounters = [ |
| 82 | + PfmIssueCounter<"SKXPort0", "uops_dispatched_port:port_0">, |
| 83 | + PfmIssueCounter<"SKXPort1", "uops_dispatched_port:port_1">, |
| 84 | + PfmIssueCounter<"SKXPort2", "uops_dispatched_port:port_2">, |
| 85 | + PfmIssueCounter<"SKXPort3", "uops_dispatched_port:port_3">, |
| 86 | + PfmIssueCounter<"SKXPort4", "uops_dispatched_port:port_4">, |
| 87 | + PfmIssueCounter<"SKXPort5", "uops_dispatched_port:port_5">, |
| 88 | + PfmIssueCounter<"SKXPort6", "uops_dispatched_port:port_6">, |
| 89 | + PfmIssueCounter<"SKXPort7", "uops_dispatched_port:port_7"> |
| 90 | + ]; |
76 | 91 | }
|
| 92 | +def : PfmCountersBinding<"skylake-avx512", SkylakeServerPfmCounters>; |
77 | 93 |
|
78 |
| -let SchedModel = BtVer2Model in { |
79 |
| -def JCycleCounter : PfmCycleCounter<"cpu_clk_unhalted">; |
80 |
| -def JUopsCounter : PfmUopsCounter<"retired_uops">; |
81 |
| -def JFPU0Counter : PfmIssueCounter<JFPU0, ["dispatched_fpu:pipe0"]>; |
82 |
| -def JFPU1Counter : PfmIssueCounter<JFPU1, ["dispatched_fpu:pipe1"]>; |
| 94 | +def BtVer2PfmCounters : ProcPfmCounters { |
| 95 | + let CycleCounter = PfmCounter<"cpu_clk_unhalted">; |
| 96 | + let UopsCounter = PfmCounter<"retired_uops">; |
| 97 | + let IssueCounters = [ |
| 98 | + PfmIssueCounter<"JFPU0", "dispatched_fpu:pipe0">, |
| 99 | + PfmIssueCounter<"JFPU1", "dispatched_fpu:pipe1"> |
| 100 | + ]; |
83 | 101 | }
|
| 102 | +def : PfmCountersBinding<"btver2", BtVer2PfmCounters>; |
0 commit comments