-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcase-study.tex
106 lines (98 loc) · 4.62 KB
/
case-study.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
\subsection{Interesting Basic Blocks}
We look at three basic blocks, where some of the evaluated models behave poorly.
These results are from Haswell.
Table~\ref{tab:case-study} shows these basic blocks, their
measured throughput, and the throughput predicted by different models.
We manually inspected the instruction schedules predicted by the models
(except for Ithemal, which just predicts a single throughput number).
The first two examples highlight cases of some models' prediction
contradicting instruction throughput specified by the manual.
The last example shows a case where a model (llvm-mca~\cite{llvm-mca} in this case) can significantly
mispredict throughput due to mis-scheduling micro-ops, despite correct modeling of individual instructions.
\textbf{Modeling bug due to unsigned division}.
We look at the first example in Table~\ref{tab:case-study},
which is bottlenecked by a 64-bit by 32-bit unsigned division.
Intel's manual~\cite{intel-manual} states that the throughput of such division
ranges from 20 to 26 cycles, which is consistent with our measurement (21.62).
All models are wrong here; llvm-mca and IACA~\cite{iaca} significantly over-predict;
Ithemal~\cite{ithemal} and OSACA~\cite{osaca} under-predict.
llvm-mca and IACA's predictions indicate that they are confusing
this division (\verb|div %ecx|) with the 128-bit by 64-bit analog (\verb|div %rcx|),
which the manual does specify to have variable latency between 80 and 95 cycles.
We note that the predictions made by llvm-mca and IACA would still be wrong
were we to replace the \verb|div %ecx| with \verb|div %rcx| in this context,
due to the fast-path for zeroed out \verb|%rdx|
(which is always the case here because of the preceding \verb|xor %edx, %edx|).
\textbf{Modeling bug due to zero-idioms}.
We look at the second example in Table~\ref{tab:case-study}.
The basic block consists of a single vectorized XOR of \verb|%xmm2| with itself.
All three micro-architectures we evaluated have fast-paths for such zero-idioms.
IACA and Ithemal recognize this idiom and make predictions close to the measured throughput,
while llvm-mca and OSACA treat this instruction as a regular vectorized XOR.
\textbf{Modeling bug due to mis-scheduling}
For the third examples in Table~\ref{tab:case-study},
we focus on the schedule predicted by llvm-mca~\cite{llvm-mca}
and explain why it overpredicts.
Figure~\ref{fig:schedule} shows the schedules predicted by llvm-mca and IACA.
Notice that instruction \verb|xorq (%rcx), %rax| is dispatched
noticeably earlier in IACA's schedule.
llvm-mca delays the dispatch of this \verb|xorb| due to its dependence on the previous \verb|xorq|.
llvm-mca is unable to recognize that
\verb|xorq (%rcx), %rax| is implemented with a load micro-op followed by an ALU micro-op.
Since the load is independent, the hardware is able to schedule it ahead of time,
hiding its latency completely.
\begin{figure}[htbp!]
\includegraphics[width=0.95\columnwidth]{figures/scheduling.pdf}
\caption{Schedules predicted by llvm-mca and IACA for an example basic block.
Each red window marks the boundary of a single iteration of execution.
The width of the windows represents the steady-state throughput.
As illustrated here, llvm-mca and IACA predicts two different schedules.
Notice that the bolded instruction is dispatched earlier in IACA's schedule.
}
\label{tab:case-study}
\end{figure}
\begin{figure}[htbp!]
\begin{center}
\includegraphics[width=0.7\columnwidth]{figures/interesting-examples.pdf}
\caption{Interesting basic blocks and their inverse throughput as observed from measurements and reported by IACA, llvm-mca and OSACA (- indicates that the tool crashes while processing the basic block).}
\label{tab:case-study}
\label{fig:schedule}
\end{center}
\end{figure}
\begin{comment}
\begin{table*}[t]
\centering
\begin{tabular}{|l|c|c|c|c|c|}
\hline
Basic Block & Measured & IACA & llvm-mca & Ithemal & OSACA \\
\hline
\begin{lstlisting}
xor edx, edx
div ecx
test edx, edx
\end{lstlisting}
& 21.62 & 98.00 & 99.04 & 14.49 & 12.25 \\
\hline
\begin{lstlisting}
vxorps xmm2, xmm2, xmm2
\end{lstlisting}
& 0.25 & 0.24 & 1.00 & 0.328 & 1.00 \\
\hline
\begin{lstlisting}
add rdi, 1
mov eax, edx
shr rdx, 8
xor al, [rdi - 1]
movzx eax, al
xor rdx, [8*rax + 0x4110a]
cmp rdi, rcx
\end{lstlisting}
& 8.25 & 8.00 & 13.04 & 2.13 & - \\
\hline
\end{tabular}
\\
~\\
\caption{Interesting basic blocks and their inverse throughputs as observed from measurements and reported by IACA, llvm-mca and OSACA (- indicates that the tool could not time the particular basic block).}
\label{tab:case-study}
\end{table*}
\end{comment}