diff options
author | David Mosberger-Tang <davidm@hpl.hp.com> | 2005-04-28 06:19:04 +0200 |
---|---|---|
committer | Tony Luck <tony.luck@intel.com> | 2005-04-28 06:19:04 +0200 |
commit | f8fa5448fc9b4a7806b1297a0b57808f12fe4d43 (patch) | |
tree | b32f9939ee3b72010e4c3255d58278f85c547a7e /net/bridge/br_if.c | |
parent | [IA64] In ia64_leave_syscall(), fix comments and whitespace only. (diff) | |
download | linux-f8fa5448fc9b4a7806b1297a0b57808f12fe4d43.tar.xz linux-f8fa5448fc9b4a7806b1297a0b57808f12fe4d43.zip |
[IA64] Reschedule break_fault() for better performance.
This patch reorganizes break_fault() to optimistically assume that a
system-call is being performed from user-space (which is almost always
the case). If it turns out that (a) we're not being called due to a
system call or (b) we're being called from within the kernel, we fixup
the no-longer-valid assumptions in non_syscall() and .break_fixup(),
respectively.
With this approach, there are 3 major phases:
- Phase 1: Read various control & application registers, in
particular the current task pointer from AR.K6.
- Phase 2: Do all memory loads (load system-call entry,
load current_thread_info()->flags, prefetch
kernel register-backing store) and switch
to kernel register-stack.
- Phase 3: Call ia64_syscall_setup() and invoke
syscall-handler.
Good for 26-30 cycles of improvement on break-based syscall-path.
Signed-off-by: David Mosberger-Tang <davidm@hpl.hp.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
Diffstat (limited to 'net/bridge/br_if.c')
0 files changed, 0 insertions, 0 deletions