From 9a791c399266a650acac45ac55a066a84aad7c64 Mon Sep 17 00:00:00 2001 From: Dmitry Vyukov Date: Wed, 8 Aug 2018 12:48:06 +0200 Subject: executor: remap cover fd's to higher values Remap cover fd's to 24x range to prevent interference with fd's used during fuzzing and also to make fd number consistent with/without cover enabled. --- executor/executor_bsd.h | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'executor/executor_bsd.h') diff --git a/executor/executor_bsd.h b/executor/executor_bsd.h index 0bed21679..73b026379 100644 --- a/executor/executor_bsd.h +++ b/executor/executor_bsd.h @@ -58,9 +58,12 @@ static long execute_syscall(const call_t* c, long a[kMaxArgs]) static void cover_open(cover_t* cov) { - cov->fd = open("/dev/kcov", O_RDWR); - if (cov->fd == -1) + int fd = open("/dev/kcov", O_RDWR); + if (fd == -1) fail("open of /dev/kcov failed"); + if (dup2(fd, cov->fd) < 0) + fail("filed to dup2(%d, %d) cover fd", fd, cov->fd); + close(fd); if (ioctl(cov->fd, KIOSETBUFSIZE, &kCoverSize)) fail("ioctl init trace write failed"); size_t mmap_alloc_size = kCoverSize * (is_kernel_64_bit ? 8 : 4); -- cgit mrf-deployment