summaryrefslogtreecommitdiffstats
path: root/introduction.tex
diff options
context:
space:
mode:
authorJohn Wickerson <j.wickerson@imperial.ac.uk>2020-11-18 12:57:44 +0000
committeroverleaf <overleaf@localhost>2020-11-18 12:57:49 +0000
commitee16ea1977cc28f2e4e72220c83e9bff58e3b4e4 (patch)
tree3f921278786d14910c4fc0a32455c31bf3f21a07 /introduction.tex
parent69a941a5ac5a22402aa9db16c561007964d19f19 (diff)
downloadoopsla21_fvhls-ee16ea1977cc28f2e4e72220c83e9bff58e3b4e4.tar.gz
oopsla21_fvhls-ee16ea1977cc28f2e4e72220c83e9bff58e3b4e4.zip
Update on Overleaf.
Diffstat (limited to 'introduction.tex')
-rw-r--r--introduction.tex3
1 files changed, 2 insertions, 1 deletions
diff --git a/introduction.tex b/introduction.tex
index a15ad33..9f9903a 100644
--- a/introduction.tex
+++ b/introduction.tex
@@ -18,7 +18,8 @@ This undermines any reasoning conducted at the software level.
And there are reasons to doubt that HLS tools actually \emph{do} preserve equivalence. First, just like conventional compilers, HLS tools are large pieces of software that perform a series of complex analyses and transformations.
Second, unlike conventional compilers, HLS tools target HDL, which has superficial syntactic similarities to software languages but a subtly different semantics, making it easy to introduce behavioural mismatches between the output of the HLS tool and its input.
%Hence, the premise of this work is: Can we trust these compilers to translate high-level languages like C/C++ to HDL correctly?
-These doubts have been realised by For instance, \citet{lidbury15_many_core_compil_fuzzin} had to abandon their attempt to fuzz-test Altera's (now Intel's) OpenCL compiler since it ``either crashed or emitted an internal compiler error'' on so many of their test inputs.
+These doubts have been realised by
+For instance, \citet{lidbury15_many_core_compil_fuzzin} had to abandon their attempt to fuzz-test Altera's (now Intel's) OpenCL compiler since it ``either crashed or emitted an internal compiler error'' on so many of their test inputs.
More recently, Du et al.~\cite{du+20} fuzz-tested three commercial HLS tools using Csmith~\cite{yang11_findin_under_bugs_c_compil}, and despite restricting the generated programs to the C fragment explicitly supported by all the tools, they still found that on average 2.5\% of test cases generated a design that did not match the behaviour of the input.
%
Meanwhile, Xilinx's Vivado HLS has been shown to apply pipelining optimisations incorrectly\footnote{\url{https://bit.ly/vivado-hls-pipeline-bug}} or to silently generate wrong code should the programmer stray outside the fragment of C that it supports\footnote{\url{https://bit.ly/vivado-hls-pointer-bug}}.