Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(52)

Unified Diff: snapshot/test/test_cpu_context.cc

Issue 686353004: Add MinidumpContextWriter::CreateFromSnapshot(), everything downstream, and its test (Closed) Base URL: https://chromium.googlesource.com/crashpad/crashpad@master
Patch Set: Address review feedback Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « snapshot/test/test_cpu_context.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: snapshot/test/test_cpu_context.cc
diff --git a/snapshot/test/test_cpu_context.cc b/snapshot/test/test_cpu_context.cc
new file mode 100644
index 0000000000000000000000000000000000000000..c0ec085d2fd6e631949f01a226dfad8d3cacf963
--- /dev/null
+++ b/snapshot/test/test_cpu_context.cc
@@ -0,0 +1,165 @@
+// 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 "snapshot/test/test_cpu_context.h"
+
+#include "base/basictypes.h"
+
+namespace crashpad {
+namespace test {
+
+void InitializeCPUContextX86(CPUContext* context, uint32_t seed) {
+ context->architecture = kCPUArchitectureX86;
+
+ if (seed == 0) {
+ memset(context->x86, 0, sizeof(*context->x86));
+ return;
+ }
+
+ uint32_t value = seed;
+
+ context->x86->eax = value++;
+ context->x86->ebx = value++;
+ context->x86->ecx = value++;
+ context->x86->edx = value++;
+ context->x86->edi = value++;
+ context->x86->esi = value++;
+ context->x86->ebp = value++;
+ context->x86->esp = value++;
+ context->x86->eip = value++;
+ context->x86->eflags = value++;
+ context->x86->cs = value++;
+ context->x86->ds = value++;
+ context->x86->es = value++;
+ context->x86->fs = value++;
+ context->x86->gs = value++;
+ context->x86->ss = value++;
+ InitializeCPUContextX86Fxsave(&context->x86->fxsave, &value);
+ context->x86->dr0 = value++;
+ context->x86->dr1 = value++;
+ context->x86->dr2 = value++;
+ context->x86->dr3 = value++;
+ context->x86->dr4 = value++;
+ context->x86->dr5 = value++;
+ context->x86->dr6 = value++;
+ context->x86->dr7 = value++;
+}
+
+void InitializeCPUContextX86_64(CPUContext* context, uint32_t seed) {
+ context->architecture = kCPUArchitectureX86_64;
+
+ if (seed == 0) {
+ memset(context->x86_64, 0, sizeof(*context->x86_64));
+ return;
+ }
+
+ uint32_t value = seed;
+
+ context->x86_64->rax = value++;
+ context->x86_64->rbx = value++;
+ context->x86_64->rcx = value++;
+ context->x86_64->rdx = value++;
+ context->x86_64->rdi = value++;
+ context->x86_64->rsi = value++;
+ context->x86_64->rbp = value++;
+ context->x86_64->rsp = value++;
+ context->x86_64->r8 = value++;
+ context->x86_64->r9 = value++;
+ context->x86_64->r10 = value++;
+ context->x86_64->r11 = value++;
+ context->x86_64->r12 = value++;
+ context->x86_64->r13 = value++;
+ context->x86_64->r14 = value++;
+ context->x86_64->r15 = value++;
+ context->x86_64->rip = value++;
+ context->x86_64->rflags = value++;
+ context->x86_64->cs = value++;
+ context->x86_64->fs = value++;
+ context->x86_64->gs = value++;
+ InitializeCPUContextX86_64Fxsave(&context->x86_64->fxsave, &value);
+ context->x86_64->dr0 = value++;
+ context->x86_64->dr1 = value++;
+ context->x86_64->dr2 = value++;
+ context->x86_64->dr3 = value++;
+ context->x86_64->dr4 = value++;
+ context->x86_64->dr5 = value++;
+ context->x86_64->dr6 = value++;
+ context->x86_64->dr7 = value++;
+}
+
+namespace {
+
+// This is templatized because the CPUContextX86::Fxsave and
+// CPUContextX86_64::Fxsave are nearly identical but have different sizes for
+// the members |xmm|, |reserved_4|, and |available|.
+template <typename FxsaveType>
+void InitializeCPUContextFxsave(FxsaveType* fxsave, uint32_t* seed) {
+ uint32_t value = *seed;
+
+ fxsave->fcw = value++;
+ fxsave->fsw = value++;
+ fxsave->ftw = value++;
+ fxsave->reserved_1 = value++;
+ fxsave->fop = value++;
+ fxsave->fpu_ip = value++;
+ fxsave->fpu_cs = value++;
+ fxsave->reserved_2 = value++;
+ fxsave->fpu_dp = value++;
+ fxsave->fpu_ds = value++;
+ fxsave->reserved_3 = value++;
+ fxsave->mxcsr = value++;
+ fxsave->mxcsr_mask = value++;
+ for (size_t st_mm_index = 0;
+ st_mm_index < arraysize(fxsave->st_mm);
+ ++st_mm_index) {
+ for (size_t byte = 0;
+ byte < arraysize(fxsave->st_mm[st_mm_index].st);
+ ++byte) {
+ fxsave->st_mm[st_mm_index].st[byte] = value++;
+ }
+ for (size_t byte = 0;
+ byte < arraysize(fxsave->st_mm[st_mm_index].st_reserved);
+ ++byte) {
+ fxsave->st_mm[st_mm_index].st_reserved[byte] = value;
+ }
+ }
+ for (size_t xmm_index = 0; xmm_index < arraysize(fxsave->xmm); ++xmm_index) {
+ for (size_t byte = 0; byte < arraysize(fxsave->xmm[xmm_index]); ++byte) {
+ fxsave->xmm[xmm_index][byte] = value++;
+ }
+ }
+ for (size_t byte = 0; byte < arraysize(fxsave->reserved_4); ++byte) {
+ fxsave->reserved_4[byte] = value++;
+ }
+ for (size_t byte = 0; byte < arraysize(fxsave->available); ++byte) {
+ fxsave->available[byte] = value++;
+ }
+
+ *seed = value;
+}
+
+} // namespace
+
+void InitializeCPUContextX86Fxsave(CPUContextX86::Fxsave* fxsave,
+ uint32_t* seed) {
+ return InitializeCPUContextFxsave(fxsave, seed);
+}
+
+void InitializeCPUContextX86_64Fxsave(CPUContextX86_64::Fxsave* fxsave,
+ uint32_t* seed) {
+ return InitializeCPUContextFxsave(fxsave, seed);
+}
+
+} // namespace test
+} // namespace crashpad
« no previous file with comments | « snapshot/test/test_cpu_context.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698