]> git.ipfire.org Git - thirdparty/grub.git/commitdiff
kfreebsd-i386 bootcheck
authorVladimir 'phcoder' Serbinenko <phcoder@gmail.com>
Mon, 18 Jan 2010 21:29:25 +0000 (22:29 +0100)
committerVladimir 'phcoder' Serbinenko <phcoder@gmail.com>
Mon, 18 Jan 2010 21:29:25 +0000 (22:29 +0100)
conf/i386.rmk
tests/boot/knetbsd.cfg [new file with mode: 0644]
tests/boot/knetbsd.init-i386.S [new file with mode: 0644]

index b1adb13d962f453ccb5513119802d58f62526df2..c9ba18b11fbf3929fa27ce3c06ace03ef3aac4a9 100644 (file)
@@ -81,14 +81,26 @@ kfreebsd.init.x86_64: $(srcdir)/tests/boot/kfreebsd.init-x86_64.S
 kfreebsd.init.i386: $(srcdir)/tests/boot/kfreebsd.init-i386.S
        $(TARGET_CC) -o $@ $< -m32 -nostdlib -nostdinc -DSUCCESSFUL_BOOT_STRING=\"$(SUCCESSFUL_BOOT_STRING)\" && freebsd-brandelf -t FreeBSD $@
 
-linux-initramfs.%: linux.init.% Makefile
+knetbsd.init.i386: $(srcdir)/tests/boot/knetbsd.init-i386.S
+       $(TARGET_CC) -o $@ $< -m32 -nostdlib -nostdinc -DSUCCESSFUL_BOOT_STRING=\"$(SUCCESSFUL_BOOT_STRING)\"
+
+linux-initramfs.%: linux.init.%
        TDIR=`mktemp -d`; cp $< $$TDIR/init; (cd $$TDIR; echo ./init | cpio --quiet --dereference -o -H newc) | gzip > $@; rm -rf $$TDIR
 
-kfreebsd-mfsroot.%: kfreebsd.init.% Makefile
+kfreebsd-mfsroot.%: kfreebsd.init.%
        TDIR=`mktemp -d`; mkdir $$TDIR/dev; mkdir $$TDIR/sbin; cp $< $$TDIR/sbin/init; makefs -t ffs -s 30m -f 1000 -o minfree=0,version=1 $@ $$TDIR; rm -rf $$TDIR
 
+knetbsd.image.%: knetbsd.init.%
+       TDIR=`mktemp -d` && mkdir $$TDIR/dev && mkdir $$TDIR/sbin && cp $< $$TDIR/sbin/init && makefs -t ffs -s 30m -f 1000 -o minfree=0,version=1 $@ $$TDIR && rm -rf $$TDIR
+
+knetbsd.miniroot-image.i386: knetbsd.image.i386 $(GRUB_PAYLOADS_DIR)/knetbsd.miniroot.i386
+       $(OBJCOPY) --add-section=miniroot=$< $(GRUB_PAYLOADS_DIR)/knetbsd.miniroot.i386 $@
+
 CLEANFILES += linux.init.i386 kfreebsd.init.i386 linux.init.x86_64 linux-initramfs.i386 linux-initramfs.x86_64
 
+bootcheck-knetbsd-i386: knetbsd.miniroot-image.i386 $(GRUB_PAYLOADS_DIR)/knetbsd.i386 $(srcdir)/tests/boot/knetbsd.cfg knetbsd.miniroot-image.i386 grub-shell
+       timeout -s KILL $(BOOTCHECK_TIMEOUT) ./grub-shell --boot=$(BOOTTARGET) --qemu=qemu-system-i386 --files=/miniroot=knetbsd.miniroot-image.i386 --files=/knetbsd=$(GRUB_PAYLOADS_DIR)/knetbsd.i386 $(srcdir)/tests/boot/knetbsd.cfg | grep $(SUCCESSFUL_BOOT_STRING) > /dev/null
+
 bootcheck-kfreebsd-i386: kfreebsd-mfsroot.i386 $(GRUB_PAYLOADS_DIR)/kfreebsd.i386 $(GRUB_PAYLOADS_DIR)/kfreebsd_env.i386 $(srcdir)/tests/boot/kfreebsd.cfg grub-shell
        timeout -s KILL $(BOOTCHECK_TIMEOUT) ./grub-shell --boot=$(BOOTTARGET) --qemu=qemu-system-i386 --files=/mfsroot=kfreebsd-mfsroot.i386 --files=/kfreebsd=$(GRUB_PAYLOADS_DIR)/kfreebsd.i386 --files=/kfreebsd_env=$(GRUB_PAYLOADS_DIR)/kfreebsd_env.i386 $(srcdir)/tests/boot/kfreebsd.cfg | grep $(SUCCESSFUL_BOOT_STRING) > /dev/null
 
