diff options
author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-15 13:40:41 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-15 13:40:41 -0400 |
commit | 419217cb1d0266f62cbea6cdc6b1d1324350bc34 (patch) | |
tree | 01f80c026cc94dfc13b3a16d2fce3ba41c69d54f /arch/x86/kernel/entry_32.S | |
parent | 4937ce87959629d31e9b09cf5bdf1e12a305c805 (diff) | |
parent | 14358e6ddaed27499d7d366b3e65c3e46b39e1c4 (diff) |
Merge branch 'v2.6.24-lockdep' of git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep
* 'v2.6.24-lockdep' of git://git.kernel.org/pub/scm/linux/kernel/git/peterz/linux-2.6-lockdep:
lockdep: annotate dir vs file i_mutex
lockdep: per filesystem inode lock class
lockdep: annotate kprobes irq fiddling
lockdep: annotate rcu_read_{,un}lock{,_bh}
lockdep: annotate journal_start()
lockdep: s390: connect the sysexit hook
lockdep: x86_64: connect the sysexit hook
lockdep: i386: connect the sysexit hook
lockdep: syscall exit check
lockdep: fixup mutex annotations
lockdep: fix mismatched lockdep_depth/curr_chain_hash
lockdep: Avoid /proc/lockdep & lock_stat infinite output
lockdep: maintainers
Diffstat (limited to 'arch/x86/kernel/entry_32.S')
-rw-r--r-- | arch/x86/kernel/entry_32.S | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/arch/x86/kernel/entry_32.S b/arch/x86/kernel/entry_32.S index 290b7bc82da3..8099fea0a72f 100644 --- a/arch/x86/kernel/entry_32.S +++ b/arch/x86/kernel/entry_32.S | |||
@@ -251,6 +251,7 @@ check_userspace: | |||
251 | jb resume_kernel # not returning to v8086 or userspace | 251 | jb resume_kernel # not returning to v8086 or userspace |
252 | 252 | ||
253 | ENTRY(resume_userspace) | 253 | ENTRY(resume_userspace) |
254 | LOCKDEP_SYS_EXIT | ||
254 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt | 255 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt |
255 | # setting need_resched or sigpending | 256 | # setting need_resched or sigpending |
256 | # between sampling and the iret | 257 | # between sampling and the iret |
@@ -338,6 +339,7 @@ sysenter_past_esp: | |||
338 | jae syscall_badsys | 339 | jae syscall_badsys |
339 | call *sys_call_table(,%eax,4) | 340 | call *sys_call_table(,%eax,4) |
340 | movl %eax,PT_EAX(%esp) | 341 | movl %eax,PT_EAX(%esp) |
342 | LOCKDEP_SYS_EXIT | ||
341 | DISABLE_INTERRUPTS(CLBR_ANY) | 343 | DISABLE_INTERRUPTS(CLBR_ANY) |
342 | TRACE_IRQS_OFF | 344 | TRACE_IRQS_OFF |
343 | movl TI_flags(%ebp), %ecx | 345 | movl TI_flags(%ebp), %ecx |
@@ -377,6 +379,7 @@ syscall_call: | |||
377 | call *sys_call_table(,%eax,4) | 379 | call *sys_call_table(,%eax,4) |
378 | movl %eax,PT_EAX(%esp) # store the return value | 380 | movl %eax,PT_EAX(%esp) # store the return value |
379 | syscall_exit: | 381 | syscall_exit: |
382 | LOCKDEP_SYS_EXIT | ||
380 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt | 383 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt |
381 | # setting need_resched or sigpending | 384 | # setting need_resched or sigpending |
382 | # between sampling and the iret | 385 | # between sampling and the iret |
@@ -467,6 +470,7 @@ work_pending: | |||
467 | jz work_notifysig | 470 | jz work_notifysig |
468 | work_resched: | 471 | work_resched: |
469 | call schedule | 472 | call schedule |
473 | LOCKDEP_SYS_EXIT | ||
470 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt | 474 | DISABLE_INTERRUPTS(CLBR_ANY) # make sure we don't miss an interrupt |
471 | # setting need_resched or sigpending | 475 | # setting need_resched or sigpending |
472 | # between sampling and the iret | 476 | # between sampling and the iret |