2024-11-19 00:12:26 +01:00
|
|
|
\section{Foundations}
|
2024-11-20 12:54:09 +01:00
|
|
|
|
|
|
|
\begin{frame}{Bird's eye view of a CPU}
|
|
|
|
\centering
|
|
|
|
\includegraphics[height=0.94\textheight]{cpu_big_picture.svg}
|
|
|
|
\end{frame}
|
|
|
|
|
|
|
|
\begin{frame}{Possible bottlenecks}
|
|
|
|
\begin{columns}
|
2024-11-20 23:08:08 +01:00
|
|
|
\begin{column}{0.37\textwidth}
|
2024-11-20 12:54:09 +01:00
|
|
|
\begin{center}
|
|
|
|
\includegraphics[width=\textwidth]{cpu_big_picture_truncate.svg}
|
|
|
|
\end{center}
|
|
|
|
\end{column}
|
|
|
|
\hfill
|
2024-11-20 23:08:08 +01:00
|
|
|
\begin{column}{0.62\textwidth}
|
2024-11-20 12:54:09 +01:00
|
|
|
\begin{tightitemize}{0pt}
|
|
|
|
\begin{itemize}
|
2024-12-01 21:20:44 +01:00
|
|
|
\item \alert{Frontend:} \uops{} not issued fast enough
|
2024-11-20 12:54:09 +01:00
|
|
|
\bigskip
|
|
|
|
|
2024-12-01 21:20:44 +01:00
|
|
|
\item \alert{Backend:} saturated execution units
|
2024-11-20 12:54:09 +01:00
|
|
|
\bigskip
|
|
|
|
|
|
|
|
\item \alert{Dependencies:} computation is stalled waiting
|
2024-12-01 21:20:44 +01:00
|
|
|
for previous results
|
2024-11-20 12:54:09 +01:00
|
|
|
\end{itemize}
|
|
|
|
\end{tightitemize}
|
|
|
|
\end{column}
|
|
|
|
\end{columns}
|
|
|
|
\end{frame}
|
|
|
|
|
2024-12-01 21:20:44 +01:00
|
|
|
%\begin{frame}{Dependencies and the ROB}
|
|
|
|
% \begin{columns}
|
|
|
|
% \begin{column}{0.35\textwidth}
|
|
|
|
% \begin{center}
|
|
|
|
% \includegraphics[width=\textwidth]{cpu_frontend.svg}
|
|
|
|
% \end{center}
|
|
|
|
% \end{column}
|
|
|
|
% \hfill
|
|
|
|
% \begin{column}{0.64\textwidth}
|
|
|
|
% \begin{tightitemize}{0pt}
|
|
|
|
% \begin{itemize}
|
|
|
|
% \item Dependencies can stall execution
|
|
|
|
% \item Maybe instructions further down can be executed right now?
|
|
|
|
% \end{itemize}
|
|
|
|
% \begin{center}
|
|
|
|
% \textbf{\alert{$\to$ Out-of-Order CPUs}}
|
|
|
|
% \end{center}
|
|
|
|
% \begin{itemize}
|
|
|
|
% \item ROB: circular buffer of \uops{}
|
|
|
|
% \item First possible instruction is issued
|
|
|
|
% \end{itemize}
|
|
|
|
% \end{tightitemize}
|
|
|
|
% \end{column}
|
|
|
|
% \end{columns}
|
|
|
|
%\end{frame}
|
2024-11-20 12:54:09 +01:00
|
|
|
|
2024-12-01 21:20:44 +01:00
|
|
|
%\begin{frame}{How do we get insights from this complex system?}
|
|
|
|
% \textbf{Hardware counters}
|
|
|
|
% \begin{itemize}
|
|
|
|
% \item Built-in hardware, counters gathered at runtime
|
|
|
|
% \item Very accurate
|
|
|
|
% \item Available data varies from model to model
|
|
|
|
% \item May not even be available at all
|
|
|
|
% \end{itemize}
|
|
|
|
%
|
|
|
|
% \textbf{Simulation?}
|
|
|
|
% \begin{itemize}
|
|
|
|
% \item A modern CPU is \alert{$\sim$\,100e9 transistors}: very complex
|
|
|
|
% models!
|
|
|
|
% \item Very expensive, even for manufacturers for design validation
|
|
|
|
% \item CPU design is industrial secret $\leadsto$ not available anyway
|
|
|
|
% \item \ldots{}\ie{} not feasible.
|
|
|
|
% \end{itemize}
|
|
|
|
%\end{frame}
|
2024-11-20 12:54:09 +01:00
|
|
|
|
2024-12-05 18:34:30 +01:00
|
|
|
\begin{frame}[fragile]{What do we analyze?}
|
|
|
|
\begin{columns}
|
|
|
|
\column{\dimexpr\paperwidth-20pt}
|
|
|
|
\begin{minipage}[c]{0.60\textwidth}
|
2024-11-20 12:54:09 +01:00
|
|
|
Pieces of code referred as \alert{``microkernels''}:
|
|
|
|
|
|
|
|
\begin{itemize}
|
|
|
|
\item body of an (assumed) infinite loop;
|
|
|
|
\item in steady-state;
|
|
|
|
\item straight-line code (branches assumed not taken);
|
|
|
|
\item L1-resident (memory model is out of scope).
|
|
|
|
\end{itemize}
|
2024-12-05 18:34:30 +01:00
|
|
|
\end{minipage}
|
|
|
|
\hfill\begin{minipage}[c]{0.35\textwidth}
|
|
|
|
\begin{lstlisting}[language={[x86masm]Assembler}, numbers=none]
|
|
|
|
loop:
|
|
|
|
movsd (%rcx, %rax), %xmm0
|
|
|
|
mulsd %xmm1, %xmm0
|
|
|
|
addsd (%rdx, %rax), %xmm0
|
|
|
|
movsd %xmm0, (%rdx, %rax)
|
|
|
|
addq $8, %rax
|
|
|
|
cmpq $0x2260, %rax
|
|
|
|
jne loop\end{lstlisting}
|
|
|
|
\end{minipage}
|
|
|
|
\vspace{2em}
|
|
|
|
\begin{center}
|
2024-11-20 12:54:09 +01:00
|
|
|
Reasonable hypotheses for the category of codes worth optimizing this way!
|
2024-12-05 18:34:30 +01:00
|
|
|
\end{center}
|
|
|
|
\end{columns}
|
2024-11-20 12:54:09 +01:00
|
|
|
\end{frame}
|
|
|
|
|
2024-12-05 12:06:59 +01:00
|
|
|
\begin{frame}{Code analyzers}
|
|
|
|
\begin{itemize}
|
|
|
|
\item Predict performance of a microkernel
|
|
|
|
\item Features microarchitectural models
|
|
|
|
\item Most often static analyzers
|
|
|
|
\item Predict at least the \alert{\emph{reverse-throughput}} of a kernel (cycles per iteration)
|
|
|
|
\item May derive further useful metrics, \eg{} bottlenecks, by
|
|
|
|
inspecting their model at will
|
|
|
|
\end{itemize}
|
|
|
|
\end{frame}
|
|
|
|
|
2024-11-20 12:54:09 +01:00
|
|
|
\begin{frame}{Existing code analyzers}
|
2024-12-05 18:34:30 +01:00
|
|
|
\begin{minipage}[t]{0.55\textwidth}
|
|
|
|
\begin{block}{Behavioural}
|
|
|
|
\medskip
|
|
|
|
\begin{itemize}
|
|
|
|
\item \alert{\iaca{}}: Intel, proprietary. Intel CPUs only.
|
|
|
|
\item \alert{\llvmmca{}}: \texttt{llvm} project, FOSS.
|
|
|
|
\item \alert{\uica{}}, \alert{\uopsinfo{}}: academia. Intel CPUs
|
|
|
|
only.
|
|
|
|
\end{itemize}
|
|
|
|
\end{block}
|
|
|
|
\end{minipage}
|
|
|
|
\hfill
|
|
|
|
\begin{minipage}[t]{0.40\textwidth}
|
|
|
|
\begin{block}{ML-based}
|
|
|
|
\medskip
|
|
|
|
\begin{itemize}
|
|
|
|
\item \alert{\ithemal{}}: academia.
|
|
|
|
\end{itemize}
|
|
|
|
\end{block}
|
|
|
|
\end{minipage} \\
|
|
|
|
|
|
|
|
\vfill
|
2024-11-20 12:54:09 +01:00
|
|
|
|
2024-12-05 18:34:30 +01:00
|
|
|
Behavioural tools are (to some extent) based on \alert{manually-made}
|
2024-12-01 12:17:32 +01:00
|
|
|
models!\\
|
|
|
|
\pause{}
|
|
|
|
\bigskip{}
|
|
|
|
\begin{center}
|
|
|
|
\textbf{\alert{Ambition:}} \alert{automated} model generation.
|
|
|
|
\end{center}
|
2024-11-20 12:54:09 +01:00
|
|
|
\end{frame}
|
2024-11-20 23:08:08 +01:00
|
|
|
|
|
|
|
\begin{frame}{When I started my PhD\ldots}
|
|
|
|
\centering
|
2024-12-01 21:21:08 +01:00
|
|
|
%\includegraphics[height=0.9\textheight]{patate_placeholder.jpg}
|
2024-12-06 11:54:46 +01:00
|
|
|
\only<1>{\includegraphics[height=0.9\textheight]{sota_potato.svg}}%
|
|
|
|
\only<2>{\includegraphics[height=0.9\textheight]{sota_potato_eval.svg}}\\
|
2024-11-20 23:08:08 +01:00
|
|
|
\end{frame}
|