@@ -102,7 +114,9 @@ bootcheck-linux-x86_64: linux-initramfs.x86_64 $(GRUB_PAYLOADS_DIR)/linux.x86_64
        timeout -s KILL $(BOOTCHECK_TIMEOUT) ./grub-shell --boot=$(BOOTTARGET) --qemu=qemu-system-x86_64 --files=/initrd=linux-initramfs.x86_64 --files=/linux=$(GRUB_PAYLOADS_DIR)/linux.x86_64 $(srcdir)/tests/boot/linux.cfg | grep $(SUCCESSFUL_BOOT_STRING) > /dev/null
 
 BOOTCHECKS+=bootcheck-linux-i386 bootcheck-linux-x86_64 \
-       bootcheck-kfreebsd-i386 bootcheck-kfreebsd-x86_64
+       bootcheck-kfreebsd-i386 bootcheck-kfreebsd-x86_64 \
+       bootcheck-knetbsd-i386
 
 .PHONY: bootcheck-linux-i386 bootcheck-linux-x86_64 \
        bootcheck-kfreebsd-i386 bootcheck-kfreebsd-x86_64
+       bootcheck-knetbsd-i386
\ No newline at end of file
diff --git a/tests/boot/knetbsd.cfg b/tests/boot/knetbsd.cfg
new file mode 100644 (file)
index 0000000..ad2258d
--- /dev/null
@@ -0,0 +1,5 @@
+knetbsd /knetbsd -h
+knetbsd_module_elf /miniroot
+boot
+# Shouln't happen
+halt
diff --git a/tests/boot/knetbsd.init-i386.S b/tests/boot/knetbsd.init-i386.S
new file mode 100644 (file)
index 0000000..200aed0
--- /dev/null
@@ -0,0 +1,134 @@
+/*
+ *  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 <http://www.gnu.org/licenses/>.
+ */
+
+#define MODE_RDRW 2
+#define FLAGS_NONE 0
+#define SYSCALL_OPEN 5
+#define SYSCALL_WRITE 4
+#define SYSCALL_RESET 208
+#define SYSCALL_EXIT 1
+#define SYSCALL_MKNOD 14
+#define SYSCALL_MOUNT 410
+#define SYSCALL_INT 0x80
+
+#define RESET_NOSYNC 0x4
+#define RESET_HALT 0x8
+#define RESET_POWEROFF 0x800
+
+       .section ".init", "ax"
+       .global start,_start
+start:
+_start:
+       /* mount.  */
+       movl $SYSCALL_MOUNT, %eax
+       push $(tmpfs_args_end - tmpfs_args)
+       push $tmpfs_args
+       push $0
+       push $devfsdir
+       push $devfstype
+       pushl $0
+       int $SYSCALL_INT
+       addl $20, %esp
+
+       /* mknod.  */
+       movl $SYSCALL_MKNOD, %eax
+       pushl $0
+       pushl $0x2140
+       leal device, %ebx
+       pushl %ebx
+       pushl $0
+       int $SYSCALL_INT
+       addl $16, %esp
+
+       /* 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
+
+       /* shutdown.  */
+       movl $SYSCALL_RESET, %eax
+       pushl $haltmsg
+       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:
+haltmsg:
+       .ascii "Machine halted"
+       .byte 0
+devfstype:
+       .ascii "tmpfs"
+       .byte 0
+devfsdir:
+       .ascii "/dev"
+       .byte 0
+tmpfs_args:
+       /* Version.  */
+       .long 1
+
+       /* Maximum inodes.  */
+       .quad   0
+       /* Maximum size.  */
+       .quad   0
+
+       /* UID */
+       .long           0
+       /* GID */
+       .long           0
+       /* Mode */
+       .long           0777
+tmpfs_args_end:        
\ No newline at end of file