mattdm / rpms / grub2

Forked from rpms/grub2 6 years ago
Clone
31004e6
From 7789de5b693525b7df0fca50d68000c26bdcfe8c Mon Sep 17 00:00:00 2001
31004e6
From: Vladimir 'phcoder' Serbinenko <phcoder@gmail.com>
31004e6
Date: Thu, 11 Apr 2013 21:09:43 +0200
f74b50e
Subject: [PATCH 279/482] 	Use ACPI shutdown intests as traditional port
31004e6
 was removed.
31004e6
31004e6
---
31004e6
 ChangeLog                                   |  4 +++
31004e6
 grub-core/tests/boot/kbsd.init-i386.S       | 20 +------------
31004e6
 grub-core/tests/boot/kbsd.init-x86_64.S     | 19 +-----------
31004e6
 grub-core/tests/boot/kernel-8086.S          | 21 +-------------
31004e6
 grub-core/tests/boot/kernel-i386.S          | 21 ++------------
31004e6
 grub-core/tests/boot/kfreebsd.init-i386.S   | 45 +++++++++++++----------------
31004e6
 grub-core/tests/boot/kfreebsd.init-x86_64.S | 40 ++++++++++---------------
31004e6
 grub-core/tests/boot/linux.init-i386.S      | 20 +------------
31004e6
 grub-core/tests/boot/linux.init-x86_64.S    | 20 +------------
31004e6
 grub-core/tests/boot/qemu-shutdown-x86.S    |  9 ++++++
31004e6
 10 files changed, 56 insertions(+), 163 deletions(-)
31004e6
 create mode 100644 grub-core/tests/boot/qemu-shutdown-x86.S
31004e6
31004e6
diff --git a/ChangeLog b/ChangeLog
31004e6
index bb6d97b..614748a 100644
31004e6
--- a/ChangeLog
31004e6
+++ b/ChangeLog
31004e6
@@ -1,3 +1,7 @@
31004e6
+2013-04-11  Vladimir Serbinenko  <phcoder@gmail.com>
31004e6
+
31004e6
+	Use ACPI shutdown intests as traditional port was removed.
31004e6
+
31004e6
 2013-04-11  Andrey Borzenkov <arvidjaar@gmail.com>
31004e6
 
31004e6
 	* util/grub.d/30_os-prober.in: Add onstr to entries for visual
31004e6
diff --git a/grub-core/tests/boot/kbsd.init-i386.S b/grub-core/tests/boot/kbsd.init-i386.S
31004e6
index 7011c79..72ddb7c 100644
31004e6
--- a/grub-core/tests/boot/kbsd.init-i386.S
31004e6
+++ b/grub-core/tests/boot/kbsd.init-i386.S
31004e6
@@ -37,8 +37,6 @@
31004e6
 #define RESET_HALT 0x8
31004e6
 #define RESET_POWEROFF 0x800
31004e6
 
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
-
31004e6
 	.section ".init", "ax"
31004e6
 	.global start,_start
31004e6
 start:
31004e6
@@ -72,23 +70,7 @@ _start:
31004e6
 	int $SYSCALL_INT
31004e6
 	addl $12, %esp
31004e6
 
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 
31004e6
 	/* shutdown.  */
31004e6
 	movl $SYSCALL_RESET, %eax
31004e6
diff --git a/grub-core/tests/boot/kbsd.init-x86_64.S b/grub-core/tests/boot/kbsd.init-x86_64.S
31004e6
index 81f810e..7486bc3 100644
31004e6
--- a/grub-core/tests/boot/kbsd.init-x86_64.S
31004e6
+++ b/grub-core/tests/boot/kbsd.init-x86_64.S
31004e6
@@ -35,7 +35,6 @@
31004e6
 #define RESET_NOSYNC 0x4
31004e6
 #define RESET_HALT 0x8
31004e6
 #define RESET_POWEROFF 0x800
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
 
31004e6
 	.section ".init", "ax"
31004e6
 	.global start,_start
31004e6
@@ -61,23 +60,7 @@ _start:
31004e6
 	leaq iopl_arg, %rsi
31004e6
 	syscall
31004e6
 
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 
31004e6
 	/* shutdown.  */
