mirror of
https://github.com/chromium/crashpad.git
synced 2025-01-14 17:30:09 +08:00
50ed179e9a
Use BUILDFLAG(IS_*) instead of defined(OS_*). This was generated mostly mechnically by performing the following steps: - sed -i '' -E -e 's/defined\(OS_/BUILDFLAG(IS_/g' \ -e 's%([ !])OS_([A-Z]+)%\1BUILDFLAG(IS_\2)%g' \ $(git grep -l 'OS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - sed -i '' -e 's/#ifdef BUILDFLAG(/#if BUILDFLAG(/' \ $(git grep -l '#ifdef BUILDFLAG(' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - gsed -i -z -E -e \ 's%(.*)#include "%\1#include "build/buildflag.h"\n#include "%' \ $(git grep -l 'BUILDFLAG(IS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm') - Spot checks to move #include "build/buildflag.h" to the correct parts of files. - sed -i '' -E -e \ 's%^(#include "build/buildflag.h")$%#include "build/build_config.h"\n\1%' \ $(grep -L '^#include "build/build_config.h"$' $(git grep -l 'BUILDFLAG(IS_' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm')) - Add “clang-format off” around tool usage messages. - git cl format - Update mini_chromium to 85ba51f98278 (intermediate step). TESTING ONLY). - for f in $(git grep -l '^#include "build/buildflag.h"$' '**/*.c' '**/*.cc' '**/*.h' '**/*.m' '**/*.mm'); do \ grep -v '^#include "build/buildflag.h"$' "${f}" > /tmp/z; \ cp /tmp/z "${f}"; done - git cl format - Update mini_chromium to 735143774c5f (intermediate step). - Update mini_chromium to f41420eb45fa (as checked in). - Update mini_chromium to 6e2f204b4ae1 (as checked in). For ease of review and inspection, each of these steps is uploaded as a new patch set in a review series. This includes an update of mini_chromium to 6e2f204b4ae1: f41420eb45fa Use BUILDFLAG for OS checking 6e2f204b4ae1 Include what you use: string_util.h uses build_config.h Bug: chromium:1234043 Change-Id: Ieef86186f094c64e59b853729737e36982f8cf69 Reviewed-on: https://chromium-review.googlesource.com/c/crashpad/crashpad/+/3400258 Reviewed-by: Joshua Peraza <jperaza@chromium.org> Commit-Queue: Mark Mentovai <mark@chromium.org>
139 lines
5.1 KiB
C++
139 lines
5.1 KiB
C++
// Copyright 2014 The Crashpad Authors. All rights reserved.
|
||
//
|
||
// Licensed under the Apache License, Version 2.0 (the "License");
|
||
// you may not use this file except in compliance with the License.
|
||
// You may obtain a copy of the License at
|
||
//
|
||
// http://www.apache.org/licenses/LICENSE-2.0
|
||
//
|
||
// Unless required by applicable law or agreed to in writing, software
|
||
// distributed under the License is distributed on an "AS IS" BASIS,
|
||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||
// See the License for the specific language governing permissions and
|
||
// limitations under the License.
|
||
|
||
#include "client/crashpad_info.h"
|
||
|
||
#include <type_traits>
|
||
|
||
#include "build/build_config.h"
|
||
#include "util/misc/address_sanitizer.h"
|
||
#include "util/misc/from_pointer_cast.h"
|
||
|
||
#if BUILDFLAG(IS_APPLE)
|
||
#include <mach-o/loader.h>
|
||
#endif
|
||
|
||
namespace {
|
||
|
||
// Don’t change this when simply adding fields. Readers will size-check the
|
||
// structure and ignore fields they’re aware of when not present, as well as
|
||
// fields they’re not aware of. Only change this when introducing an
|
||
// incompatible layout, with the understanding that existing readers will not
|
||
// understand new versions.
|
||
constexpr uint32_t kCrashpadInfoVersion = 1;
|
||
|
||
} // namespace
|
||
|
||
namespace crashpad {
|
||
|
||
static_assert(std::is_standard_layout<CrashpadInfo>::value,
|
||
"CrashpadInfo must be standard layout");
|
||
|
||
// This structure needs to be stored somewhere that is easy to find without
|
||
// external information.
|
||
//
|
||
// It isn’t placed in an unnamed namespace: hopefully, this will catch attempts
|
||
// to place multiple copies of this structure into the same module. If that’s
|
||
// attempted, and the name of the symbol is the same in each translation unit,
|
||
// it will result in a linker error, which is better than having multiple
|
||
// structures show up.
|
||
//
|
||
// This may result in a static module initializer in debug-mode builds, but
|
||
// because it’s POD, no code should need to run to initialize this under
|
||
// release-mode optimization.
|
||
|
||
#if BUILDFLAG(IS_POSIX)
|
||
__attribute__((
|
||
|
||
#if BUILDFLAG(IS_APPLE)
|
||
// Put the structure in a well-known section name where it can be easily
|
||
// found without having to consult the symbol table.
|
||
section(SEG_DATA ",crashpad_info"),
|
||
#endif
|
||
|
||
#if defined(ADDRESS_SANITIZER)
|
||
// AddressSanitizer would add a trailing red zone of at least 32 bytes,
|
||
// which would be reflected in the size of the custom section. This confuses
|
||
// MachOImageReader::GetCrashpadInfo(), which finds that the section’s size
|
||
// disagrees with the structure’s size_ field. By specifying an alignment
|
||
// greater than the red zone size, the red zone will be suppressed.
|
||
aligned(64),
|
||
#endif // defined(ADDRESS_SANITIZER)
|
||
|
||
// There's no need to expose this as a public symbol from the symbol table.
|
||
// All accesses from the outside can locate the well-known section name.
|
||
visibility("hidden"),
|
||
|
||
// The “used” attribute prevents the structure from being dead-stripped.
|
||
used))
|
||
|
||
#elif BUILDFLAG(IS_WIN)
|
||
|
||
// Put the struct in a section name CPADinfo where it can be found without the
|
||
// symbol table.
|
||
#pragma section("CPADinfo", read, write)
|
||
__declspec(allocate("CPADinfo"))
|
||
|
||
#else // !BUILDFLAG(IS_POSIX) && !BUILDFLAG(IS_WIN)
|
||
#error Port
|
||
#endif // !BUILDFLAG(IS_POSIX) && !BUILDFLAG(IS_WIN)
|
||
|
||
CrashpadInfo g_crashpad_info;
|
||
|
||
extern "C" int* CRASHPAD_NOTE_REFERENCE;
|
||
|
||
// static
|
||
CrashpadInfo* CrashpadInfo::GetCrashpadInfo() {
|
||
#if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_ANDROID) || \
|
||
BUILDFLAG(IS_FUCHSIA)
|
||
// This otherwise-unused reference is used so that any module that
|
||
// references GetCrashpadInfo() will also include the note in the
|
||
// .note.crashpad.info section. That note in turn contains the address of
|
||
// g_crashpad_info. This allows the module reader to find the CrashpadInfo
|
||
// structure without requiring the use of the dynamic symbol table.
|
||
static volatile int* pointer_to_note_section = CRASHPAD_NOTE_REFERENCE;
|
||
(void)pointer_to_note_section;
|
||
#endif
|
||
return &g_crashpad_info;
|
||
}
|
||
|
||
CrashpadInfo::CrashpadInfo()
|
||
: signature_(kSignature),
|
||
size_(sizeof(*this)),
|
||
version_(kCrashpadInfoVersion),
|
||
indirectly_referenced_memory_cap_(0),
|
||
padding_0_(0),
|
||
crashpad_handler_behavior_(TriState::kUnset),
|
||
system_crash_reporter_forwarding_(TriState::kUnset),
|
||
gather_indirectly_referenced_memory_(TriState::kUnset),
|
||
padding_1_(0),
|
||
extra_memory_ranges_(nullptr),
|
||
simple_annotations_(nullptr),
|
||
user_data_minidump_stream_head_(nullptr),
|
||
annotations_list_(nullptr) {}
|
||
|
||
void CrashpadInfo::AddUserDataMinidumpStream(uint32_t stream_type,
|
||
const void* data,
|
||
size_t size) {
|
||
auto to_be_added = new internal::UserDataMinidumpStreamListEntry();
|
||
to_be_added->next =
|
||
FromPointerCast<uint64_t>(user_data_minidump_stream_head_);
|
||
to_be_added->stream_type = stream_type;
|
||
to_be_added->base_address = FromPointerCast<uint64_t>(data);
|
||
to_be_added->size = base::checked_cast<uint64_t>(size);
|
||
user_data_minidump_stream_head_ = to_be_added;
|
||
}
|
||
|
||
} // namespace crashpad
|