use uncompressed size instead buffer size to find end of kernel to put boot info

This commit is contained in:
Laurent Vivier 2004-06-03 22:39:38 +00:00
parent aedc975d9e
commit 7114efab5f

View File

@ -36,8 +36,6 @@ extern char end_enter_kernel040;
int start(long kernel_image_offset, long kernel_image_size, long kernel_size, int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
long ramdisk_offset, long ramdisk_size, char* command_line) long ramdisk_offset, long ramdisk_size, char* command_line)
{ {
unsigned long kernel_image_start;
unsigned long ramdisk_start;
#ifdef TARGET_M68K #ifdef TARGET_M68K
char * kernel; char * kernel;
unsigned long physImage; unsigned long physImage;
@ -48,6 +46,9 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
unsigned long aligned_addr; unsigned long aligned_addr;
unsigned long enter_kernel; unsigned long enter_kernel;
unsigned long end_enter_kernel; unsigned long end_enter_kernel;
unsigned long kernel_image_start;
unsigned long ramdisk_start;
int uncompressed_size;
#endif #endif
printf("Early Macintosh Image LoadEr\n"); printf("Early Macintosh Image LoadEr\n");
@ -75,7 +76,7 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
error("You're trying to boot a powerPC kernel on 680x0 Machine\n"); error("You're trying to boot a powerPC kernel on 680x0 Machine\n");
} }
/* FIX ME: add some stuff to start 3rd level (powerPC) */ /* FIXME: add some stuff to start 3rd level (powerPC) */
while(1); while(1);
@ -111,7 +112,7 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
/* align kernel address to a 4 byte word */ /* align kernel address to a 4 byte word */
kernel = (unsigned char*)(((unsigned long)kernel + 3) & 0xFFFFFFFC); kernel = (unsigned char*)(((unsigned long)kernel + 3) & 0xFFFFFFFC);
kernel_size = uncompress(kernel, (char*)kernel_image_start); uncompressed_size = uncompress(kernel, (char*)kernel_image_start);
printf("\n"); printf("\n");
} }
else else
@ -142,6 +143,10 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
ret = logical2physical((unsigned long)kernel, &physImage); ret = logical2physical((unsigned long)kernel, &physImage);
/* initialize bootinfo structure */
bootinfo_init(command_line, (char*)ramdisk_start, ramdisk_size);
/* compute final address of kernel */ /* compute final address of kernel */
aligned_size = boot_info.memory[0].addr & (KERNEL_ALIGN - 1); aligned_size = boot_info.memory[0].addr & (KERNEL_ALIGN - 1);
@ -156,8 +161,7 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
/* set bootinfo at end of kernel image */ /* set bootinfo at end of kernel image */
bootinfo_init(command_line, (char*)ramdisk_start, ramdisk_size); set_kernel_bootinfo(kernel + uncompressed_size);
set_kernel_bootinfo(kernel + kernel_size);
/* disable interrupt */ /* disable interrupt */
@ -201,7 +205,7 @@ int start(long kernel_image_offset, long kernel_image_size, long kernel_size,
printf("\n"); printf("\n");
printf("Physical address of kernel will be 0x%08lx\n", start_mem); printf("Physical address of kernel will be 0x%08lx\n", start_mem);
printf("Ok, booting the kernel.\n"); printf("Ok, booting the kernel.\n");
entry(physImage, kernel_size + BI_ALLOC_SIZE, start_mem); entry(physImage, uncompressed_size + BI_ALLOC_SIZE, start_mem);
return 0; return 0;