Home
last modified time | relevance | path

Searched refs:dr7 (Results 1 – 25 of 28) sorted by relevance

12

/linux-6.15/arch/x86/include/asm/
H A Ddebugreg.h122 unsigned long dr7; in local_db_save() local
127 get_debugreg(dr7, 7); in local_db_save()
128 dr7 &= ~0x400; /* architecturally set bit */ in local_db_save()
129 if (dr7) in local_db_save()
138 return dr7; in local_db_save()
141 static __always_inline void local_db_restore(unsigned long dr7) in local_db_restore() argument
149 if (dr7) in local_db_restore()
150 set_debugreg(dr7, 7); in local_db_restore()
H A Dhw_breakpoint.h70 int decode_dr7(unsigned long dr7, int bpnum, unsigned *len, unsigned *type);
H A Dsvm.h323 u64 dr7; member
380 u64 dr7; member
471 u64 dr7; member
H A Dkvm_host.h960 unsigned long dr7; member
/linux-6.15/arch/x86/kernel/
H A Dhw_breakpoint.c79 int bp_info = dr7 >> (DR_CONTROL_SHIFT + bpnum * DR_CONTROL_SIZE); in decode_dr7()
84 return (dr7 >> (bpnum * DR_ENABLE_SIZE)) & 0x3; in decode_dr7()
99 unsigned long *dr7; in arch_install_hw_breakpoint() local
119 dr7 = this_cpu_ptr(&cpu_dr7); in arch_install_hw_breakpoint()
120 *dr7 |= encode_dr7(i, info->len, info->type); in arch_install_hw_breakpoint()
128 set_debugreg(*dr7, 7); in arch_install_hw_breakpoint()
147 unsigned long dr7; in arch_uninstall_hw_breakpoint() local
164 dr7 = this_cpu_read(cpu_dr7); in arch_uninstall_hw_breakpoint()
165 dr7 &= ~__encode_dr7(i, info->len, info->type); in arch_uninstall_hw_breakpoint()
167 set_debugreg(dr7, 7); in arch_uninstall_hw_breakpoint()
[all …]
H A Dptrace.c498 int dr7 = 0; in ptrace_get_dr7() local
504 dr7 |= encode_dr7(i, info->len, info->type); in ptrace_get_dr7()
508 return dr7; in ptrace_get_dr7()
H A Dtraps.c1104 unsigned long dr7 = local_db_save(); in exc_debug_kernel() local
1162 local_db_restore(dr7); in exc_debug_kernel()
/linux-6.15/tools/perf/arch/x86/tests/
H A Dbp-modify.c63 unsigned long rip = 0, dr7 = 1; in bp_modify1() local
96 offsetof(struct user, u_debugreg[7]), dr7)) { in bp_modify1()
140 unsigned long rip = 0, dr7 = 1; in bp_modify2() local
166 offsetof(struct user, u_debugreg[7]), dr7)) { in bp_modify2()
/linux-6.15/tools/testing/selftests/x86/
H A Dmov_ss_trap.c64 unsigned long dr0, dr1, dr7; in enable_watchpoint() local
68 dr7 = ((1UL << 1) | /* G0 */ in enable_watchpoint()
85 if (ptrace(PTRACE_POKEUSER, parent, (void *)offsetof(struct user, u_debugreg[7]), dr7) != 0) in enable_watchpoint()
88 printf("\tDR0 = %lx, DR1 = %lx, DR7 = %lx\n", dr0, dr1, dr7); in enable_watchpoint()
/linux-6.15/tools/testing/selftests/breakpoints/
H A Dbreakpoint_test.c59 unsigned long vdr7, dr7; in toggle_breakpoint() local
88 dr7 = ptrace(PTRACE_PEEKUSER, child_pid, in toggle_breakpoint()
104 dr7 |= vdr7; in toggle_breakpoint()
106 dr7 &= ~vdr7; in toggle_breakpoint()
109 offsetof(struct user, u_debugreg[7]), dr7); in toggle_breakpoint()
/linux-6.15/arch/x86/kvm/
H A Dsmm.c52 CHECK_SMRAM32_OFFSET(dr7, 0xFFC8); in check_smram_offsets()
99 CHECK_SMRAM64_OFFSET(dr7, 0xFF60); in check_smram_offsets()
199 smram->dr7 = (u32)vcpu->arch.dr7; in enter_smm_save_state_32()
241 smram->dr7 = vcpu->arch.dr7; in enter_smm_save_state_64()
475 if (kvm_set_dr(vcpu, 7, smstate->dr7)) in rsm_load_state_32()
527 if (kvm_set_dr(vcpu, 7, smstate->dr7)) in rsm_load_state_64()
H A Dsmm.h59 u32 dr7; member
130 u64 dr7; member
H A Dx86.c1483 unsigned long dr7; in kvm_update_dr7() local
1488 dr7 = vcpu->arch.dr7; in kvm_update_dr7()
1491 if (dr7 & DR7_BP_EN_MASK) in kvm_update_dr7()
1549 return vcpu->arch.dr7; in kvm_get_dr()
5559 dbgregs->dr7 = vcpu->arch.dr7; in kvm_vcpu_ioctl_x86_get_debugregs()
5585 vcpu->arch.dr7 = dbgregs->dr7; in kvm_vcpu_ioctl_x86_set_debugregs()
8928 enable = dr7; in kvm_vcpu_check_hw_bp()
8929 rwlen = dr7 >> 16; in kvm_vcpu_check_hw_bp()
9036 vcpu->arch.dr7, in kvm_vcpu_check_code_breakpoint()
10386 vcpu->arch.dr7 &= ~DR7_GD; in kvm_check_and_inject_events()
[all …]
H A Demulate.c2908 ulong desc_addr, dr7; in emulator_do_task_switch() local
2992 dr7 = ops->get_dr(ctxt, 7); in emulator_do_task_switch()
2993 ops->set_dr(ctxt, 7, dr7 & ~(DR_LOCAL_ENABLE_MASK | DR_LOCAL_SLOWDOWN)); in emulator_do_task_switch()
/linux-6.15/arch/x86/kernel/cpu/mce/
H A Dcore.c2224 unsigned long dr7; in DEFINE_IDTENTRY_MCE() local
2226 dr7 = local_db_save(); in DEFINE_IDTENTRY_MCE()
2228 local_db_restore(dr7); in DEFINE_IDTENTRY_MCE()
2234 unsigned long dr7; in DEFINE_IDTENTRY_MCE_USER() local
2236 dr7 = local_db_save(); in DEFINE_IDTENTRY_MCE_USER()
2238 local_db_restore(dr7); in DEFINE_IDTENTRY_MCE_USER()
2255 unsigned long dr7; in DEFINE_FREDENTRY_MCE() local
2257 dr7 = local_db_save(); in DEFINE_FREDENTRY_MCE()
2262 local_db_restore(dr7); in DEFINE_FREDENTRY_MCE()
2269 unsigned long dr7; in DEFINE_IDTENTRY_RAW() local
[all …]
/linux-6.15/arch/x86/kvm/svm/
H A Dnested.c298 if (CC(!kvm_dr6_valid(save->dr6)) || CC(!kvm_dr7_valid(save->dr7))) in __nested_vmcb_check_save()
405 to->dr7 = from->dr7; in __nested_copy_vmcb_save_to_cache()
592 vmcb02->save.dr7 = svm->nested.save.dr7 | DR7_FIXED_1; in nested_vmcb02_prepare_save()
1016 vmcb12->save.dr7 = vmcb02->save.dr7; in nested_svm_vmexit()
1123 svm->vcpu.arch.dr7 = DR7_FIXED_1; in nested_svm_vmexit()
1409 if (vcpu->arch.dr7 & DR7_GD) { in nested_svm_inject_exception_vmexit()
1410 vcpu->arch.dr7 &= ~DR7_GD; in nested_svm_inject_exception_vmexit()
H A Dsvm.c2090 vcpu->arch.dr7 = svm->vmcb->save.dr7; in svm_sync_dirty_debug_regs()
2102 svm->vmcb->save.dr7 = value; in svm_set_dr7()
2174 kvm_run->debug.arch.dr7 = svm->vmcb->save.dr7; in db_interception()
3553 "dr6:", save->dr6, "dr7:", save->dr7); in dump_vmcb()
H A Dsvm.h143 u64 dr7; member
/linux-6.15/tools/testing/selftests/kvm/lib/x86/
H A Dsvm.c93 asm volatile ("mov %%dr7, %0" : "=r"(save->dr7) : : "memory"); in generic_svm_setup()
/linux-6.15/tools/testing/selftests/kvm/include/x86/
H A Dsvm.h208 u64 dr7; member
/linux-6.15/arch/x86/include/uapi/asm/
H A Dkvm.h290 __u64 dr7; member
375 __u64 dr7; member
/linux-6.15/tools/arch/x86/include/uapi/asm/
H A Dkvm.h290 __u64 dr7; member
375 __u64 dr7; member
/linux-6.15/arch/x86/coco/sev/
H A Dcore.c142 unsigned long dr7; member
1365 vmsa->dr7 = DR7_RESET_VALUE; in wakeup_cpu_via_vmgexit()
2033 data->dr7 = val; in vc_handle_dr7_write()
2051 *reg = data->dr7; in vc_handle_dr7_read()
/linux-6.15/include/hyperv/
H A Dhvhdk.h107 u64 dr7; member
/linux-6.15/arch/x86/kvm/vmx/
H A Dvmx.c5373 kvm_run->debug.arch.dr7 = vmcs_readl(GUEST_DR7); in handle_exception_nmi()
5593 int dr, dr7, reg; in handle_dr() local
5606 dr7 = vmcs_readl(GUEST_DR7); in handle_dr()
5607 if (dr7 & DR7_GD) { in handle_dr()
5615 vcpu->run->debug.arch.dr7 = dr7; in handle_dr()
5657 vcpu->arch.dr7 = vmcs_readl(GUEST_DR7); in vmx_sync_dirty_debug_regs()

12