Home | History | Annotate | Download | only in dump_writer_common

Lines Matching refs:out

27 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
51 void UContextReader::FillCPUContext(RawContextCPU *out, const ucontext *uc,
55 out->context_flags = MD_CONTEXT_X86_FULL |
58 out->gs = regs[REG_GS];
59 out->fs = regs[REG_FS];
60 out->es = regs[REG_ES];
61 out->ds = regs[REG_DS];
63 out->edi = regs[REG_EDI];
64 out->esi = regs[REG_ESI];
65 out->ebx = regs[REG_EBX];
66 out->edx = regs[REG_EDX];
67 out->ecx = regs[REG_ECX];
68 out->eax = regs[REG_EAX];
70 out->ebp = regs[REG_EBP];
71 out->eip = regs[REG_EIP];
72 out->cs = regs[REG_CS];
73 out->eflags = regs[REG_EFL];
74 out->esp = regs[REG_UESP];
75 out->ss = regs[REG_SS];
77 out->float_save.control_word = fp->cw;
78 out->float_save.status_word = fp->sw;
79 out->float_save.tag_word = fp->tag;
80 out->float_save.error_offset = fp->ipoff;
81 out->float_save.error_selector = fp->cssel;
82 out->float_save.data_offset = fp->dataoff;
83 out->float_save.data_selector = fp->datasel;
86 my_memcpy(out->float_save.register_area, fp->_st, 10 * 8);
99 void UContextReader::FillCPUContext(RawContextCPU *out, const ucontext *uc,
103 out->context_flags = MD_CONTEXT_AMD64_FULL;
105 out->cs = regs[REG_CSGSFS] & 0xffff;
107 out->fs = (regs[REG_CSGSFS] >> 32) & 0xffff;
108 out->gs = (regs[REG_CSGSFS] >> 16) & 0xffff;
110 out->eflags = regs[REG_EFL];
112 out->rax = regs[REG_RAX];
113 out->rcx = regs[REG_RCX];
114 out->rdx = regs[REG_RDX];
115 out->rbx = regs[REG_RBX];
117 out->rsp = regs[REG_RSP];
118 out->rbp = regs[REG_RBP];
119 out->rsi = regs[REG_RSI];
120 out->rdi = regs[REG_RDI];
121 out->r8 = regs[REG_R8];
122 out->r9 = regs[REG_R9];
123 out->r10 = regs[REG_R10];
124 out->r11 = regs[REG_R11];
125 out->r12 = regs[REG_R12];
126 out->r13 = regs[REG_R13];
127 out->r14 = regs[REG_R14];
128 out->r15 = regs[REG_R15];
130 out->rip = regs[REG_RIP];
132 out->flt_save.control_word = fpregs->cwd;
133 out->flt_save.status_word = fpregs->swd;
134 out->flt_save.tag_word = fpregs->ftw;
135 out->flt_save.error_opcode = fpregs->fop;
136 out->flt_save.error_offset = fpregs->rip;
137 out->flt_save.data_offset = fpregs->rdp;
138 out->flt_save.error_selector = 0; // We don't have this.
139 out->flt_save.data_selector = 0; // We don't have this.
140 out->flt_save.mx_csr = fpregs->mxcsr;
141 out->flt_save.mx_csr_mask = fpregs->mxcr_mask;
142 my_memcpy(&out->flt_save.float_registers, &fpregs->_st, 8 * 16);
143 my_memcpy(&out->flt_save.xmm_registers, &fpregs->_xmm, 16 * 16);
156 void UContextReader::FillCPUContext(RawContextCPU *out, const ucontext *uc) {
157 out->context_flags = MD_CONTEXT_ARM_FULL;
159 out->iregs[0] = uc->uc_mcontext.arm_r0;
160 out->iregs[1] = uc->uc_mcontext.arm_r1;
161 out->iregs[2] = uc->uc_mcontext.arm_r2;
162 out->iregs[3] = uc->uc_mcontext.arm_r3;
163 out->iregs[4] = uc->uc_mcontext.arm_r4;
164 out->iregs[5] = uc->uc_mcontext.arm_r5;
165 out->iregs[6] = uc->uc_mcontext.arm_r6;
166 out->iregs[7] = uc->uc_mcontext.arm_r7;
167 out->iregs[8] = uc->uc_mcontext.arm_r8;
168 out->iregs[9] = uc->uc_mcontext.arm_r9;
169 out->iregs[10] = uc->uc_mcontext.arm_r10;
171 out->iregs[11] = uc->uc_mcontext.arm_fp;
172 out->iregs[12] = uc->uc_mcontext.arm_ip;
173 out->iregs[13] = uc->uc_mcontext.arm_sp;
174 out->iregs[14] = uc->uc_mcontext.arm_lr;
175 out->iregs[15] = uc->uc_mcontext.arm_pc;
177 out->cpsr = uc->uc_mcontext.arm_cpsr;
180 out->float_save.fpscr = 0;
181 my_memset(&out->float_save.regs, 0, sizeof(out->float_save.regs));
182 my_memset(&out->float_save.extra, 0, sizeof(out->float_save.extra));
195 void UContextReader::FillCPUContext(RawContextCPU *out, const ucontext *uc,
197 out->context_flags = MD_CONTEXT_ARM64_FULL;
199 out->cpsr = static_cast<uint32_t>(uc->uc_mcontext.pstate);
201 out->iregs[i] = uc->uc_mcontext.regs[i];
202 out->iregs[MD_CONTEXT_ARM64_REG_SP] = uc->uc_mcontext.sp;
203 out->iregs[MD_CONTEXT_ARM64_REG_PC] = uc->uc_mcontext.pc;
205 out->float_save.fpsr = fpregs->fpsr;
206 out->float_save.fpcr = fpregs->fpcr;
207 my_memcpy(&out->float_save.regs, &fpregs->vregs,
221 void UContextReader::FillCPUContext(RawContextCPU *out, const ucontext *uc) {
222 out->context_flags = MD_CONTEXT_MIPS_FULL;
225 out->iregs[i] = uc->uc_mcontext.gregs[i];
227 out->mdhi = uc->uc_mcontext.mdhi;
228 out->mdlo = uc->uc_mcontext.mdlo;
230 out->hi[0] = uc->uc_mcontext.hi1;
231 out->hi[1] = uc->uc_mcontext.hi2;
232 out->hi[2] = uc->uc_mcontext.hi3;
233 out->lo[0] = uc->uc_mcontext.lo1;
234 out->lo[1] = uc->uc_mcontext.lo2;
235 out->lo[2] = uc->uc_mcontext.lo3;
236 out->dsp_control = uc->uc_mcontext.dsp;
238 out->epc = uc->uc_mcontext.pc;
239 out->badvaddr = 0; // Not reported in signal context.
240 out->status = 0; // Not reported in signal context.
241 out->cause = 0; // Not reported in signal context.
244 out->float_save.regs[i] = uc->uc_mcontext.fpregs.fp_r.fp_dregs[i];
246 out->float_save.fpcsr = uc->uc_mcontext.fpc_csr;
248 out->float_save.fir = uc->uc_mcontext.fpc_eir; // Unused.