diff options
Diffstat (limited to 'arch/m32r/boot/compressed')
-rw-r--r-- | arch/m32r/boot/compressed/Makefile | 42 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/boot.h | 59 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/head.S | 172 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/install.sh | 57 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/m32r_sio.c | 68 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/misc.c | 210 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/vmlinux.lds.S | 31 | ||||
-rw-r--r-- | arch/m32r/boot/compressed/vmlinux.scr | 9 |
8 files changed, 648 insertions, 0 deletions
diff --git a/arch/m32r/boot/compressed/Makefile b/arch/m32r/boot/compressed/Makefile new file mode 100644 index 000000000000..d908e1d3c07f --- /dev/null +++ b/arch/m32r/boot/compressed/Makefile | |||
@@ -0,0 +1,42 @@ | |||
1 | # | ||
2 | # linux/arch/sh/boot/compressed/Makefile | ||
3 | # | ||
4 | # create a compressed vmlinux image from the original vmlinux | ||
5 | # | ||
6 | |||
7 | targets := vmlinux vmlinux.bin vmlinux.bin.gz head.o misc.o \ | ||
8 | piggy.o vmlinux.lds | ||
9 | EXTRA_AFLAGS := -traditional | ||
10 | |||
11 | OBJECTS = $(obj)/head.o $(obj)/misc.o | ||
12 | |||
13 | # | ||
14 | # IMAGE_OFFSET is the load offset of the compression loader | ||
15 | # | ||
16 | #IMAGE_OFFSET := $(shell printf "0x%08x" $$[$(CONFIG_MEMORY_START)+0x2000]) | ||
17 | #IMAGE_OFFSET := $(shell printf "0x%08x" $$[$(CONFIG_MEMORY_START)+0x00400000]) | ||
18 | |||
19 | LDFLAGS_vmlinux := -T | ||
20 | |||
21 | $(obj)/vmlinux: $(obj)/vmlinux.lds $(OBJECTS) $(obj)/piggy.o FORCE | ||
22 | $(call if_changed,ld) | ||
23 | @: | ||
24 | |||
25 | $(obj)/vmlinux.bin: vmlinux FORCE | ||
26 | $(call if_changed,objcopy) | ||
27 | |||
28 | $(obj)/vmlinux.bin.gz: $(obj)/vmlinux.bin FORCE | ||
29 | $(call if_changed,gzip) | ||
30 | |||
31 | CFLAGS_misc.o += -fpic | ||
32 | |||
33 | ifdef CONFIG_MMU | ||
34 | LDFLAGS_piggy.o := -r --format binary --oformat elf32-m32r-linux -T | ||
35 | else | ||
36 | LDFLAGS_piggy.o := -r --format binary --oformat elf32-m32r -T | ||
37 | endif | ||
38 | |||
39 | OBJCOPYFLAGS += -R .empty_zero_page | ||
40 | |||
41 | $(obj)/piggy.o: $(obj)/vmlinux.scr $(obj)/vmlinux.bin.gz FORCE | ||
42 | $(call if_changed,ld) | ||
diff --git a/arch/m32r/boot/compressed/boot.h b/arch/m32r/boot/compressed/boot.h new file mode 100644 index 000000000000..9272e38d1104 --- /dev/null +++ b/arch/m32r/boot/compressed/boot.h | |||
@@ -0,0 +1,59 @@ | |||
1 | /* | ||
2 | * 1. load vmlinuz | ||
3 | * | ||
4 | * CONFIG_MEMORY_START +-----------------------+ | ||
5 | * | vmlinuz | | ||
6 | * +-----------------------+ | ||
7 | * 2. decompressed | ||
8 | * | ||
9 | * CONFIG_MEMORY_START +-----------------------+ | ||
10 | * | vmlinuz | | ||
11 | * +-----------------------+ | ||
12 | * | | | ||
13 | * BOOT_RELOC_ADDR +-----------------------+ | ||
14 | * | | | ||
15 | * KERNEL_DECOMPRESS_ADDR +-----------------------+ | ||
16 | * | vmlinux | | ||
17 | * +-----------------------+ | ||
18 | * | ||
19 | * 3. relocate copy & jump code | ||
20 | * | ||
21 | * CONFIG_MEMORY_START +-----------------------+ | ||
22 | * | vmlinuz | | ||
23 | * +-----------------------+ | ||
24 | * | | | ||
25 | * BOOT_RELOC_ADDR +-----------------------+ | ||
26 | * | boot(copy&jump) | | ||
27 | * KERNEL_DECOMPRESS_ADDR +-----------------------+ | ||
28 | * | vmlinux | | ||
29 | * +-----------------------+ | ||
30 | * | ||
31 | * 4. relocate decompressed kernel | ||
32 | * | ||
33 | * CONFIG_MEMORY_START +-----------------------+ | ||
34 | * | vmlinux | | ||
35 | * +-----------------------+ | ||
36 | * | | | ||
37 | * BOOT_RELOC_ADDR +-----------------------+ | ||
38 | * | boot(copy&jump) | | ||
39 | * KERNEL_DECOMPRESS_ADDR +-----------------------+ | ||
40 | * | | | ||
41 | * +-----------------------+ | ||
42 | * | ||
43 | */ | ||
44 | #ifdef __ASSEMBLY__ | ||
45 | #define __val(x) x | ||
46 | #else | ||
47 | #define __val(x) (x) | ||
48 | #endif | ||
49 | |||
50 | #define DECOMPRESS_OFFSET_BASE __val(0x00900000) | ||
51 | #define BOOT_RELOC_SIZE __val(0x00001000) | ||
52 | |||
53 | #define KERNEL_EXEC_ADDR __val(CONFIG_MEMORY_START) | ||
54 | #define KERNEL_DECOMPRESS_ADDR __val(CONFIG_MEMORY_START + \ | ||
55 | DECOMPRESS_OFFSET_BASE + BOOT_RELOC_SIZE) | ||
56 | #define KERNEL_ENTRY __val(CONFIG_MEMORY_START + 0x1000) | ||
57 | |||
58 | #define BOOT_EXEC_ADDR __val(CONFIG_MEMORY_START) | ||
59 | #define BOOT_RELOC_ADDR __val(CONFIG_MEMORY_START + DECOMPRESS_OFFSET_BASE) | ||
diff --git a/arch/m32r/boot/compressed/head.S b/arch/m32r/boot/compressed/head.S new file mode 100644 index 000000000000..07cfd6ad1ae4 --- /dev/null +++ b/arch/m32r/boot/compressed/head.S | |||
@@ -0,0 +1,172 @@ | |||
1 | /* | ||
2 | * linux/arch/m32r/boot/compressed/head.S | ||
3 | * | ||
4 | * Copyright (c) 2001-2003 Hiroyuki Kondo, Hirokazu Takata, | ||
5 | * Hitoshi Yamamoto, Takeo Takahashi | ||
6 | * Copyright (c) 2004 Hirokazu Takata | ||
7 | */ | ||
8 | |||
9 | .text | ||
10 | #include <linux/config.h> | ||
11 | #include <linux/linkage.h> | ||
12 | #include <asm/addrspace.h> | ||
13 | #include <asm/page.h> | ||
14 | #include <asm/assembler.h> | ||
15 | |||
16 | /* | ||
17 | * This code can be loaded anywhere, as long as output will not | ||
18 | * overlap it. | ||
19 | * | ||
20 | * NOTE: This head.S should *NOT* be compiled with -fpic. | ||
21 | * | ||
22 | */ | ||
23 | |||
24 | .global startup | ||
25 | .global __bss_start, _ebss, end, zimage_data, zimage_len | ||
26 | __ALIGN | ||
27 | startup: | ||
28 | ldi r0, #0x0000 /* SPI, disable EI */ | ||
29 | mvtc r0, psw | ||
30 | |||
31 | ldi r12, #-8 | ||
32 | bl 1f | ||
33 | .fillinsn | ||
34 | 1: | ||
35 | seth r1, #high(CONFIG_MEMORY_START + 0x00400000) /* Start address */ | ||
36 | add r12, r14 /* Real address */ | ||
37 | sub r12, r1 /* difference */ | ||
38 | |||
39 | .global got_len | ||
40 | seth r3, #high(_GLOBAL_OFFSET_TABLE_+8) | ||
41 | or3 r3, r3, #low(_GLOBAL_OFFSET_TABLE_+12) | ||
42 | add r3, r14 | ||
43 | |||
44 | /* Update the contents of global offset table */ | ||
45 | ldi r1, #low(got_len) | ||
46 | srli r1, #2 | ||
47 | beqz r1, 2f | ||
48 | .fillinsn | ||
49 | 1: | ||
50 | ld r2, @r3 | ||
51 | add r2, r12 | ||
52 | st r2, @r3 | ||
53 | addi r3, #4 | ||
54 | addi r1, #-1 | ||
55 | bnez r1, 1b | ||
56 | .fillinsn | ||
57 | 2: | ||
58 | /* XXX: resolve plt */ | ||
59 | |||
60 | /* | ||
61 | * Clear BSS first so that there are no surprises... | ||
62 | */ | ||
63 | #ifdef CONFIG_ISA_DUAL_ISSUE | ||
64 | seth r2, #high(__bss_start) | ||
65 | or3 r2, r2, #low(__bss_start) | ||
66 | add r2, r12 | ||
67 | seth r3, #high(_ebss) | ||
68 | or3 r3, r3, #low(_ebss) | ||
69 | add r3, r12 | ||
70 | sub r3, r2 | ||
71 | |||
72 | ; R4 = BSS size in longwords (rounded down) | ||
73 | mv r4, r3 || ldi r1, #0 | ||
74 | srli r4, #4 || addi r2, #-4 | ||
75 | beqz r4, .Lendloop1 | ||
76 | .Lloop1: | ||
77 | #ifndef CONFIG_CHIP_M32310 | ||
78 | ; Touch memory for the no-write-allocating cache. | ||
79 | ld r0, @(4,r2) | ||
80 | #endif | ||
81 | st r1, @+r2 || addi r4, #-1 | ||
82 | st r1, @+r2 | ||
83 | st r1, @+r2 | ||
84 | st r1, @+r2 || cmpeq r1, r4 ; R4 = 0? | ||
85 | bnc .Lloop1 | ||
86 | .Lendloop1: | ||
87 | and3 r4, r3, #15 | ||
88 | addi r2, #4 | ||
89 | beqz r4, .Lendloop2 | ||
90 | .Lloop2: | ||
91 | stb r1, @r2 || addi r4, #-1 | ||
92 | addi r2, #1 | ||
93 | bnez r4, .Lloop2 | ||
94 | .Lendloop2: | ||
95 | |||
96 | #else /* not CONFIG_ISA_DUAL_ISSUE */ | ||
97 | seth r2, #high(__bss_start) | ||
98 | or3 r2, r2, #low(__bss_start) | ||
99 | add r2, r12 | ||
100 | seth r3, #high(_ebss) | ||
101 | or3 r3, r3, #low(_ebss) | ||
102 | add r3, r12 | ||
103 | sub r3, r2 | ||
104 | mv r4, r3 | ||
105 | srli r4, #2 ; R4 = BSS size in longwords (rounded down) | ||
106 | ldi r1, #0 ; clear R1 for longwords store | ||
107 | addi r2, #-4 ; account for pre-inc store | ||
108 | beqz r4, .Lendloop1 ; any more to go? | ||
109 | .Lloop1: | ||
110 | st r1, @+r2 ; yep, zero out another longword | ||
111 | addi r4, #-1 ; decrement count | ||
112 | bnez r4, .Lloop1 ; go do some more | ||
113 | .Lendloop1: | ||
114 | |||
115 | #endif /* not CONFIG_ISA_DUAL_ISSUE */ | ||
116 | |||
117 | seth r1, #high(end) | ||
118 | or3 r1, r1, #low(end) | ||
119 | add r1, r12 | ||
120 | mv sp, r1 | ||
121 | |||
122 | /* | ||
123 | * decompress the kernel | ||
124 | */ | ||
125 | mv r0, sp | ||
126 | srli r0, 31 /* MMU is ON or OFF */ | ||
127 | seth r1, #high(zimage_data) | ||
128 | or3 r1, r1, #low(zimage_data) | ||
129 | add r1, r12 | ||
130 | seth r2, #high(zimage_len) | ||
131 | or3 r2, r2, #low(zimage_len) | ||
132 | mv r3, sp | ||
133 | |||
134 | bl decompress_kernel | ||
135 | |||
136 | #if defined(CONFIG_CHIP_M32700) || defined(CONFIG_CHIP_OPSP) || defined(CONFIG_CHIP_VDEC2) | ||
137 | /* Cache flush */ | ||
138 | ldi r0, -1 | ||
139 | ldi r1, 0xd0 ; invalidate i-cache, copy back d-cache | ||
140 | stb r1, @r0 | ||
141 | #elif defined(CONFIG_CHIP_M32102) | ||
142 | /* Cache flush */ | ||
143 | ldi r0, -2 | ||
144 | ldi r1, 0x0100 ; invalidate | ||
145 | stb r1, @r0 | ||
146 | #else | ||
147 | #error "put your cache flush function, please" | ||
148 | #endif | ||
149 | |||
150 | mv r0, sp | ||
151 | srli r0, 31 /* MMU is ON or OFF */ | ||
152 | slli r0, 31 | ||
153 | or3 r0, r0, #0x2000 | ||
154 | seth r1, #high(CONFIG_MEMORY_START) | ||
155 | or r0, r1 | ||
156 | jmp r0 | ||
157 | |||
158 | .balign 512 | ||
159 | fake_headers_as_bzImage: | ||
160 | .short 0 | ||
161 | .ascii "HdrS" | ||
162 | .short 0x0202 | ||
163 | .short 0 | ||
164 | .short 0 | ||
165 | .byte 0x00, 0x10 | ||
166 | .short 0 | ||
167 | .byte 0 | ||
168 | .byte 1 | ||
169 | .byte 0x00, 0x80 | ||
170 | .long 0 | ||
171 | .long 0 | ||
172 | |||
diff --git a/arch/m32r/boot/compressed/install.sh b/arch/m32r/boot/compressed/install.sh new file mode 100644 index 000000000000..6d72e9e72697 --- /dev/null +++ b/arch/m32r/boot/compressed/install.sh | |||
@@ -0,0 +1,57 @@ | |||
1 | #!/bin/sh | ||
2 | # | ||
3 | # arch/sh/boot/install.sh | ||
4 | # | ||
5 | # This file is subject to the terms and conditions of the GNU General Public | ||
6 | # License. See the file "COPYING" in the main directory of this archive | ||
7 | # for more details. | ||
8 | # | ||
9 | # Copyright (C) 1995 by Linus Torvalds | ||
10 | # | ||
11 | # Adapted from code in arch/i386/boot/Makefile by H. Peter Anvin | ||
12 | # Adapted from code in arch/i386/boot/install.sh by Russell King | ||
13 | # Adapted from code in arch/arm/boot/install.sh by Stuart Menefy | ||
14 | # Adapted from code in arch/sh/boot/install.sh by Takeo Takahashi | ||
15 | # | ||
16 | # "make install" script for sh architecture | ||
17 | # | ||
18 | # Arguments: | ||
19 | # $1 - kernel version | ||
20 | # $2 - kernel image file | ||
21 | # $3 - kernel map file | ||
22 | # $4 - default install path (blank if root directory) | ||
23 | # | ||
24 | |||
25 | # User may have a custom install script | ||
26 | |||
27 | if [ -x /sbin/installkernel ]; then | ||
28 | exec /sbin/installkernel "$@" | ||
29 | fi | ||
30 | |||
31 | if [ "$2" = "zImage" ]; then | ||
32 | # Compressed install | ||
33 | echo "Installing compressed kernel" | ||
34 | if [ -f $4/vmlinuz-$1 ]; then | ||
35 | mv $4/vmlinuz-$1 $4/vmlinuz.old | ||
36 | fi | ||
37 | |||
38 | if [ -f $4/System.map-$1 ]; then | ||
39 | mv $4/System.map-$1 $4/System.old | ||
40 | fi | ||
41 | |||
42 | cat $2 > $4/vmlinuz-$1 | ||
43 | cp $3 $4/System.map-$1 | ||
44 | else | ||
45 | # Normal install | ||
46 | echo "Installing normal kernel" | ||
47 | if [ -f $4/vmlinux-$1 ]; then | ||
48 | mv $4/vmlinux-$1 $4/vmlinux.old | ||
49 | fi | ||
50 | |||
51 | if [ -f $4/System.map ]; then | ||
52 | mv $4/System.map $4/System.old | ||
53 | fi | ||
54 | |||
55 | cat $2 > $4/vmlinux-$1 | ||
56 | cp $3 $4/System.map | ||
57 | fi | ||
diff --git a/arch/m32r/boot/compressed/m32r_sio.c b/arch/m32r/boot/compressed/m32r_sio.c new file mode 100644 index 000000000000..bad5475eff90 --- /dev/null +++ b/arch/m32r/boot/compressed/m32r_sio.c | |||
@@ -0,0 +1,68 @@ | |||
1 | /* | ||
2 | * arch/m32r/boot/compressed/m32r_sio.c | ||
3 | * | ||
4 | * 2003-02-12: Takeo Takahashi | ||
5 | * | ||
6 | */ | ||
7 | |||
8 | #include <linux/config.h> | ||
9 | |||
10 | static void putc(char c); | ||
11 | |||
12 | static int puts(const char *s) | ||
13 | { | ||
14 | char c; | ||
15 | while ((c = *s++)) putc(c); | ||
16 | return 0; | ||
17 | } | ||
18 | |||
19 | #if defined(CONFIG_PLAT_M32700UT_Alpha) || defined(CONFIG_PLAT_M32700UT) | ||
20 | #include <asm/m32r.h> | ||
21 | #include <asm/io.h> | ||
22 | |||
23 | #define USE_FPGA_MAP 0 | ||
24 | |||
25 | #if USE_FPGA_MAP | ||
26 | /* | ||
27 | * fpga configuration program uses MMU, and define map as same as | ||
28 | * M32104 uT-Engine board. | ||
29 | */ | ||
30 | #define BOOT_SIO0STS (volatile unsigned short *)(0x02c00000 + 0x20006) | ||
31 | #define BOOT_SIO0TXB (volatile unsigned short *)(0x02c00000 + 0x2000c) | ||
32 | #else | ||
33 | #undef PLD_BASE | ||
34 | #define PLD_BASE 0xa4c00000 | ||
35 | #define BOOT_SIO0STS PLD_ESIO0STS | ||
36 | #define BOOT_SIO0TXB PLD_ESIO0TXB | ||
37 | #endif | ||
38 | |||
39 | static void putc(char c) | ||
40 | { | ||
41 | |||
42 | while ((*BOOT_SIO0STS & 0x3) != 0x3) ; | ||
43 | if (c == '\n') { | ||
44 | *BOOT_SIO0TXB = '\r'; | ||
45 | while ((*BOOT_SIO0STS & 0x3) != 0x3) ; | ||
46 | } | ||
47 | *BOOT_SIO0TXB = c; | ||
48 | } | ||
49 | #else /* defined(CONFIG_PLAT_M32700UT_Alpha) || defined(CONFIG_PLAT_M32700UT) */ | ||
50 | #ifdef CONFIG_MMU | ||
51 | #define SIO0STS (volatile unsigned short *)(0xa0efd000 + 14) | ||
52 | #define SIO0TXB (volatile unsigned short *)(0xa0efd000 + 30) | ||
53 | #else | ||
54 | #define SIO0STS (volatile unsigned short *)(0x00efd000 + 14) | ||
55 | #define SIO0TXB (volatile unsigned short *)(0x00efd000 + 30) | ||
56 | #endif | ||
57 | |||
58 | static void putc(char c) | ||
59 | { | ||
60 | |||
61 | while ((*SIO0STS & 0x1) == 0) ; | ||
62 | if (c == '\n') { | ||
63 | *SIO0TXB = '\r'; | ||
64 | while ((*SIO0STS & 0x1) == 0) ; | ||
65 | } | ||
66 | *SIO0TXB = c; | ||
67 | } | ||
68 | #endif | ||
diff --git a/arch/m32r/boot/compressed/misc.c b/arch/m32r/boot/compressed/misc.c new file mode 100644 index 000000000000..70fa799005c3 --- /dev/null +++ b/arch/m32r/boot/compressed/misc.c | |||
@@ -0,0 +1,210 @@ | |||
1 | /* | ||
2 | * arch/m32r/boot/compressed/misc.c | ||
3 | * | ||
4 | * This is a collection of several routines from gzip-1.0.3 | ||
5 | * adapted for Linux. | ||
6 | * | ||
7 | * malloc by Hannu Savolainen 1993 and Matthias Urlichs 1994 | ||
8 | * | ||
9 | * Adapted for SH by Stuart Menefy, Aug 1999 | ||
10 | * | ||
11 | * 2003-02-12: Support M32R by Takeo Takahashi | ||
12 | * This is based on arch/sh/boot/compressed/misc.c. | ||
13 | */ | ||
14 | |||
15 | #include <linux/config.h> | ||
16 | #include <linux/string.h> | ||
17 | |||
18 | /* | ||
19 | * gzip declarations | ||
20 | */ | ||
21 | |||
22 | #define OF(args) args | ||
23 | #define STATIC static | ||
24 | |||
25 | #undef memset | ||
26 | #undef memcpy | ||
27 | #define memzero(s, n) memset ((s), 0, (n)) | ||
28 | |||
29 | typedef unsigned char uch; | ||
30 | typedef unsigned short ush; | ||
31 | typedef unsigned long ulg; | ||
32 | |||
33 | #define WSIZE 0x8000 /* Window size must be at least 32k, */ | ||
34 | /* and a power of two */ | ||
35 | |||
36 | static uch *inbuf; /* input buffer */ | ||
37 | static uch window[WSIZE]; /* Sliding window buffer */ | ||
38 | |||
39 | static unsigned insize = 0; /* valid bytes in inbuf */ | ||
40 | static unsigned inptr = 0; /* index of next byte to be processed in inbuf */ | ||
41 | static unsigned outcnt = 0; /* bytes in output buffer */ | ||
42 | |||
43 | /* gzip flag byte */ | ||
44 | #define ASCII_FLAG 0x01 /* bit 0 set: file probably ASCII text */ | ||
45 | #define CONTINUATION 0x02 /* bit 1 set: continuation of multi-part gzip file */ | ||
46 | #define EXTRA_FIELD 0x04 /* bit 2 set: extra field present */ | ||
47 | #define ORIG_NAME 0x08 /* bit 3 set: original file name present */ | ||
48 | #define COMMENT 0x10 /* bit 4 set: file comment present */ | ||
49 | #define ENCRYPTED 0x20 /* bit 5 set: file is encrypted */ | ||
50 | #define RESERVED 0xC0 /* bit 6,7: reserved */ | ||
51 | |||
52 | #define get_byte() (inptr < insize ? inbuf[inptr++] : fill_inbuf()) | ||
53 | |||
54 | /* Diagnostic functions */ | ||
55 | #ifdef DEBUG | ||
56 | # define Assert(cond,msg) {if(!(cond)) error(msg);} | ||
57 | # define Trace(x) fprintf x | ||
58 | # define Tracev(x) {if (verbose) fprintf x ;} | ||
59 | # define Tracevv(x) {if (verbose>1) fprintf x ;} | ||
60 | # define Tracec(c,x) {if (verbose && (c)) fprintf x ;} | ||
61 | # define Tracecv(c,x) {if (verbose>1 && (c)) fprintf x ;} | ||
62 | #else | ||
63 | # define Assert(cond,msg) | ||
64 | # define Trace(x) | ||
65 | # define Tracev(x) | ||
66 | # define Tracevv(x) | ||
67 | # define Tracec(c,x) | ||
68 | # define Tracecv(c,x) | ||
69 | #endif | ||
70 | |||
71 | static int fill_inbuf(void); | ||
72 | static void flush_window(void); | ||
73 | static void error(char *m); | ||
74 | static void gzip_mark(void **); | ||
75 | static void gzip_release(void **); | ||
76 | |||
77 | static unsigned char *input_data; | ||
78 | static int input_len; | ||
79 | |||
80 | static long bytes_out = 0; | ||
81 | static uch *output_data; | ||
82 | static unsigned long output_ptr = 0; | ||
83 | |||
84 | #include "m32r_sio.c" | ||
85 | |||
86 | static void *malloc(int size); | ||
87 | static void free(void *where); | ||
88 | |||
89 | static unsigned long free_mem_ptr; | ||
90 | static unsigned long free_mem_end_ptr; | ||
91 | |||
92 | #define HEAP_SIZE 0x10000 | ||
93 | |||
94 | #include "../../../../lib/inflate.c" | ||
95 | |||
96 | static void *malloc(int size) | ||
97 | { | ||
98 | void *p; | ||
99 | |||
100 | if (size <0) error("Malloc error"); | ||
101 | if (free_mem_ptr == 0) error("Memory error"); | ||
102 | |||
103 | free_mem_ptr = (free_mem_ptr + 3) & ~3; /* Align */ | ||
104 | |||
105 | p = (void *)free_mem_ptr; | ||
106 | free_mem_ptr += size; | ||
107 | |||
108 | if (free_mem_ptr >= free_mem_end_ptr) | ||
109 | error("Out of memory"); | ||
110 | |||
111 | return p; | ||
112 | } | ||
113 | |||
114 | static void free(void *where) | ||
115 | { /* Don't care */ | ||
116 | } | ||
117 | |||
118 | static void gzip_mark(void **ptr) | ||
119 | { | ||
120 | *ptr = (void *) free_mem_ptr; | ||
121 | } | ||
122 | |||
123 | static void gzip_release(void **ptr) | ||
124 | { | ||
125 | free_mem_ptr = (long) *ptr; | ||
126 | } | ||
127 | |||
128 | void* memset(void* s, int c, size_t n) | ||
129 | { | ||
130 | int i; | ||
131 | char *ss = (char*)s; | ||
132 | |||
133 | for (i=0;i<n;i++) ss[i] = c; | ||
134 | return s; | ||
135 | } | ||
136 | |||
137 | void* memcpy(void* __dest, __const void* __src, | ||
138 | size_t __n) | ||
139 | { | ||
140 | int i; | ||
141 | char *d = (char *)__dest, *s = (char *)__src; | ||
142 | |||
143 | for (i=0;i<__n;i++) d[i] = s[i]; | ||
144 | return __dest; | ||
145 | } | ||
146 | |||
147 | /* =========================================================================== | ||
148 | * Fill the input buffer. This is called only when the buffer is empty | ||
149 | * and at least one byte is really needed. | ||
150 | */ | ||
151 | static int fill_inbuf(void) | ||
152 | { | ||
153 | if (insize != 0) { | ||
154 | error("ran out of input data"); | ||
155 | } | ||
156 | |||
157 | inbuf = input_data; | ||
158 | insize = input_len; | ||
159 | inptr = 1; | ||
160 | return inbuf[0]; | ||
161 | } | ||
162 | |||
163 | /* =========================================================================== | ||
164 | * Write the output window window[0..outcnt-1] and update crc and bytes_out. | ||
165 | * (Used for the decompressed data only.) | ||
166 | */ | ||
167 | static void flush_window(void) | ||
168 | { | ||
169 | ulg c = crc; /* temporary variable */ | ||
170 | unsigned n; | ||
171 | uch *in, *out, ch; | ||
172 | |||
173 | in = window; | ||
174 | out = &output_data[output_ptr]; | ||
175 | for (n = 0; n < outcnt; n++) { | ||
176 | ch = *out++ = *in++; | ||
177 | c = crc_32_tab[((int)c ^ ch) & 0xff] ^ (c >> 8); | ||
178 | } | ||
179 | crc = c; | ||
180 | bytes_out += (ulg)outcnt; | ||
181 | output_ptr += (ulg)outcnt; | ||
182 | outcnt = 0; | ||
183 | } | ||
184 | |||
185 | static void error(char *x) | ||
186 | { | ||
187 | puts("\n\n"); | ||
188 | puts(x); | ||
189 | puts("\n\n -- System halted"); | ||
190 | |||
191 | while(1); /* Halt */ | ||
192 | } | ||
193 | |||
194 | /* return decompressed size */ | ||
195 | void | ||
196 | decompress_kernel(int mmu_on, unsigned char *zimage_data, | ||
197 | unsigned int zimage_len, unsigned long heap) | ||
198 | { | ||
199 | output_data = (unsigned char *)CONFIG_MEMORY_START + 0x2000 | ||
200 | + (mmu_on ? 0x80000000 : 0); | ||
201 | free_mem_ptr = heap; | ||
202 | free_mem_end_ptr = free_mem_ptr + HEAP_SIZE; | ||
203 | input_data = zimage_data; | ||
204 | input_len = zimage_len; | ||
205 | |||
206 | makecrc(); | ||
207 | puts("Uncompressing Linux... "); | ||
208 | gunzip(); | ||
209 | puts("Ok, booting the kernel.\n"); | ||
210 | } | ||
diff --git a/arch/m32r/boot/compressed/vmlinux.lds.S b/arch/m32r/boot/compressed/vmlinux.lds.S new file mode 100644 index 000000000000..a18431759633 --- /dev/null +++ b/arch/m32r/boot/compressed/vmlinux.lds.S | |||
@@ -0,0 +1,31 @@ | |||
1 | #include <linux/config.h> | ||
2 | |||
3 | OUTPUT_ARCH(m32r) | ||
4 | ENTRY(startup) | ||
5 | SECTIONS | ||
6 | { | ||
7 | . = CONFIG_MEMORY_START + 0x00400000; | ||
8 | |||
9 | _text = .; | ||
10 | .text : { *(.text) } = 0 | ||
11 | .rodata : { *(.rodata) *(.rodata.*) } | ||
12 | _etext = .; | ||
13 | |||
14 | . = ALIGN(32 / 8); | ||
15 | .data : { *(.data) } | ||
16 | . = ALIGN(32 / 8); | ||
17 | _got = .; | ||
18 | .got : { *(.got) _egot = .; *(.got.*) } | ||
19 | _edata = .; | ||
20 | |||
21 | . = ALIGN(32 / 8); | ||
22 | __bss_start = .; | ||
23 | .bss : { *(.bss) *(.sbss) } | ||
24 | . = ALIGN(32 / 8); | ||
25 | _ebss = .; | ||
26 | . = ALIGN(4096); | ||
27 | . += 4096; | ||
28 | end = . ; | ||
29 | |||
30 | got_len = (_egot - _got); | ||
31 | } | ||
diff --git a/arch/m32r/boot/compressed/vmlinux.scr b/arch/m32r/boot/compressed/vmlinux.scr new file mode 100644 index 000000000000..924c7992c55b --- /dev/null +++ b/arch/m32r/boot/compressed/vmlinux.scr | |||
@@ -0,0 +1,9 @@ | |||
1 | SECTIONS | ||
2 | { | ||
3 | .data : { | ||
4 | zimage_data = .; | ||
5 | *(.data) | ||
6 | zimage_data_end = .; | ||
7 | } | ||
8 | zimage_len = zimage_data_end - zimage_data; | ||
9 | } | ||