5a79f472c7
Migrate to GNU General Public License Version 3. * COPYING: Replaced with the plain text version of GPLv3. * config.guess: Updated from gnulib. * config.sub: Likewise. * geninit.sh: Output a GPLv3 copyright notice. * geninitheader.sh: Likewise. * genmodsrc.sh: Likewise. * gensymlist.sh.in: Likewise. * boot/i386/pc/boot.S: Upgraded to GPLv3. * boot/i386/pc/diskboot.S: Likewise. * boot/i386/pc/pxeboot.S: Likewise. * commands/blocklist.c: Likewise. * commands/boot.c: Likewise. * commands/cat.c: Likewise. * commands/cmp.c: Likewise. * commands/configfile.c: Likewise. * commands/echo.c: Likewise. * commands/help.c: Likewise. * commands/ls.c: Likewise. * commands/search.c: Likewise. * commands/terminal.c: Likewise. * commands/test.c: Likewise. * commands/videotest.c: Likewise. * commands/i386/cpuid.c: Likewise. * commands/i386/pc/halt.c: Likewise. * commands/i386/pc/play.c: Likewise. * commands/i386/pc/reboot.c: Likewise. * commands/i386/pc/vbeinfo.c: Likewise. * commands/i386/pc/vbetest.c: Likewise. * commands/ieee1275/halt.c: Likewise. * commands/ieee1275/reboot.c: Likewise. * commands/ieee1275/suspend.c: Likewise. * disk/loopback.c: Likewise. * disk/lvm.c: Likewise. * disk/raid.c: Likewise. * disk/efi/efidisk.c: Likewise. * disk/i386/pc/biosdisk.c: Likewise. * disk/ieee1275/ofdisk.c: Likewise. * font/manager.c: Likewise. * fs/affs.c: Likewise. * fs/ext2.c: Likewise. * fs/fat.c: Likewise. * fs/fshelp.c: Likewise. * fs/hfs.c: Likewise. * fs/hfsplus.c: Likewise. * fs/iso9660.c: Likewise. * fs/jfs.c: Likewise. * fs/minix.c: Likewise. * fs/sfs.c: Likewise. * fs/ufs.c: Likewise. * fs/xfs.c: Likewise. * hello/hello.c: Likewise. * include/grub/acorn_filecore.h: Likewise. * include/grub/arg.h: Likewise. * include/grub/bitmap.h: Likewise. * include/grub/boot.h: Likewise. * include/grub/cache.h: Likewise. * include/grub/device.h: Likewise. * include/grub/disk.h: Likewise. * include/grub/dl.h: Likewise. * include/grub/elfload.h: Likewise. * include/grub/env.h: Likewise. * include/grub/err.h: Likewise. * include/grub/file.h: Likewise. * include/grub/font.h: Likewise. * include/grub/fs.h: Likewise. * include/grub/fshelp.h: Likewise. * include/grub/gzio.h: Likewise. * include/grub/hfs.h: Likewise. * include/grub/kernel.h: Likewise. * include/grub/loader.h: Likewise. * include/grub/lvm.h: Likewise. * include/grub/misc.h: Likewise. * include/grub/mm.h: Likewise. * include/grub/net.h: Likewise. * include/grub/normal.h: Likewise. * include/grub/parser.h: Likewise. * include/grub/partition.h: Likewise. * include/grub/pc_partition.h: Likewise. * include/grub/raid.h: Likewise. * include/grub/rescue.h: Likewise. * include/grub/script.h: Likewise. * include/grub/setjmp.h: Likewise. * include/grub/symbol.h: Likewise. * include/grub/term.h: Likewise. * include/grub/terminfo.h: Likewise. * include/grub/tparm.h: Likewise. * include/grub/types.h: Likewise. * include/grub/video.h: Likewise. * include/grub/efi/api.h: Likewise. * include/grub/efi/chainloader.h: Likewise. * include/grub/efi/console.h: Likewise. * include/grub/efi/console_control.h: Likewise. * include/grub/efi/disk.h: Likewise. * include/grub/efi/efi.h: Likewise. * include/grub/efi/pe32.h: Likewise. * include/grub/efi/time.h: Likewise. * include/grub/i386/linux.h: Likewise. * include/grub/i386/setjmp.h: Likewise. * include/grub/i386/types.h: Likewise. * include/grub/i386/efi/kernel.h: Likewise. * include/grub/i386/efi/loader.h: Likewise. * include/grub/i386/efi/time.h: Likewise. * include/grub/i386/pc/biosdisk.h: Likewise. * include/grub/i386/pc/boot.h: Likewise. * include/grub/i386/pc/chainloader.h: Likewise. * include/grub/i386/pc/console.h: Likewise. * include/grub/i386/pc/init.h: Likewise. * include/grub/i386/pc/kernel.h: Likewise. * include/grub/i386/pc/loader.h: Likewise. * include/grub/i386/pc/memory.h: Likewise. * include/grub/i386/pc/multiboot.h: Likewise. * include/grub/i386/pc/serial.h: Likewise. * include/grub/i386/pc/time.h: Likewise. * include/grub/i386/pc/vbe.h: Likewise. * include/grub/i386/pc/vbeblit.h: Likewise. * include/grub/i386/pc/vbefill.h: Likewise. * include/grub/i386/pc/vbeutil.h: Likewise. * include/grub/i386/pc/vga.h: Likewise. * include/grub/ieee1275/ieee1275.h: Likewise. * include/grub/ieee1275/ofdisk.h: Likewise. * include/grub/powerpc/libgcc.h: Likewise. * include/grub/powerpc/setjmp.h: Likewise. * include/grub/powerpc/types.h: Likewise. * include/grub/powerpc/ieee1275/biosdisk.h: Likewise. * include/grub/powerpc/ieee1275/console.h: Likewise. * include/grub/powerpc/ieee1275/ieee1275.h: Likewise. * include/grub/powerpc/ieee1275/kernel.h: Likewise. * include/grub/powerpc/ieee1275/loader.h: Likewise. * include/grub/powerpc/ieee1275/multiboot.h: Likewise. * include/grub/powerpc/ieee1275/time.h: Likewise. * include/grub/powerpc/ieee1275/util/biosdisk.h: Likewise. * include/grub/sparc64/libgcc.h: Likewise. * include/grub/sparc64/setjmp.h: Likewise. * include/grub/sparc64/types.h: Likewise. * include/grub/sparc64/ieee1275/console.h: Likewise. * include/grub/sparc64/ieee1275/ieee1275.h: Likewise. * include/grub/sparc64/ieee1275/kernel.h: Likewise. * include/grub/sparc64/ieee1275/time.h: Likewise. * include/grub/util/biosdisk.h: Likewise. * include/grub/util/getroot.h: Likewise. * include/grub/util/lvm.h: Likewise. * include/grub/util/misc.h: Likewise. * include/grub/util/raid.h: Likewise. * include/grub/util/resolve.h: Likewise. * io/gzio.c: Likewise. * kern/device.c: Likewise. * kern/disk.c: Likewise. * kern/dl.c: Likewise. * kern/elf.c: Likewise. * kern/env.c: Likewise. * kern/err.c: Likewise. * kern/file.c: Likewise. * kern/fs.c: Likewise. * kern/loader.c: Likewise. * kern/main.c: Likewise. * kern/misc.c: Likewise. * kern/mm.c: Likewise. * kern/parser.c: Likewise. * kern/partition.c: Likewise. * kern/rescue.c: Likewise. * kern/term.c: Likewise. * kern/efi/efi.c: Likewise. * kern/efi/init.c: Likewise. * kern/efi/mm.c: Likewise. * kern/i386/dl.c: Likewise. * kern/i386/efi/init.c: Likewise. * kern/i386/efi/startup.S: Likewise. * kern/i386/pc/init.c: Likewise. * kern/i386/pc/lzo1x.S: Likewise. * kern/i386/pc/startup.S: Likewise. * kern/ieee1275/ieee1275.c: Likewise. * kern/powerpc/cache.S: Likewise. * kern/powerpc/dl.c: Likewise. * kern/powerpc/ieee1275/cmain.c: Likewise. * kern/powerpc/ieee1275/crt0.S: Likewise. * kern/powerpc/ieee1275/init.c: Likewise. * kern/powerpc/ieee1275/openfw.c: Likewise. * kern/sparc64/cache.S: Likewise. * kern/sparc64/dl.c: Likewise. * kern/sparc64/ieee1275/init.c: Likewise. * kern/sparc64/ieee1275/openfw.c: Likewise. * loader/efi/chainloader.c: Likewise. * loader/efi/chainloader_normal.c: Likewise. * loader/i386/efi/linux.c: Likewise. * loader/i386/efi/linux_normal.c: Likewise. * loader/i386/pc/chainloader.c: Likewise. * loader/i386/pc/chainloader_normal.c: Likewise. * loader/i386/pc/linux.c: Likewise. * loader/i386/pc/linux_normal.c: Likewise. * loader/i386/pc/multiboot.c: Likewise. * loader/i386/pc/multiboot_normal.c: Likewise. * loader/powerpc/ieee1275/linux.c: Likewise. * loader/powerpc/ieee1275/linux_normal.c: Likewise. * normal/arg.c: Likewise. * normal/cmdline.c: Likewise. * normal/command.c: Likewise. * normal/completion.c: Likewise. * normal/execute.c: Likewise. * normal/function.c: Likewise. * normal/lexer.c: Likewise. * normal/main.c: Likewise. * normal/menu.c: Likewise. * normal/menu_entry.c: Likewise. * normal/misc.c: Likewise. * normal/parser.y: Likewise. * normal/script.c: Likewise. * normal/i386/setjmp.S: Likewise. * normal/powerpc/setjmp.S: Likewise. * normal/sparc64/setjmp.S: Likewise. * partmap/acorn.c: Likewise. * partmap/amiga.c: Likewise. * partmap/apple.c: Likewise. * partmap/gpt.c: Likewise. * partmap/pc.c: Likewise. * partmap/sun.c: Likewise. * term/gfxterm.c: Likewise. * term/terminfo.c: Likewise. * term/efi/console.c: Likewise. * term/i386/pc/console.c: Likewise. * term/i386/pc/serial.c: Likewise. * term/i386/pc/vesafb.c: Likewise. * term/i386/pc/vga.c: Likewise. * term/ieee1275/ofconsole.c: Likewise. * util/biosdisk.c: Likewise. * util/console.c: Likewise. * util/genmoddep.c: Likewise. * util/getroot.c: Likewise. * util/grub-emu.c: Likewise. * util/grub-mkdevicemap.c: Likewise. * util/grub-probe.c: Likewise. * util/lvm.c: Likewise. * util/misc.c: Likewise. * util/raid.c: Likewise. * util/resolve.c: Likewise. * util/update-grub.in: Likewise. * util/update-grub_lib.in: Likewise. * util/grub.d/00_header.in: Likewise. * util/grub.d/10_hurd.in: Likewise. * util/grub.d/10_linux.in: Likewise. * util/i386/efi/grub-install.in: Likewise. * util/i386/efi/grub-mkimage.c: Likewise. * util/i386/pc/grub-install.in: Likewise. * util/i386/pc/grub-mkimage.c: Likewise. * util/i386/pc/grub-mkrescue.in: Likewise. * util/i386/pc/grub-setup.c: Likewise. * util/i386/pc/misc.c: Likewise. * util/powerpc/ieee1275/grub-install.in: Likewise. * util/powerpc/ieee1275/grub-mkimage.c: Likewise. * util/powerpc/ieee1275/misc.c: Likewise. * video/bitmap.c: Likewise. * video/video.c: Likewise. * video/i386/pc/vbe.c: Likewise. * video/i386/pc/vbeblit.c: Likewise. * video/i386/pc/vbefill.c: Likewise. * video/i386/pc/vbeutil.c: Likewise. * video/readers/tga.c: Likewise.
322 lines
6 KiB
ArmAsm
322 lines
6 KiB
ArmAsm
/*
|
|
* GRUB -- GRand Unified Bootloader
|
|
* Copyright (C) 1996-2002 Markus Franz Xaver Johannes Oberhumer
|
|
* Copyright (C) 2003,2007 Free Software Foundation, Inc.
|
|
*
|
|
* GRUB is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GRUB is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/*
|
|
* This code was stolen from the files enter.sh, leave.sh, lzo1x_d.sh,
|
|
* lzo1x_f.s and lzo_asm.h in LZO version 1.08, and was heavily modified
|
|
* to adapt it to GRUB's requirement.
|
|
*
|
|
* See <http://www.oberhumer.com/opensource/lzo/>, for more information
|
|
* about LZO.
|
|
*/
|
|
|
|
#define INP 4+16(%esp)
|
|
#define INS 8+16(%esp)
|
|
#define OUTP 12+16(%esp)
|
|
#define NN 3
|
|
#define N_3 %ebp
|
|
#define N_255 $255
|
|
#define LODSB movb (%esi), %al ; incl %esi
|
|
#define NOTL_3(r) xorl N_3, r
|
|
#define MOVSL(r1,r2,x) movl (r1), x ; addl $4, r1 ; movl x, (r2) ; addl $4, r2
|
|
#define COPYL_C(r1,r2,x,rc) 9: MOVSL(r1,r2,x) ; decl rc ; jnz 9b
|
|
#define COPYL(r1,r2,x) COPYL_C(r1,r2,x,%ecx)
|
|
|
|
lzo1x_decompress:
|
|
pushl %ebp
|
|
pushl %edi
|
|
pushl %esi
|
|
pushl %ebx
|
|
|
|
cld
|
|
|
|
movl INP, %esi
|
|
movl OUTP, %edi
|
|
movl $3, %ebp
|
|
|
|
|
|
xorl %eax, %eax
|
|
xorl %ebx, %ebx /* high bits 9-32 stay 0 */
|
|
lodsb
|
|
cmpb $17, %al
|
|
jbe .L01
|
|
subb $17-NN, %al
|
|
jmp .LFLR
|
|
|
|
|
|
/***********************************************************************
|
|
// literal run
|
|
************************************************************************/
|
|
|
|
0: addl N_255, %eax
|
|
1: movb (%esi), %bl
|
|
incl %esi
|
|
orb %bl, %bl
|
|
jz 0b
|
|
leal 18+NN(%eax,%ebx), %eax
|
|
jmp 3f
|
|
|
|
|
|
.align 8
|
|
.L00:
|
|
LODSB
|
|
.L01:
|
|
cmpb $16, %al
|
|
jae .LMATCH
|
|
|
|
/* a literal run */
|
|
orb %al, %al
|
|
jz 1b
|
|
addl $3+NN, %eax
|
|
3:
|
|
.LFLR:
|
|
movl %eax, %ecx
|
|
NOTL_3(%eax)
|
|
shrl $2, %ecx
|
|
andl N_3, %eax
|
|
COPYL(%esi,%edi,%edx)
|
|
subl %eax, %esi
|
|
subl %eax, %edi
|
|
|
|
LODSB
|
|
cmpb $16, %al
|
|
jae .LMATCH
|
|
|
|
|
|
/***********************************************************************
|
|
// R1
|
|
************************************************************************/
|
|
|
|
shrl $2, %eax
|
|
movb (%esi), %bl
|
|
leal -0x801(%edi), %edx
|
|
leal (%eax,%ebx,4), %eax
|
|
incl %esi
|
|
subl %eax, %edx
|
|
movl (%edx), %ecx
|
|
movl %ecx, (%edi)
|
|
addl N_3, %edi
|
|
jmp .LMDONE
|
|
|
|
|
|
/***********************************************************************
|
|
// M2
|
|
************************************************************************/
|
|
|
|
.align 8
|
|
.LMATCH:
|
|
cmpb $64, %al
|
|
jb .LM3MATCH
|
|
|
|
/* a M2 match */
|
|
movl %eax, %ecx
|
|
shrl $2, %eax
|
|
leal -1(%edi), %edx
|
|
andl $7, %eax
|
|
movb (%esi), %bl
|
|
shrl $5, %ecx
|
|
leal (%eax,%ebx,8), %eax
|
|
incl %esi
|
|
subl %eax, %edx
|
|
|
|
addl $1+3, %ecx
|
|
|
|
cmpl N_3, %eax
|
|
jae .LCOPYLONG
|
|
jmp .LCOPYBYTE
|
|
|
|
|
|
/***********************************************************************
|
|
// M3
|
|
************************************************************************/
|
|
|
|
0: addl N_255, %eax
|
|
1: movb (%esi), %bl
|
|
incl %esi
|
|
orb %bl, %bl
|
|
jz 0b
|
|
leal 33+NN(%eax,%ebx), %ecx
|
|
xorl %eax, %eax
|
|
jmp 3f
|
|
|
|
|
|
.align 8
|
|
.LM3MATCH:
|
|
cmpb $32, %al
|
|
jb .LM4MATCH
|
|
|
|
/* a M3 match */
|
|
andl $31, %eax
|
|
jz 1b
|
|
lea 2+NN(%eax), %ecx
|
|
3:
|
|
movw (%esi), %ax
|
|
leal -1(%edi), %edx
|
|
shrl $2, %eax
|
|
addl $2, %esi
|
|
subl %eax, %edx
|
|
|
|
cmpl N_3, %eax
|
|
jb .LCOPYBYTE
|
|
|
|
|
|
/***********************************************************************
|
|
// copy match
|
|
************************************************************************/
|
|
|
|
.align 2
|
|
.LCOPYLONG: /* copy match using longwords */
|
|
leal -3(%edi,%ecx), %eax
|
|
shrl $2, %ecx
|
|
COPYL(%edx,%edi,%ebx)
|
|
movl %eax, %edi
|
|
xorl %ebx, %ebx
|
|
|
|
.LMDONE:
|
|
movb -2(%esi), %al
|
|
andl N_3, %eax
|
|
jz .L00
|
|
.LFLR3:
|
|
movl (%esi), %edx
|
|
addl %eax, %esi
|
|
movl %edx, (%edi)
|
|
addl %eax, %edi
|
|
|
|
LODSB
|
|
jmp .LMATCH
|
|
|
|
|
|
.align 8
|
|
.LCOPYBYTE: /* copy match using bytes */
|
|
xchgl %edx,%esi
|
|
subl N_3,%ecx
|
|
|
|
rep
|
|
movsb
|
|
movl %edx, %esi
|
|
jmp .LMDONE
|
|
|
|
|
|
/***********************************************************************
|
|
// M4
|
|
************************************************************************/
|
|
|
|
0: addl N_255, %ecx
|
|
1: movb (%esi), %bl
|
|
incl %esi
|
|
orb %bl, %bl
|
|
jz 0b
|
|
leal 9+NN(%ebx,%ecx), %ecx
|
|
jmp 3f
|
|
|
|
|
|
.align 8
|
|
.LM4MATCH:
|
|
cmpb $16, %al
|
|
jb .LM1MATCH
|
|
|
|
/* a M4 match */
|
|
movl %eax, %ecx
|
|
andl $8, %eax
|
|
shll $13, %eax /* save in bit 16 */
|
|
andl $7, %ecx
|
|
jz 1b
|
|
addl $2+NN, %ecx
|
|
3:
|
|
movw (%esi), %ax
|
|
addl $2, %esi
|
|
leal -0x4000(%edi), %edx
|
|
shrl $2, %eax
|
|
jz .LEOF
|
|
subl %eax, %edx
|
|
jmp .LCOPYLONG
|
|
|
|
|
|
/***********************************************************************
|
|
// M1
|
|
************************************************************************/
|
|
|
|
.align 8
|
|
.LM1MATCH:
|
|
/* a M1 match */
|
|
shrl $2, %eax
|
|
movb (%esi), %bl
|
|
leal -1(%edi), %edx
|
|
leal (%eax,%ebx,4), %eax
|
|
incl %esi
|
|
subl %eax, %edx
|
|
|
|
movb (%edx), %al /* we must use this because edx can be edi-1 */
|
|
movb %al, (%edi)
|
|
movb 1(%edx), %bl
|
|
movb %bl, 1(%edi)
|
|
addl $2, %edi
|
|
jmp .LMDONE
|
|
|
|
|
|
/***********************************************************************
|
|
//
|
|
************************************************************************/
|
|
|
|
.LEOF:
|
|
/**** xorl %eax,%eax eax=0 from above */
|
|
|
|
cmpl $3+NN, %ecx /* ecx must be 3/6 */
|
|
setnz %al
|
|
|
|
/* check compressed size */
|
|
movl INP, %edx
|
|
addl INS, %edx
|
|
cmpl %edx, %esi /* check compressed size */
|
|
ja .L_input_overrun
|
|
jb .L_input_not_consumed
|
|
|
|
.L_leave:
|
|
negl %eax
|
|
jnz 1f
|
|
|
|
subl OUTP, %edi /* write back the uncompressed size */
|
|
movl %edi, %eax
|
|
|
|
1: popl %ebx
|
|
popl %esi
|
|
popl %edi
|
|
popl %ebp
|
|
ret
|
|
|
|
.L_input_not_consumed:
|
|
movl $8, %eax /* LZO_E_INPUT_NOT_CONSUMED */
|
|
jmp .L_leave
|
|
|
|
.L_input_overrun:
|
|
movl $4, %eax /* LZO_E_INPUT_OVERRUN */
|
|
jmp .L_leave
|
|
|
|
#undef INP
|
|
#undef INS
|
|
#undef OUTP
|
|
#undef NN
|
|
#undef NN
|
|
#undef N_3
|
|
#undef N_255
|
|
#undef LODSB
|
|
#undef NOTL_3
|
|
#undef MOVSL
|
|
#undef COPYL_C
|
|
#undef COPYL
|