2016-12-01 03:06:14 +08:00
|
|
|
//===- FuzzerIO.h - Internal header for IO utils ----------------*- C++ -* ===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// IO interface.
|
|
|
|
//===----------------------------------------------------------------------===//
|
2016-12-14 01:46:11 +08:00
|
|
|
|
2016-12-01 03:06:14 +08:00
|
|
|
#ifndef LLVM_FUZZER_IO_H
|
|
|
|
#define LLVM_FUZZER_IO_H
|
|
|
|
|
|
|
|
#include "FuzzerDefs.h"
|
|
|
|
|
|
|
|
namespace fuzzer {
|
|
|
|
|
|
|
|
long GetEpoch(const std::string &Path);
|
|
|
|
|
|
|
|
Unit FileToVector(const std::string &Path, size_t MaxSize = 0,
|
|
|
|
bool ExitOnError = true);
|
|
|
|
|
|
|
|
std::string FileToString(const std::string &Path);
|
|
|
|
|
|
|
|
void CopyFileToErr(const std::string &Path);
|
|
|
|
|
|
|
|
void WriteToFile(const Unit &U, const std::string &Path);
|
|
|
|
|
|
|
|
void ReadDirToVectorOfUnits(const char *Path, std::vector<Unit> *V,
|
|
|
|
long *Epoch, size_t MaxSize, bool ExitOnError);
|
|
|
|
|
|
|
|
// Returns "Dir/FileName" or equivalent for the current OS.
|
|
|
|
std::string DirPlusFile(const std::string &DirPath,
|
|
|
|
const std::string &FileName);
|
|
|
|
|
2016-12-01 05:53:32 +08:00
|
|
|
// Returns the name of the dir, similar to the 'dirname' utility.
|
|
|
|
std::string DirName(const std::string &FileName);
|
|
|
|
|
2017-01-05 12:32:19 +08:00
|
|
|
// Returns path to a TmpDir.
|
|
|
|
std::string TmpDir();
|
|
|
|
|
2017-01-22 09:27:47 +08:00
|
|
|
bool IsInterestingCoverageFile(const std::string &FileName);
|
|
|
|
|
2016-12-01 03:06:14 +08:00
|
|
|
void DupAndCloseStderr();
|
|
|
|
|
|
|
|
void CloseStdout();
|
|
|
|
|
|
|
|
void Printf(const char *Fmt, ...);
|
|
|
|
|
2017-01-26 09:04:54 +08:00
|
|
|
// Print using raw syscalls, useful when printing at early init stages.
|
|
|
|
void RawPrint(const char *Str);
|
|
|
|
|
2016-12-01 05:44:26 +08:00
|
|
|
// Platform specific functions:
|
|
|
|
bool IsFile(const std::string &Path);
|
|
|
|
|
|
|
|
void ListFilesInDirRecursive(const std::string &Dir, long *Epoch,
|
|
|
|
std::vector<std::string> *V, bool TopDir);
|
|
|
|
|
|
|
|
char GetSeparator();
|
|
|
|
|
|
|
|
FILE* OpenFile(int Fd, const char *Mode);
|
|
|
|
|
|
|
|
int CloseFile(int Fd);
|
|
|
|
|
|
|
|
int DuplicateFile(int Fd);
|
|
|
|
|
2016-12-14 01:46:40 +08:00
|
|
|
void RemoveFile(const std::string &Path);
|
2016-12-01 05:44:26 +08:00
|
|
|
|
[libFuzzer] Avoid undefined behavior, properly discard output to stdout/stderr.
Fix libFuzzer when setting -close_fd_mask to a non-zero value.
In previous implementation, libFuzzer closes the file descriptors for
stdout/stderr. This has some disavantages:
For `fuzzer-fdmask.test`, we write directly to stdout and stderr using the
file streams stdout and stderr, after the file descriptors are closed, which is
undefined behavior. In Windows, in particular, this was making the test fail.
Also, if we close stdout and we open a new file in libFuzzer, we get the file
descriptor 1, which could generate problem if some code assumes file descriptors
refers to stdout and works directly writing to the file descriptor 1, but it
will be writing to the opened file (for example using std::cout).
Instead of closing the file descriptors, I redirect the output to /dev/null on
linux and nul on Windows.
Differential Revision: https://reviews.llvm.org/D28718
llvm-svn: 292743
2017-01-22 09:58:45 +08:00
|
|
|
void DiscardOutput(int Fd);
|
|
|
|
|
2017-02-08 08:03:18 +08:00
|
|
|
intptr_t GetHandleFromFd(int fd);
|
|
|
|
|
2016-12-01 03:06:14 +08:00
|
|
|
} // namespace fuzzer
|
2016-12-14 01:46:11 +08:00
|
|
|
|
2016-12-01 03:06:14 +08:00
|
|
|
#endif // LLVM_FUZZER_IO_H
|