31004e6
 	movq $SYSCALL_RESET, %rax
31004e6
diff --git a/grub-core/tests/boot/kernel-8086.S b/grub-core/tests/boot/kernel-8086.S
31004e6
index 20040da..510897c 100644
31004e6
--- a/grub-core/tests/boot/kernel-8086.S
31004e6
+++ b/grub-core/tests/boot/kernel-8086.S
31004e6
@@ -1,6 +1,4 @@
31004e6
 
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
-
31004e6
 	.text
31004e6
 	.globl _start
31004e6
 _start:
31004e6
@@ -8,18 +6,6 @@ base:
31004e6
 	.code16
31004e6
 	jmp cont
31004e6
 
31004e6
-portmsg:
31004e6
-	xorw %ax, %ax
31004e6
-1:	
31004e6
-	movb 0(%si), %al
31004e6
-	test %ax, %ax
31004e6
-	jz 1f
31004e6
-	outb %al, %dx
31004e6
-	incw %si
31004e6
-	jmp 1b
31004e6
-1:
31004e6
-	ret
31004e6
-
31004e6
 serialmsg:	
31004e6
 1:	
31004e6
 	movb 0(%si), %bl
31004e6
@@ -50,17 +36,12 @@ cont:
31004e6
 	movw %ax, %ds
31004e6
 	lea message, %si
31004e6
 	call serialmsg
31004e6
-	lea shutdown, %si
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	call portmsg
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 
31004e6
 1:
31004e6
 	hlt
31004e6
 	jmp 1b
31004e6
 
31004e6
-shutdown:
31004e6
-	.ascii "Shutdown"
31004e6
-	.byte 0
31004e6
 message:
31004e6
 	.ascii "Boot Test Passed Successfully\n" SUCCESSFUL_BOOT_STRING "\n"
31004e6
 	.byte 0
31004e6
diff --git a/grub-core/tests/boot/kernel-i386.S b/grub-core/tests/boot/kernel-i386.S
31004e6
index 904b0d4..2154d3b 100644
31004e6
--- a/grub-core/tests/boot/kernel-i386.S
31004e6
+++ b/grub-core/tests/boot/kernel-i386.S
31004e6
@@ -5,8 +5,6 @@
31004e6
 #include <multiboot.h>
31004e6
 #endif
31004e6
 
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
-
31004e6
 	.text
31004e6
 	/* Align 32 bits boundary.  */
31004e6
 	.align	8
31004e6
@@ -38,17 +36,6 @@ multiboot_header:
31004e6
 #endif
31004e6
 	
31004e6
 	.global start
31004e6
-portmsg:
31004e6
-	xorl %eax, %eax
31004e6
-1:	
31004e6
-	movb 0(%esi), %al
31004e6
-	test %eax, %eax
31004e6
-	jz 1f
31004e6
-	outb %al, %dx
31004e6
-	incl %esi
31004e6
-	jmp 1b
31004e6
-1:
31004e6
-	ret
31004e6
 
31004e6
 serialmsg:	
31004e6
 1:	
31004e6
@@ -73,17 +60,13 @@ serialmsg:
31004e6
 _start:
31004e6
 	lea message, %esi
31004e6
 	call serialmsg
31004e6
-	lea shutdown, %esi
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	call portmsg
31004e6
+
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 
31004e6
 1:
31004e6
 	hlt
31004e6
 	jmp 1b
31004e6
 
31004e6
-shutdown:
31004e6
-	.ascii "Shutdown"
31004e6
-	.byte 0
31004e6
 message:
31004e6
 	.ascii "Boot Test Passed Successfully\n" SUCCESSFUL_BOOT_STRING "\n"
31004e6
 	.byte 0
31004e6
diff --git a/grub-core/tests/boot/kfreebsd.init-i386.S b/grub-core/tests/boot/kfreebsd.init-i386.S
31004e6
index 12c94a0..a448152 100644
31004e6
--- a/grub-core/tests/boot/kfreebsd.init-i386.S
31004e6
+++ b/grub-core/tests/boot/kfreebsd.init-i386.S
31004e6
@@ -24,13 +24,12 @@
31004e6
 #define SYSCALL_FSYNC 95
