|
@@ -61,71 +61,6 @@
|
|
|
|
|
|
__HEAD
|
|
|
ENTRY(startup_32)
|
|
|
-#ifdef CONFIG_EFI_STUB
|
|
|
- jmp preferred_addr
|
|
|
-
|
|
|
- /*
|
|
|
- * We don't need the return address, so set up the stack so
|
|
|
- * efi_main() can find its arguments.
|
|
|
- */
|
|
|
-ENTRY(efi_pe_entry)
|
|
|
- add $0x4, %esp
|
|
|
-
|
|
|
- call 1f
|
|
|
-1: popl %esi
|
|
|
- subl $1b, %esi
|
|
|
-
|
|
|
- popl %ecx
|
|
|
- movl %ecx, efi32_config(%esi) /* Handle */
|
|
|
- popl %ecx
|
|
|
- movl %ecx, efi32_config+8(%esi) /* EFI System table pointer */
|
|
|
-
|
|
|
- /* Relocate efi_config->call() */
|
|
|
- leal efi32_config(%esi), %eax
|
|
|
- add %esi, 40(%eax)
|
|
|
- pushl %eax
|
|
|
-
|
|
|
- call make_boot_params
|
|
|
- cmpl $0, %eax
|
|
|
- je fail
|
|
|
- movl %esi, BP_code32_start(%eax)
|
|
|
- popl %ecx
|
|
|
- pushl %eax
|
|
|
- pushl %ecx
|
|
|
- jmp 2f /* Skip efi_config initialization */
|
|
|
-
|
|
|
-ENTRY(efi32_stub_entry)
|
|
|
- add $0x4, %esp
|
|
|
- popl %ecx
|
|
|
- popl %edx
|
|
|
-
|
|
|
- call 1f
|
|
|
-1: popl %esi
|
|
|
- subl $1b, %esi
|
|
|
-
|
|
|
- movl %ecx, efi32_config(%esi) /* Handle */
|
|
|
- movl %edx, efi32_config+8(%esi) /* EFI System table pointer */
|
|
|
-
|
|
|
- /* Relocate efi_config->call() */
|
|
|
- leal efi32_config(%esi), %eax
|
|
|
- add %esi, 40(%eax)
|
|
|
- pushl %eax
|
|
|
-2:
|
|
|
- call efi_main
|
|
|
- cmpl $0, %eax
|
|
|
- movl %eax, %esi
|
|
|
- jne 2f
|
|
|
-fail:
|
|
|
- /* EFI init failed, so hang. */
|
|
|
- hlt
|
|
|
- jmp fail
|
|
|
-2:
|
|
|
- movl BP_code32_start(%esi), %eax
|
|
|
- leal preferred_addr(%eax), %eax
|
|
|
- jmp *%eax
|
|
|
-
|
|
|
-preferred_addr:
|
|
|
-#endif
|
|
|
cld
|
|
|
/*
|
|
|
* Test KEEP_SEGMENTS flag to see if the bootloader is asking
|
|
@@ -208,6 +143,70 @@ preferred_addr:
|
|
|
jmp *%eax
|
|
|
ENDPROC(startup_32)
|
|
|
|
|
|
+#ifdef CONFIG_EFI_STUB
|
|
|
+/*
|
|
|
+ * We don't need the return address, so set up the stack so efi_main() can find
|
|
|
+ * its arguments.
|
|
|
+ */
|
|
|
+ENTRY(efi_pe_entry)
|
|
|
+ add $0x4, %esp
|
|
|
+
|
|
|
+ call 1f
|
|
|
+1: popl %esi
|
|
|
+ subl $1b, %esi
|
|
|
+
|
|
|
+ popl %ecx
|
|
|
+ movl %ecx, efi32_config(%esi) /* Handle */
|
|
|
+ popl %ecx
|
|
|
+ movl %ecx, efi32_config+8(%esi) /* EFI System table pointer */
|
|
|
+
|
|
|
+ /* Relocate efi_config->call() */
|
|
|
+ leal efi32_config(%esi), %eax
|
|
|
+ add %esi, 40(%eax)
|
|
|
+ pushl %eax
|
|
|
+
|
|
|
+ call make_boot_params
|
|
|
+ cmpl $0, %eax
|
|
|
+ je fail
|
|
|
+ movl %esi, BP_code32_start(%eax)
|
|
|
+ popl %ecx
|
|
|
+ pushl %eax
|
|
|
+ pushl %ecx
|
|
|
+ jmp 2f /* Skip efi_config initialization */
|
|
|
+ENDPROC(efi_pe_entry)
|
|
|
+
|
|
|
+ENTRY(efi32_stub_entry)
|
|
|
+ add $0x4, %esp
|
|
|
+ popl %ecx
|
|
|
+ popl %edx
|
|
|
+
|
|
|
+ call 1f
|
|
|
+1: popl %esi
|
|
|
+ subl $1b, %esi
|
|
|
+
|
|
|
+ movl %ecx, efi32_config(%esi) /* Handle */
|
|
|
+ movl %edx, efi32_config+8(%esi) /* EFI System table pointer */
|
|
|
+
|
|
|
+ /* Relocate efi_config->call() */
|
|
|
+ leal efi32_config(%esi), %eax
|
|
|
+ add %esi, 40(%eax)
|
|
|
+ pushl %eax
|
|
|
+2:
|
|
|
+ call efi_main
|
|
|
+ cmpl $0, %eax
|
|
|
+ movl %eax, %esi
|
|
|
+ jne 2f
|
|
|
+fail:
|
|
|
+ /* EFI init failed, so hang. */
|
|
|
+ hlt
|
|
|
+ jmp fail
|
|
|
+2:
|
|
|
+ movl BP_code32_start(%esi), %eax
|
|
|
+ leal startup_32(%eax), %eax
|
|
|
+ jmp *%eax
|
|
|
+ENDPROC(efi32_stub_entry)
|
|
|
+#endif
|
|
|
+
|
|
|
.text
|
|
|
relocated:
|
|
|
|