"drivers/firewire/core-transaction.c" did not exist on "a38a00fdef98a8eda23a25e54490b32865bc7c33"
[PATCH] uml: TLB operation batching
This adds VM op batching to skas0. Rather than having a context switch to and from the userspace stub for each address space change, we write a number of operations to the stub data page and invoke a different stub which loops over them and executes them all in one go. The operations are stored as [ system call number, arg1, arg2, ... ] tuples. The set is terminated by a system call number of 0. Single operations, i.e. page faults, are handled in the old way, since that is slightly more efficient. For a kernel build, a minority (~1/4) of the operations are part of a set. These sets averaged ~100 in length, so for this quarter, the context switching overhead is greatly reduced. Signed-off-by:Jeff Dike <jdike@addtoit.com> Cc: Paolo Giarrusso <blaisorblade@yahoo.it> Signed-off-by:
Andrew Morton <akpm@osdl.org> Signed-off-by:
Linus Torvalds <torvalds@osdl.org>
Showing
- arch/um/include/tlb.h 4 additions, 18 deletionsarch/um/include/tlb.h
- arch/um/kernel/skas/include/skas.h 8 additions, 5 deletionsarch/um/kernel/skas/include/skas.h
- arch/um/kernel/skas/mem_user.c 89 additions, 23 deletionsarch/um/kernel/skas/mem_user.c
- arch/um/kernel/skas/tlb.c 14 additions, 9 deletionsarch/um/kernel/skas/tlb.c
- arch/um/kernel/tlb.c 116 additions, 110 deletionsarch/um/kernel/tlb.c
- arch/um/kernel/tt/tlb.c 4 additions, 1 deletionarch/um/kernel/tt/tlb.c
- arch/um/sys-i386/stub.S 17 additions, 0 deletionsarch/um/sys-i386/stub.S
- arch/um/sys-x86_64/stub.S 21 additions, 0 deletionsarch/um/sys-x86_64/stub.S
Loading
Please register or sign in to comment