]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
ChangeLog
authorVladimir 'phcoder' Serbinenko <phcoder@gmail.com>
Sat, 28 Nov 2009 13:15:53 +0000 (14:15 +0100)
committerVladimir 'phcoder' Serbinenko <phcoder@gmail.com>
Sat, 28 Nov 2009 13:15:53 +0000 (14:15 +0100)
ChangeLog.relocators [new file with mode: 0644]

diff --git a/ChangeLog.relocators b/ChangeLog.relocators
new file mode 100644 (file)
index 0000000..4e43b1b
--- /dev/null
@@ -0,0 +1,77 @@
+2009-11-28  Vladimir Serbinenko  <phcoder@gmail.com>
+
+       Relocator framework
+
+       * THANKS: Add David Miller.
+       * loader/i386/xnu_helper.S: Removed. All users updated.
+       * conf/i386.rmk (pkglib_MODULES): Add relocator.mod.
+       (relocator_mod_SOURCES): New variable.
+       (relocator_mod_CFLAGS): Likewise.
+       (relocator_mod_LDFLAGS): Likewise.
+       (relocator_mod_ASFLAGS): Likewise.
+       * conf/x86_64.rmk: Likewise.
+       * include/grub/i386/multiboot.h (grub_multiboot_payload_orig): Removed.
+       (grub_multiboot_payload_entry_offset): Likewise.
+       (grub_multiboot_forward_relocator): Likewise.
+       (grub_multiboot_forward_relocator_end): Likewise.
+       (grub_multiboot_backward_relocator): Likewise.
+       (grub_multiboot_backward_relocator_end): Likewise.
+       (grub_multiboot_payload_eip): New variable.
+       (grub_multiboot_payload_orig): Likewise.
+       (GRUB_MULTIBOOT_STACK_SIZE): New definition.
+       * include/grub/i386/pc/memory.h: Include grub/i386/memory.h.
+       (GRUB_MEMORY_MACHINE_CR0_PE_ON): Move from here ...
+       * include/grub/i386/memory.h
+       (GRUB_MEMORY_CPU_CR0_PE_ON): ... to here
+       (GRUB_MEMORY_CPU_CR4_PAE_ON): New definition.
+       (GRUB_MEMORY_CPU_CR0_PAGING_ON): Likewise.
+       (GRUB_MEMORY_CPU_AMD64_MSR): Likewise.
+       (GRUB_MEMORY_CPU_AMD64_MSR_ON): Likewise.
+       * include/grub/i386/relocator.h: New file.
+       * include/grub/x86_64/relocator.h: Likewise.
+       * include/grub/i386/xnu.h: Include grub/cpu/relocator.h.
+       (XNU_RELOCATOR): New macro.
+       (grub_xnu_launcher_start): Remove.
+       (grub_xnu_launcher_end): Likewise.
+       * include/grub/xnu.h (grub_xnu_boot_resume): New prototype.
+       (grub_xnu_heap_real_start): Remove.
+       (grub_xnu_heap_start): Change to void *. All users updated.
+       * kern/i386/realmode.S (real_to_prot): Use GRUB_MEMORY_CPU_CR0_PE_ON.
+       * lib/i386/relocator.c: New file.
+       * lib/i386/relocator_asm.S: Likewise.
+       * lib/i386/relocator_backward.S: Likewise.
+       * lib/mips/relocator.c: Likewise.
+       * lib/mips/relocator_asm.S: Likewise.
+       * lib/relocator.c: Likewise.
+       * loader/i386/multiboot.c: Include grub/i386/relocator.h.
+       (entry): Removed.
+       (playground): Likewise.
+       (grub_multiboot_payload_orig): New variable.
+       (grub_multiboot_payload_dest): Likewise.
+       (grub_multiboot_payload_size): Likewise.
+       (grub_multiboot_payload_eip): Likewise.
+       (grub_multiboot_payload_esp): Likewise.
+       (grub_multiboot_boot): Use grub_relocator32_boot.
+       (grub_multiboot_unload): Free relocators.
+       (grub_multiboot): Setup stack. Use relocators.
+       * loader/i386/multiboot_elfxx.c: Include grub/i386/relocator.h.
+       (grub_multiboot_load_elfXX): Use relocators.
+       * loader/i386/multiboot_helper.S (grub_multiboot_payload_orig): Removed.
+       (grub_multiboot_payload_size): Likewise.
+       (grub_multiboot_payload_dest): Likewise.
+       (grub_multiboot_payload_entry_offset): Likewise.
+       (grub_multiboot_forward_relocator): Likewise.
+       (grub_multiboot_backward_relocator): Likewise.
+       (grub_multiboot_real_boot): Likewise.
+       * loader/i386/xnu.c (grub_xnu_heap_will_be_at): New variable.
+       (grub_xnu_entry_point): Likewise.
+       (grub_xnu_arg1): Likewise.
+       (grub_xnu_stack): Likewise.
+       (grub_xnu_launch): Removed.
+       (grub_xnu_boot_resume): New function.
+       (grub_xnu_boot): Use relocators.
+       * loader/i386/xnu_helper.S: Removed.
+       * loader/xnu.c (grub_xnu_heap_start): New variable.
+       (grub_xnu_heap_size): Likewise.
+       (grub_xnu_heap_malloc): Use relocators.
+       * loader/xnu_resume.c (grub_xnu_resume): Use relocators.