31004e6
 #define SYSCALL_ARCH 165
31004e6
 #define SYSCALL_EXIT 1
31004e6
-#define SYSCALL_ARCH_IOPL	4
31004e6
+#define SYSCALL_ARCH_IOPERM	4
31004e6
 #define SYSCALL_INT 0x80
31004e6
 
31004e6
 #define RESET_NOSYNC 0x4
31004e6
 #define RESET_HALT 0x8
31004e6
 #define RESET_POWEROFF 0x4000
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
 
31004e6
 	.section ".init", "ax"
31004e6
 	.global start,_start
31004e6
@@ -64,31 +63,23 @@ _start:
31004e6
 	int $SYSCALL_INT
31004e6
 	addl $8, %esp
31004e6
 
31004e6
-	/* IOPL.  */
31004e6
+	/* IOPERM.  */
31004e6
 	movl $SYSCALL_ARCH, %eax
31004e6
-	pushl $iopl_arg
31004e6
-	pushl $SYSCALL_ARCH_IOPL
31004e6
+	pushl $iopl_arg1
31004e6
+	pushl $SYSCALL_ARCH_IOPERM
31004e6
 	pushl $0
31004e6
 	int $SYSCALL_INT
31004e6
 	addl $12, %esp
31004e6
-	
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+
31004e6
+	/* IOPERM.  */
31004e6
+	movl $SYSCALL_ARCH, %eax
31004e6
+	pushl $iopl_arg2
31004e6
+	pushl $SYSCALL_ARCH_IOPERM
31004e6
+	pushl $0
31004e6
+	int $SYSCALL_INT
31004e6
+	addl $12, %esp
31004e6
+
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 	
31004e6
 	/* shutdown.  */
31004e6
 	movl $SYSCALL_RESET, %eax
31004e6
@@ -108,7 +99,11 @@ device:
31004e6
 message:
31004e6
 	.ascii "Boot Test Passed Successfully\n" SUCCESSFUL_BOOT_STRING "\n"
31004e6
 messageend:
31004e6
-iopl_arg:
31004e6
-	.long SHUTDOWN_PORT
31004e6
+ioperm_arg1:
31004e6
+	.long 0xcf8
31004e6
+	.long 8
31004e6
 	.long 1
31004e6
+ioperm_arg2:
31004e6
+	.long 0x1000
31004e6
+	.long 8
31004e6
 	.long 1
31004e6
diff --git a/grub-core/tests/boot/kfreebsd.init-x86_64.S b/grub-core/tests/boot/kfreebsd.init-x86_64.S
31004e6
index 0a9ff51..de7bab6 100644
31004e6
--- a/grub-core/tests/boot/kfreebsd.init-x86_64.S
31004e6
+++ b/grub-core/tests/boot/kfreebsd.init-x86_64.S
31004e6
@@ -23,13 +23,12 @@
31004e6
 #define SYSCALL_WRITE 4
31004e6
 #define SYSCALL_RESET 55
31004e6
 #define SYSCALL_EXIT 1
31004e6
-#define SYSCALL_ARCH_IOPL	4
31004e6
+#define SYSCALL_ARCH_IOPERM	4
31004e6
 #define SYSCALL_FSYNC 95
31004e6
 
31004e6
 #define RESET_NOSYNC 0x4
31004e6
 #define RESET_HALT 0x8
31004e6
 #define RESET_POWEROFF 0x4000
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
 
31004e6
 	.section ".init", "ax"
31004e6
 	.global start,_start
31004e6
@@ -53,29 +52,18 @@ _start:
31004e6
 	movq $SYSCALL_FSYNC, %rax
31004e6
 	syscall
31004e6
 
31004e6
-	/* IOPL.  */
31004e6
+	/* IOPERM.  */
31004e6
 	movq $SYSCALL_ARCH, %rax
31004e6
-	movq $SYSCALL_ARCH_IOPL, %rdi
31004e6
-	leaq iopl_arg, %rsi
31004e6
+	movq $SYSCALL_ARCH_IOPERM, %rdi
31004e6
+	leaq ioperm_arg1, %rsi
31004e6
 	syscall
