2007-10-31 Robert Millan <rmh@aybabtu.com>
* configure.ac: Add `i386-linuxbios' to the list of supported targets. * conf/i386-linuxbios.rmk: New file. * kern/i386/pc/hardware.c: Likewise. * term/i386/pc/at_keyboard.c: Likewise. * term/i386/pc/vga_text.c: Likewise. * include/grub/i386/linuxbios/boot.h: Likewise. * include/grub/i386/linuxbios/console.h: Likewise. * include/grub/i386/linuxbios/init.h: Likewise. * include/grub/i386/linuxbios/kernel.h: Likewise. * include/grub/i386/linuxbios/loader.h: Likewise. * include/grub/i386/linuxbios/memory.h: Likewise. * include/grub/i386/linuxbios/serial.h: Likewise. * include/grub/i386/linuxbios/time.h: Likewise. * kern/i386/linuxbios/init.c: Likewise. * kern/i386/linuxbios/startup.S: Likewise. * kern/i386/linuxbios/table.c: Likewise.
This commit is contained in:
		
							parent
							
								
									e911ecc1c2
								
							
						
					
					
						commit
						ca25d8f0c1
					
				
					 19 changed files with 6147 additions and 3373 deletions
				
			
		
							
								
								
									
										186
									
								
								kern/i386/linuxbios/init.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										186
									
								
								kern/i386/linuxbios/init.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,186 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 2002,2003,2004,2005,2006,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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <grub/kernel.h> | ||||
| #include <grub/mm.h> | ||||
| #include <grub/machine/time.h> | ||||
| #include <grub/machine/init.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/machine/console.h> | ||||
| #include <grub/machine/kernel.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/err.h> | ||||
| #include <grub/dl.h> | ||||
| #include <grub/misc.h> | ||||
| #include <grub/loader.h> | ||||
| #include <grub/env.h> | ||||
| #include <grub/cache.h> | ||||
| #include <grub/time.h> | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/cpu/io.h> | ||||
| 
 | ||||
| #define GRUB_FLOPPY_REG_DIGITAL_OUTPUT		0x3f2 | ||||
| 
 | ||||
| extern char _start[]; | ||||
| extern char _end[]; | ||||
| 
 | ||||
| grub_addr_t grub_os_area_addr; | ||||
| grub_size_t grub_os_area_size; | ||||
| grub_size_t grub_lower_mem, grub_upper_mem; | ||||
| 
 | ||||
| /* FIXME: we need interrupts to do this right */ | ||||
| static grub_uint32_t grub_time_tics = 0; | ||||
| 
 | ||||
| grub_uint32_t | ||||
| grub_get_rtc (void) | ||||
| { | ||||
|   return grub_time_tics; | ||||
| } | ||||
| 
 | ||||
| /* Stop the floppy drive from spinning, so that other software is
 | ||||
|    jumped to with a known state.  */ | ||||
| void | ||||
| grub_stop_floppy (void) | ||||
| { | ||||
|   grub_outb (0, GRUB_FLOPPY_REG_DIGITAL_OUTPUT); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_millisleep (grub_uint32_t ms __attribute__ ((unused))) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_exit () | ||||
| { | ||||
|   grub_printf ("grub_exit() is not implemented.\n"); | ||||
|   grub_stop (); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_reboot () | ||||
| { | ||||
|   grub_printf ("grub_reboot() is not implemented.\n"); | ||||
|   grub_stop (); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_halt (int no_apm __attribute__ ((unused))) | ||||
| { | ||||
|   grub_printf ("grub_halt() is not implemented.\n"); | ||||
|   grub_stop (); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_arch_sync_caches (void *address __attribute__ ((unused)), | ||||
| 		       grub_size_t len __attribute__ ((unused))) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| static char * | ||||
| make_install_device (void) | ||||
| { | ||||
|   return NULL; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_init (void) | ||||
| { | ||||
|   /* Initialize the console as early as possible.  */ | ||||
|   grub_console_init (); | ||||
| 
 | ||||
|   grub_lower_mem = GRUB_MEMORY_MACHINE_LOWER_USABLE; | ||||
|   grub_upper_mem = 0; | ||||
| 
 | ||||
|   auto int heap_init (mem_region_t); | ||||
|   int heap_init (mem_region_t mem_region) | ||||
|   { | ||||
|     grub_uint64_t addr = mem_region->addr; | ||||
|     grub_uint64_t size = mem_region->size; | ||||
| 
 | ||||
| #if GRUB_CPU_SIZEOF_VOID_P == 4 | ||||
|     /* Restrict ourselves to 32-bit memory space.  */ | ||||
|     if (addr > ULONG_MAX) | ||||
|       { | ||||
| 	grub_upper_mem = ULONG_MAX; | ||||
| 	return 0; | ||||
|       } | ||||
|     if (addr + size > ULONG_MAX) | ||||
|       size = ULONG_MAX - addr; | ||||
| #endif | ||||
| 
 | ||||
|     grub_upper_mem = grub_max (grub_upper_mem, addr + size); | ||||
| 
 | ||||
|     if (mem_region->type != GRUB_LINUXBIOS_MEMORY_AVAILABLE) | ||||
|       return 0; | ||||
| 
 | ||||
|     /* Avoid the lower memory.  */ | ||||
|     if (addr < GRUB_MEMORY_MACHINE_LOWER_SIZE) | ||||
|       { | ||||
| 	if (addr + size <= GRUB_MEMORY_MACHINE_LOWER_SIZE) | ||||
| 	  return 0; | ||||
| 	else | ||||
| 	  { | ||||
| 	    size -= GRUB_MEMORY_MACHINE_LOWER_SIZE - addr; | ||||
| 	    addr = GRUB_MEMORY_MACHINE_LOWER_SIZE; | ||||
| 	  } | ||||
|       } | ||||
| 
 | ||||
|     if (addr == GRUB_MEMORY_MACHINE_UPPER_START | ||||
| 	|| (addr >= GRUB_MEMORY_MACHINE_LOWER_SIZE | ||||
| 	    && addr <= GRUB_MEMORY_MACHINE_UPPER_START | ||||
| 	    && (addr + size > GRUB_MEMORY_MACHINE_UPPER_START))) | ||||
|       { | ||||
| 	grub_size_t quarter = size >> 2; | ||||
| 
 | ||||
| 	grub_os_area_addr = addr; | ||||
| 	grub_os_area_size = size - quarter; | ||||
| 	grub_mm_init_region ((void *) (grub_os_area_addr + grub_os_area_size), | ||||
| 			     quarter); | ||||
|       } | ||||
|     else | ||||
|       grub_mm_init_region ((void *) addr, (grub_size_t) size); | ||||
| 
 | ||||
|     return 0; | ||||
|   } | ||||
| 
 | ||||
|   grub_available_iterate (heap_init); | ||||
| 
 | ||||
|   /* This variable indicates size, not offset.  */ | ||||
|   grub_upper_mem -= GRUB_MEMORY_MACHINE_UPPER_START; | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_set_prefix (void) | ||||
| { | ||||
|   /* Initialize the prefix.  */ | ||||
|   grub_env_set ("prefix", make_install_device ()); | ||||
| } | ||||
| 
 | ||||
| void | ||||
| grub_machine_fini (void) | ||||
| { | ||||
|   grub_console_fini (); | ||||
| } | ||||
| 
 | ||||
| /* Return the end of the core image.  */ | ||||
| grub_addr_t | ||||
| grub_arch_modules_addr (void) | ||||
| { | ||||
|   return ALIGN_UP(_end, GRUB_MOD_ALIGN); | ||||
| } | ||||
							
								
								
									
										77
									
								
								kern/i386/linuxbios/startup.S
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								kern/i386/linuxbios/startup.S
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,77 @@ | |||
| /* | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 1999,2000,2001,2002,2003,2005,2006,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/>. | ||||
|  */ | ||||
| 
 | ||||
| #define ASM_FILE	1 | ||||
| 
 | ||||
| #include <grub/symbol.h> | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/cpu/linux.h> | ||||
| #include <multiboot.h> | ||||
| #include <multiboot2.h> | ||||
| 
 | ||||
| /* | ||||
|  * Note: GRUB is compiled with the options -mrtd and -mregparm=3. | ||||
|  *       So the first three arguments are passed in %eax, %edx, and %ecx, | ||||
|  *       respectively, and if a function has a fixed number of arguments | ||||
|  *       and the number if greater than three, the function must return | ||||
|  *       with "ret $N" where N is ((the number of arguments) - 3) * 4. | ||||
|  */ | ||||
| 
 | ||||
| 	.file	"startup.S" | ||||
| 	.text | ||||
| 	.globl	start, _start | ||||
| 
 | ||||
| #if 0 | ||||
| /* | ||||
|  *  Support for booting GRUB from a Multiboot boot loader (e.g. GRUB itself). | ||||
|  */ | ||||
| multiboot_header: | ||||
| 	/* magic */ | ||||
| 	.long	0x1BADB002
 | ||||
| 	/* flags */ | ||||
| 	.long	0
 | ||||
| 	/* checksum */ | ||||
| 	.long	-0x1BADB002 | ||||
| #endif | ||||
| 
 | ||||
| start: | ||||
| _start: | ||||
| 	/* initialize the stack */ | ||||
| 	movl $GRUB_MEMORY_MACHINE_PROT_STACK, %esp | ||||
| 
 | ||||
| 	/* jump to the main body of C code */ | ||||
| 	jmp EXT_C(grub_main) | ||||
| 
 | ||||
| /* | ||||
|  *  This call is special...  it never returns...  in fact it should simply | ||||
|  *  hang at this point! | ||||
|  */ | ||||
| FUNCTION(grub_stop) | ||||
| 	hlt | ||||
| 	jmp EXT_C(grub_stop) | ||||
| 
 | ||||
| /* | ||||
|  *  prot_to_real and associated structures (but NOT real_to_prot, that is | ||||
|  *  only needed for BIOS gates). | ||||
|  */ | ||||
| #include "../realmode.S" | ||||
| 
 | ||||
| /* | ||||
|  *  Routines needed by Linux and Multiboot loaders. | ||||
|  */ | ||||
| #include "../loader.S" | ||||
							
								
								
									
										69
									
								
								kern/i386/linuxbios/table.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								kern/i386/linuxbios/table.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,69 @@ | |||
| /*
 | ||||
|  *  GRUB  --  GRand Unified Bootloader | ||||
|  *  Copyright (C) 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/>.
 | ||||
|  */ | ||||
| 
 | ||||
| #include <grub/machine/memory.h> | ||||
| #include <grub/types.h> | ||||
| #include <grub/err.h> | ||||
| 
 | ||||
| static grub_err_t | ||||
| grub_linuxbios_table_iterate (grub_linuxbios_table_header_t table_header, | ||||
| 		      int (*hook) (grub_linuxbios_table_item_t)) | ||||
| { | ||||
|   grub_linuxbios_table_item_t table_item; | ||||
| 
 | ||||
|   if (grub_memcmp (table_header->signature, "LBIO", 4)) | ||||
|     grub_fatal ("Could not find LinuxBIOS table\n"); | ||||
| 
 | ||||
|   table_item = | ||||
|     (grub_linuxbios_table_item_t) ((long) table_header + | ||||
| 			       (long) table_header->size); | ||||
|   for (; table_item->size; | ||||
|        table_item = (grub_linuxbios_table_item_t) ((long) table_item + (long) table_item->size)) | ||||
|     if (hook (table_item)) | ||||
|       return 1; | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| grub_err_t | ||||
| grub_available_iterate (int (*hook) (mem_region_t)) | ||||
| { | ||||
|   mem_region_t mem_region; | ||||
| 
 | ||||
|   auto int iterate_linuxbios_table (grub_linuxbios_table_item_t); | ||||
|   int iterate_linuxbios_table (grub_linuxbios_table_item_t table_item) | ||||
|   { | ||||
|     if (table_item->tag != GRUB_LINUXBIOS_MEMBER_MEMORY) | ||||
|       return 0; | ||||
| 
 | ||||
|     mem_region = | ||||
|       (mem_region_t) ((long) table_item + | ||||
| 				 sizeof (struct grub_linuxbios_table_item)); | ||||
|     for (; (long) mem_region < (long) table_item + (long) table_item->size; | ||||
| 	 mem_region++) | ||||
|       if (hook (mem_region)) | ||||
| 	return 1; | ||||
| 
 | ||||
|     return 0; | ||||
|   } | ||||
| 
 | ||||
|   grub_linuxbios_table_iterate (GRUB_MEMORY_MACHINE_LINUXBIOS_TABLE_ADDR, | ||||
| 			iterate_linuxbios_table); | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue