/* * GRUB -- GRand Unified Bootloader * Copyright (C) 2010 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 . */ #ifdef TARGET_NETBSD #define SYSCALL_RESET 208 #elif defined (TARGET_OPENBSD) #define SYSCALL_RESET 55 #else #error unknown target #endif #define MODE_RDRW 2 #define FLAGS_NONE 0 #define SYSCALL_OPEN 5 #define SYSCALL_WRITE 4 #define SYSCALL_EXIT 1 #define SYSCALL_ARCH 165 #define SYSCALL_INT 0x80 #define SYSCALL_ARCH_IOPL 2 #define RESET_NOSYNC 0x4 #define RESET_HALT 0x8 #define RESET_POWEROFF 0x800 #define SHUTDOWN_PORT 0x8900 .section ".init", "ax" .global start,_start start: _start: /* open. */ movl $SYSCALL_OPEN, %eax pushl $FLAGS_NONE pushl $MODE_RDRW leal device, %ebx pushl %ebx pushl $0 int $SYSCALL_INT addl $16, %esp movl %eax, %ecx /* write. */ movl $SYSCALL_WRITE, %eax pushl $(messageend-message) leal message, %ebx pushl %ebx pushl %ecx pushl $0 int $SYSCALL_INT addl $16, %esp /* IOPL. */ movl $SYSCALL_ARCH, %eax pushl $iopl_arg pushl $SYSCALL_ARCH_IOPL pushl $0 int $SYSCALL_INT addl $12, %esp movw $SHUTDOWN_PORT, %dx movb $'S', %al outb %al, %dx movb $'h', %al outb %al, %dx movb $'u', %al outb %al, %dx movb $'t', %al outb %al, %dx movb $'d', %al outb %al, %dx movb $'o', %al outb %al, %dx movb $'w', %al outb %al, %dx movb $'n', %al outb %al, %dx /* shutdown. */ movl $SYSCALL_RESET, %eax pushl $0 pushl $(RESET_POWEROFF|RESET_HALT|RESET_NOSYNC) pushl $0 int $SYSCALL_INT addl $8, %esp /* exit (1). Shouldn't be reached. */ movl $SYSCALL_EXIT, %eax pushl $1 pushl $0 int $SYSCALL_INT .section ".fini", "ax" 1: jmp 1b .section ".text", "ax" 1: jmp 1b /* This section is needed for NetBSD to identify the binary. */ .section ".note.netbsd.ident", "a" .long 0x7 .long 0x4 .long 0x1 .ascii "NetBSD" .byte 0 .data device: .ascii "/dev/console" .byte 0 message: .ascii "Boot Test Passed Successfully\n" SUCCESSFUL_BOOT_STRING "\n" messageend: iopl_arg: .long 3