31004e6
 
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+	movq $SYSCALL_ARCH, %rax
31004e6
+	movq $SYSCALL_ARCH_IOPERM, %rdi
31004e6
+	leaq ioperm_arg2, %rsi
31004e6
+	syscall
31004e6
+
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 	
31004e6
 	/* shutdown.  */
31004e6
 	movq $SYSCALL_RESET, %rax
31004e6
@@ -92,7 +80,11 @@ device:
31004e6
 message:
31004e6
 	.ascii "Boot Test Passed Successfully\n" SUCCESSFUL_BOOT_STRING "\n"
31004e6
 messageend:
31004e6
-iopl_arg:
31004e6
-	.long SHUTDOWN_PORT
31004e6
+ioperm_arg1:
31004e6
+	.long 0xcf8
31004e6
+	.long 8
31004e6
 	.long 1
31004e6
+ioperm_arg2:
31004e6
+	.long 0x1000
31004e6
+	.long 8
31004e6
 	.long 1
31004e6
diff --git a/grub-core/tests/boot/linux.init-i386.S b/grub-core/tests/boot/linux.init-i386.S
31004e6
index 5b0088e..c0983ac 100644
31004e6
--- a/grub-core/tests/boot/linux.init-i386.S
31004e6
+++ b/grub-core/tests/boot/linux.init-i386.S
31004e6
@@ -27,8 +27,6 @@
31004e6
 #define SHUTDOWN_MAGIC2 0x28121969
31004e6
 #define SHUTDOWN_MAGIC3 0x4321fedc
31004e6
 
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
-
31004e6
 	.text
31004e6
 	.global start, _start
31004e6
 _start:
31004e6
@@ -44,23 +42,7 @@ start:
31004e6
 	movl $3, %ebx
31004e6
 	int $SYSCALL_INT
31004e6
 
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 	
31004e6
 	/* shutdown.  */
31004e6
 	movl $SYSCALL_RESET, %eax
31004e6
diff --git a/grub-core/tests/boot/linux.init-x86_64.S b/grub-core/tests/boot/linux.init-x86_64.S
31004e6
index fc32dfd..90bdcc3 100644
31004e6
--- a/grub-core/tests/boot/linux.init-x86_64.S
31004e6
+++ b/grub-core/tests/boot/linux.init-x86_64.S
31004e6
@@ -26,8 +26,6 @@
31004e6
 #define SHUTDOWN_MAGIC2 0x28121969
31004e6
 #define SHUTDOWN_MAGIC3 0x4321fedc
31004e6
 
31004e6
-#define SHUTDOWN_PORT 0x8900
31004e6
-
31004e6
 	.text
31004e6
 	.global start, _start
31004e6
 _start:
31004e6
@@ -43,23 +41,7 @@ start:
31004e6
 	movq $3, %rdi
31004e6
 	syscall
31004e6
 
31004e6
-	movw $SHUTDOWN_PORT, %dx
31004e6
-	movb $'S', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'h', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'u', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'t', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'d', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'o', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'w', %al
31004e6
-	outb %al, %dx
31004e6
-	movb $'n', %al
31004e6
-	outb %al, %dx
31004e6
+#include "qemu-shutdown-x86.S"
31004e6
 	
31004e6
 	/* shutdown.  */
31004e6
 	movq $SYSCALL_RESET, %rax
31004e6
diff --git a/grub-core/tests/boot/qemu-shutdown-x86.S b/grub-core/tests/boot/qemu-shutdown-x86.S
31004e6
new file mode 100644
31004e6
index 0000000..8f794fc
31004e6
--- /dev/null
31004e6
+++ b/grub-core/tests/boot/qemu-shutdown-x86.S
31004e6
@@ -0,0 +1,9 @@
31004e6
+	movl $0x80000b40, %eax
31004e6
+	movw $0xcf8, %dx
31004e6
+	outl  %eax, %dx
31004e6
+	movl $0x1001, %eax
31004e6
+	movw $0xcfc, %dx
31004e6
+	outl  %eax, %dx
31004e6
+	movw $0x2000, %ax
31004e6
+	movw $0x1004, %dx	
31004e6
+	outw  %ax, %dx
31004e6
-- 
31004e6
1.8.2.1
31004e6