mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-17 13:16:39 +00:00

Include windows.h with an all lowercase filename; Windows SDK headers aren't self consistent so they can't be used in an entirely case sensitive setting, and mingw headers use all lowercase names for such headers. This fixes building after 881faf41909b47376595e8d7bb9c9a109182d20b.
81 lines
3.1 KiB
C++
81 lines
3.1 KiB
C++
//===- FuzzerExtraCountersWindows.cpp - Extra coverage counters for Win32 -===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
// Extra coverage counters defined by user code for Windows.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "FuzzerPlatform.h"
|
|
#include <cstdint>
|
|
|
|
#if LIBFUZZER_WINDOWS
|
|
#include <windows.h>
|
|
|
|
namespace fuzzer {
|
|
|
|
//
|
|
// The __start___libfuzzer_extra_counters variable is align 16, size 16 to
|
|
// ensure the padding between it and the next variable in this section (either
|
|
// __libfuzzer_extra_counters or __stop___libfuzzer_extra_counters) will be
|
|
// located at (__start___libfuzzer_extra_counters +
|
|
// sizeof(__start___libfuzzer_extra_counters)). Otherwise, the calculation of
|
|
// (stop - (start + sizeof(start))) might be skewed.
|
|
//
|
|
// The section name, __libfuzzer_extra_countaaa ends with "aaa", so it sorts
|
|
// before __libfuzzer_extra_counters alphabetically. We want the start symbol to
|
|
// be placed in the section just before the user supplied counters (if present).
|
|
//
|
|
#pragma section(".data$__libfuzzer_extra_countaaa")
|
|
ATTRIBUTE_ALIGNED(16)
|
|
__declspec(allocate(".data$__libfuzzer_extra_countaaa")) uint8_t
|
|
__start___libfuzzer_extra_counters[16] = {0};
|
|
|
|
//
|
|
// Example of what the user-supplied counters should look like. First, the
|
|
// pragma to create the section name. It will fall alphabetically between
|
|
// ".data$__libfuzzer_extra_countaaa" and ".data$__libfuzzer_extra_countzzz".
|
|
// Next, the declspec to allocate the variable inside the specified section.
|
|
// Finally, some array, struct, whatever that is used to track the counter data.
|
|
// The size of this variable is computed at runtime by finding the difference of
|
|
// __stop___libfuzzer_extra_counters and __start___libfuzzer_extra_counters +
|
|
// sizeof(__start___libfuzzer_extra_counters).
|
|
//
|
|
|
|
//
|
|
// #pragma section(".data$__libfuzzer_extra_counters")
|
|
// __declspec(allocate(".data$__libfuzzer_extra_counters"))
|
|
// uint8_t any_name_variable[64 * 1024];
|
|
//
|
|
|
|
//
|
|
// Here, the section name, __libfuzzer_extra_countzzz ends with "zzz", so it
|
|
// sorts after __libfuzzer_extra_counters alphabetically. We want the stop
|
|
// symbol to be placed in the section just after the user supplied counters (if
|
|
// present). Align to 1 so there isn't any padding placed between this and the
|
|
// previous variable.
|
|
//
|
|
#pragma section(".data$__libfuzzer_extra_countzzz")
|
|
ATTRIBUTE_ALIGNED(1)
|
|
__declspec(allocate(".data$__libfuzzer_extra_countzzz")) uint8_t
|
|
__stop___libfuzzer_extra_counters = 0;
|
|
|
|
uint8_t *ExtraCountersBegin() {
|
|
return __start___libfuzzer_extra_counters +
|
|
sizeof(__start___libfuzzer_extra_counters);
|
|
}
|
|
|
|
uint8_t *ExtraCountersEnd() { return &__stop___libfuzzer_extra_counters; }
|
|
|
|
ATTRIBUTE_NO_SANITIZE_ALL
|
|
void ClearExtraCounters() {
|
|
uint8_t *Beg = ExtraCountersBegin();
|
|
SecureZeroMemory(Beg, ExtraCountersEnd() - Beg);
|
|
}
|
|
|
|
} // namespace fuzzer
|
|
|
|
#endif
|