Switch to biblatex
This commit is contained in:
parent
20898800cb
commit
0575bfd3f5
2 changed files with 36 additions and 8 deletions
|
@ -7,6 +7,14 @@
|
||||||
publisher={Springer}
|
publisher={Springer}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@online{nicely_fdiv,
|
||||||
|
author = {Thomas Nicely},
|
||||||
|
title={Pentium FDIV flaw FAQ},
|
||||||
|
year = {2011},
|
||||||
|
url = {http://www.trnicely.net/pentbug/pentbug.html},
|
||||||
|
urldate = {2017-08-10}
|
||||||
|
}
|
||||||
|
|
||||||
@inproceedings{harrison2003formal,
|
@inproceedings{harrison2003formal,
|
||||||
title={Formal verification at intel},
|
title={Formal verification at intel},
|
||||||
author={Harrison, John},
|
author={Harrison, John},
|
||||||
|
|
|
@ -7,8 +7,9 @@
|
||||||
\usepackage{graphicx}
|
\usepackage{graphicx}
|
||||||
\usepackage{indentfirst}
|
\usepackage{indentfirst}
|
||||||
\usepackage{enumerate}
|
\usepackage{enumerate}
|
||||||
\usepackage{cite}
|
%\usepackage{cite}
|
||||||
\usepackage{caption}
|
\usepackage{caption}
|
||||||
|
\usepackage[backend=biber,style=trad-alpha]{biblatex}
|
||||||
\usepackage[left=2cm,right=2cm,top=2cm,bottom=2cm]{geometry}
|
\usepackage[left=2cm,right=2cm,top=2cm,bottom=2cm]{geometry}
|
||||||
|
|
||||||
|
|
||||||
|
@ -18,8 +19,11 @@
|
||||||
\usepackage{my_listings}
|
\usepackage{my_listings}
|
||||||
\usepackage{my_hyperref}
|
\usepackage{my_hyperref}
|
||||||
|
|
||||||
|
\bibliography{../common/refs}
|
||||||
|
|
||||||
\title{Pattern-matching and substitution in electronic circuits}
|
\title{Pattern-matching and substitution in electronic circuits}
|
||||||
\author{Théophile Bastian, under supervision of Carl-Johan Seger\\
|
\author{Théophile Bastian, under supervision of Carl-Johan Seger
|
||||||
|
and Mary Sheeran\\
|
||||||
\small{Chalmers University, Göteborg, Sweden}}
|
\small{Chalmers University, Göteborg, Sweden}}
|
||||||
\date{February~--~June 2017}
|
\date{February~--~June 2017}
|
||||||
|
|
||||||
|
@ -44,11 +48,12 @@ increasing interest in the computer science community, as people realised how
|
||||||
hard bugs are to track down. But hardware bugs are even more tedious to find
|
hard bugs are to track down. But hardware bugs are even more tedious to find
|
||||||
and fix, and can easily lead to disastrous consequences, as those cannot be
|
and fix, and can easily lead to disastrous consequences, as those cannot be
|
||||||
patched on existing hardware. For instance, the well-known Pentium
|
patched on existing hardware. For instance, the well-known Pentium
|
||||||
``\textsc{fdiv}'' bug~\ref{pratt1995fdiv} that affected a large number of
|
``\textsc{fdiv}'' bug~\cite{pratt1995fdiv} that affected a large number of
|
||||||
Pentium processors lead to wrong results for some floating point divisions.
|
Pentium processors lead to wrong results for some floating point divisions.
|
||||||
Intel had to replace \todo{how many?} CPUs, leading to a loss of \todo{how
|
Intel had to replace \todo{how many?} CPUs, leading to an announced loss of 475
|
||||||
much?}. Even recently, the Skylake and Kiby Lake \todo{(?)} hyperthreading bug
|
million dollars~\cite{nicely_fdiv}. Even recently, the Skylake and Kaby Lake
|
||||||
had to be patched using microcode, loosing performance and reliability.
|
hyperthreading bug had to be patched using microcode, loosing performance and
|
||||||
|
reliability.
|
||||||
|
|
||||||
To avoid such disasters, the industry nowadays uses a wide range of techniques
|
To avoid such disasters, the industry nowadays uses a wide range of techniques
|
||||||
to catch bugs as early as possible -- which, hopefully, is before the product's
|
to catch bugs as early as possible -- which, hopefully, is before the product's
|
||||||
|
@ -79,6 +84,22 @@ understand, and make it easier to understand to work more efficiently.
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
\section{General approach}
|
\section{General approach}
|
||||||
|
|
||||||
|
Among many others, one idea that proved itself efficient at Intel for circuit
|
||||||
|
verification was to prove the correctness of a ``simple'' circuit, that is, a
|
||||||
|
circuit that is not too optimized, on which the various features and parts can
|
||||||
|
be easily seen and properties can be expressed cleanly. This circuit could then
|
||||||
|
be refined afterwards, only by means of proved transformations mostly
|
||||||
|
resulting from a somewhat large database of usual transformations, along with
|
||||||
|
their proofs of correctness.
|
||||||
|
|
||||||
|
This process of replacement was mostly done through a ``search and replace''
|
||||||
|
tool. The tool would basically search every (non-overlapping) occurrence of a
|
||||||
|
given ``pattern'', remove these occurrences from the circuit, and plug the
|
||||||
|
replacement version of the pattern in its place. A pattern, in this context,
|
||||||
|
consists in a piece of circuit, along with in- and outbound wires to be
|
||||||
|
reconnected in the right place afterwards.
|
||||||
|
|
||||||
\todo{}
|
\todo{}
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
@ -99,7 +120,6 @@ understand, and make it easier to understand to work more efficiently.
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
|
||||||
\bibliography{../common/refs}
|
\printbibliography{}
|
||||||
\bibliographystyle{alpha}
|
|
||||||
|
|
||||||
\end{document}
|
\end{document}
|
||||||
|
|
Loading…
Reference in a new issue