linux/arch/x86/kernel
Roland McGrath e1f287735c x86 single_step: TIF_FORCED_TF
This changes the single-step support to use a new thread_info flag
TIF_FORCED_TF instead of the PT_DTRACE flag in task_struct.ptrace.
This keeps arch implementation uses out of this non-arch field.

This changes the ptrace access to eflags to mask TF and maintain
the TIF_FORCED_TF flag directly if userland sets TF, instead of
relying on ptrace_signal_deliver.  The 64-bit and 32-bit kernels
are harmonized on this same behavior.  The ptrace_signal_deliver
approach works now, but this change makes the low-level register
access code reliable when called from different contexts than a
ptrace stop, which will be possible in the future.

The 64-bit do_debug exception handler is also changed not to clear TF
from user-mode registers.  This matches the 32-bit kernel's behavior.

Signed-off-by: Roland McGrath <roland@redhat.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
2008-01-30 13:30:50 +01:00
..
acpi ACPI: suspend: old debugging hacks sneaked back 2007-12-06 16:03:06 -05:00
cpu x86: fall back on interrupt disable in cmpxchg8b on 80386 and 80486 2008-01-30 13:30:47 +01:00
.gitignore
alternative.c
aperture_64.c x86: clean up arch/x86/kernel/aperture_64.c printk()s 2008-01-30 13:30:10 +01:00
apic_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
apic_64.c x86: extended interrupt LVT support for AMD Barcelona 2008-01-30 13:30:40 +01:00
apm_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
asm-offsets_32.c x86 vDSO: i386 vdso32 2008-01-30 13:30:42 +01:00
asm-offsets_64.c x86 vDSO: ia32 sysenter_return 2008-01-30 13:30:43 +01:00
asm-offsets.c
audit_64.c
bootflag.c
bugs_64.c
cpuid.c PM: Acquire device locks on suspend 2008-01-24 20:40:04 -08:00
crash_dump_32.c
crash_dump_64.c
crash.c x86: disable hpet legacy replacement for kdump 2007-12-03 17:17:10 +01:00
doublefault_32.c
e820_32.c x86: remove extern declarations for code, data, bss resources 2008-01-30 13:30:32 +01:00
e820_64.c x86: sanitize user specified e820 memmap values 2008-01-30 13:30:46 +01:00
early_printk.c
early-quirks.c x86 gart: rename symbols only used for the GART implementation 2007-10-30 00:22:22 +01:00
efi_32.c
efi_stub_32.S
entry_32.S x86 vDSO: ia32_sysenter_target 2008-01-30 13:30:43 +01:00
entry_64.S sched: high-res preemption tick 2008-01-25 21:08:29 +01:00
genapic_64.c
genapic_flat_64.c
geode_32.c
head64.c x86: do not set boot cpu in cpu_online_map at x86_64_start_kernel() 2008-01-30 13:30:46 +01:00
head_32.S fix lguest rmmod "bad pgd" 2008-01-01 11:30:35 -08:00
head_64.S
hpet.c x86: remove duplicate includes 2008-01-30 13:30:32 +01:00
i386_ksyms_32.c x86: unexport __{read,write}_lock_failed 2008-01-30 13:30:29 +01:00
i387_32.c
i387_64.c x86: fix taking DNA during 64bit sigreturn 2007-11-12 11:09:33 -08:00
i8237.c Driver core: change sysdev classes to use dynamic kobject names 2008-01-24 20:40:40 -08:00
i8253.c mips, x86: optimize the i8259 code a bit 2008-01-30 13:30:47 +01:00
i8259_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
i8259_64.c x86: make i8259_64 more _32-like 2008-01-30 13:30:29 +01:00
init_task.c x86: nuke a ton of unused exports 2008-01-30 13:30:28 +01:00
io_apic_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
io_apic_64.c x86: clear IO_APIC before enabing apic error vector. 2008-01-30 13:30:39 +01:00
io_delay.c x86: add DMI quirk for io-delay hangs on Compaq Presario V6000 laptops 2008-01-30 13:30:05 +01:00
ioport_32.c x86: clean up ioport_32.c 2008-01-30 13:30:24 +01:00
ioport_64.c
irq_32.c
irq_64.c x86: move ack_bad_irq into irq code 2008-01-30 13:30:19 +01:00
k8.c
kprobes_32.c x86: jprobe bugfix 2007-12-18 18:05:58 +01:00
kprobes_64.c x86: kprobes bugfix 2007-12-18 18:05:58 +01:00
ldt.c x86: merge arch/x86/kernel/ldt_32/64.c 2008-01-30 13:30:14 +01:00
machine_kexec_32.c
machine_kexec_64.c x86: 64-bit, make sparsemem vmemmap the only memory model 2008-01-30 13:30:47 +01:00
Makefile
Makefile_32 x86: single_step: share code 2008-01-30 13:30:50 +01:00
Makefile_64 x86: single_step moved 2008-01-30 13:30:50 +01:00
mca_32.c
mfgpt_32.c x86: GEODE fix a race condition in the MFGPT timer tick 2008-01-22 23:30:16 +01:00
microcode.c cpu-hotplug: replace lock_cpu_hotplug() with get_online_cpus() 2008-01-25 21:08:02 +01:00
module_32.c
module_64.c
mpparse_32.c x86: cleanup mpspec variants 2008-01-30 13:30:35 +01:00
mpparse_64.c
msr.c PM: Acquire device locks on suspend 2008-01-24 20:40:04 -08:00
nmi_32.c x86: clean up nmi_32/64.c 2008-01-30 13:30:33 +01:00
nmi_64.c x86: clean up nmi_32/64.c 2008-01-30 13:30:33 +01:00
numaq_32.c
paravirt_32.c x86: irqflags consolidation 2008-01-30 13:30:33 +01:00
pci-calgary_64.c x86: remove duplicate includes 2008-01-30 13:30:32 +01:00
pci-dma_32.c
pci-dma_64.c x86: pci-dma_64.c: cleanups 2008-01-30 13:30:31 +01:00
pci-gart_64.c x86: code cleanups in arch/x86/kernel/pci-gart_64.c 2008-01-30 13:30:12 +01:00
pci-nommu_64.c x86 gart: rename iommu.h to gart.h 2007-10-30 00:22:22 +01:00
pci-swiotlb_64.c x86: nuke a ton of unused exports 2008-01-30 13:30:28 +01:00
pcspeaker.c
pmtimer_64.c x86: move pmtmr related declarations 2008-01-30 13:30:18 +01:00
process_32.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
process_64.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
ptrace_32.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
ptrace_64.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
quirks.c x86: Add HPET force support for MCP55 (nForce 5) chipsets 2007-10-23 22:37:25 +02:00
reboot_32.c x86: disable hpet on shutdown 2007-12-03 17:17:10 +01:00
reboot_64.c x86: disable hpet on shutdown 2007-12-03 17:17:10 +01:00
reboot_fixups_32.c x86: reboot fixup for wrap2c board 2007-11-17 16:27:02 +01:00
relocate_kernel_32.S
relocate_kernel_64.S
rtc.c x86: share rtc code 2008-01-30 13:30:27 +01:00
scx200_32.c
setup64.c
setup_32.c x86: remove extern declarations for code, data, bss resources 2008-01-30 13:30:32 +01:00
setup_64.c x86: store core id bits in cpuinfo_x8 2008-01-30 13:30:39 +01:00
sigframe_32.h
signal_32.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
signal_64.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
smp_32.c x86: export smp_ops to allow modular build of KVM 2007-10-27 20:57:43 +02:00
smp_64.c x86: cleanup tlbflush.h variants 2008-01-30 13:30:35 +01:00
smpboot_32.c x86: adjust numa 32 namespace 2008-01-30 13:30:38 +01:00
smpboot_64.c x86: set cpu_index to nr_cpus instead of 0 2008-01-30 13:30:46 +01:00
smpcommon_32.c
srat_32.c
stacktrace.c x86: nuke a ton of unused exports 2008-01-30 13:30:28 +01:00
step.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
summit_32.c
suspend_64.c x86: hibernation: document __save_processor_state() on x86 2008-01-30 13:30:04 +01:00
suspend_asm_64.S x86: Save registers in saved_context during suspend and hibernation 2007-10-23 22:37:24 +02:00
sys_i386_32.c
sys_x86_64.c
syscall_64.c
syscall_table_32.S
tce_64.c
time_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
time_64.c x86: clean up arch/x86/kernel/time_64.c includes 2008-01-30 13:30:27 +01:00
tls.c x86: TLS cleanup 2008-01-30 13:30:46 +01:00
topology.c x86: arch_register_cpu() section fix 2007-12-04 17:19:07 +01:00
trampoline_32.S
trampoline_64.S
traps_32.c lockdep: more hardirq annotations for notify_die() 2008-01-16 09:51:59 +01:00
traps_64.c x86 single_step: TIF_FORCED_TF 2008-01-30 13:30:50 +01:00
tsc_32.c x86: scale cyc_2_nsec according to CPU frequency 2008-01-30 13:30:06 +01:00
tsc_64.c x86: scale cyc_2_nsec according to CPU frequency 2008-01-30 13:30:06 +01:00
tsc_sync.c x86: fix: s2ram + P4 + tsc = annoyance 2008-01-30 13:30:04 +01:00
verify_cpu_64.S
vm86_32.c
vmi_32.c x86: irqflags consolidation 2008-01-30 13:30:33 +01:00
vmiclock_32.c x86: move 8259 defines to i8259.h 2008-01-30 13:30:29 +01:00
vmlinux_32.lds.S x86: vmlinux_32.lds.S: remove repeated comment from the x86-32 linker script 2008-01-30 13:30:46 +01:00
vmlinux_64.lds.S all archs: consolidate init and exit sections in vmlinux.lds.h 2008-01-28 23:21:17 +01:00
vmlinux.lds.S
vsmp_64.c x86: clean up arch/x86/kernel/vsmp_64.c 2008-01-30 13:30:24 +01:00
vsyscall_64.c
x8664_ksyms_64.c x86: unexport __{read,write}_lock_failed 2008-01-30 13:30:29 +01:00