x86, setup: Use string copy operation to optimze copy in kernel compression
authorZhao Yakui <yakui.zhao@intel.com>
Fri, 8 Oct 2010 01:47:33 +0000 (09:47 +0800)
committerH. Peter Anvin <hpa@zytor.com>
Fri, 8 Oct 2010 04:23:09 +0000 (21:23 -0700)
commit68f4d5a00adaab33b136fce2c72d5c377b39b0b0
treedfd0404f760ca8ab117117e4388885255b47013b
parentcb655d0f3d57c23db51b981648e452988c0223f9
x86, setup: Use string copy operation to optimze copy in kernel compression

The kernel decompression code parses the ELF header and then copies
the segment to the corresponding destination.  Currently it uses slow
byte-copy code.  This patch makes it use the string copy operations
instead.

In the test the copy performance can be improved very significantly after using
the string copy operation mechanism.
        1. The copy time can be reduced from 150ms to 20ms on one Atom machine
2. The copy time can be reduced about 80% on another machine
The time is reduced from 7ms to 1.5ms when using 32-bit kernel.
The time is reduced from 10ms to 2ms when using 64-bit kernel.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
LKML-Reference: <1286502453-7043-1-git-send-email-yakui.zhao@intel.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
arch/x86/boot/compressed/misc.c