]> xenbits.xensource.com Git - xen.git/commit
fuzz/x86_emulate: clear errors after each iteration
authorGeorge Dunlap <george.dunlap@citrix.com>
Mon, 9 Oct 2017 14:04:11 +0000 (16:04 +0200)
committerJan Beulich <jbeulich@suse.com>
Mon, 9 Oct 2017 14:04:11 +0000 (16:04 +0200)
commit849a1f10c937ce0782db95b85da391a49317c49e
treeee9d15c2166939d9e72b878d68a7f31738b8f051
parent581c3e874c300695ddfa8b2a95675a42ebf97301
fuzz/x86_emulate: clear errors after each iteration

Once feof() returns true for a stream, it will continue to return true
for that stream until clearerr() is called (or the stream is closed
and re-opened).

In llvm-clang-fast-mode, the same file descriptor is used for each
iteration of the loop, meaning that the "Input too large" check was
broken -- feof() would return true even if the fread() hadn't hit the
end of the file.  The result is that AFL generates testcases of
arbitrary size.

Fix this by clearing the error after each iteration.

Signed-off-by: George Dunlap <george.dunlap@citrix.com>
Reviewed-by: Jan Beulich <jbeulich@suse.com>
tools/fuzz/x86_instruction_emulator/afl-harness.c