diff options
Diffstat (limited to 'target/image')
-rw-r--r-- | target/image/x86/Config.in | 20 | ||||
-rw-r--r-- | target/image/x86/Makefile | 41 | ||||
-rwxr-xr-x | target/image/x86/gen_image.sh | 60 | ||||
-rw-r--r-- | target/image/x86/grub/Makefile | 58 | ||||
-rw-r--r-- | target/image/x86/grub/menu.lst | 11 |
5 files changed, 189 insertions, 1 deletions
diff --git a/target/image/x86/Config.in b/target/image/x86/Config.in new file mode 100644 index 000000000..fa61468c9 --- /dev/null +++ b/target/image/x86/Config.in @@ -0,0 +1,20 @@ +config X86_GRUB_IMAGES + bool "Build GRUB images (Linux x86 or x86_64 host only)" + depends LINUX_2_6_X86 + depends TARGET_ROOTFS_EXT2FS || TARGET_ROOTFS_JFFS2 + default y + +config X86_GRUB_BAUDRATE + int "Serial port baud rate" + depends X86_GRUB_IMAGES + default 38400 + +config X86_GRUB_KERNELPART + int "Kernel partition size (in MB)" + depends X86_GRUB_IMAGES + default 4 + +config X86_GRUB_FSPART + int "Filesystem partition size (in MB)" + depends X86_GRUB_IMAGES + default 16 diff --git a/target/image/x86/Makefile b/target/image/x86/Makefile index 919ccbc9f..b836f3ace 100644 --- a/target/image/x86/Makefile +++ b/target/image/x86/Makefile @@ -7,9 +7,48 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/image.mk +ifeq ($(CONFIG_X86_GRUB_IMAGES),y) + define Build/Compile + $(MAKE) -C grub compile + endef + + define Build/Clean + $(MAKE) -C grub clean + endef + + define Image/cmdline/jffs2-64k + block2mtd.block2mtd=/dev/hda2,65536 root=/dev/mtdblock0 rootfstype=jffs2 + endef + + define Image/cmdline/jffs2-128k + block2mtd.block2mtd=/dev/hda2,131072 root=/dev/mtdblock0 rootfstype=jffs2 + endef + + define Image/cmdline/ext2 + root=/dev/hda2 rootfstype=ext2 + endef + + define Image/Build/grub + mkdir -p $(KDIR)/root.grub/boot/grub + $(CP) \ + $(STAGING_DIR)/usr/lib/grub/i386-pc/stage1 \ + $(STAGING_DIR)/usr/lib/grub/i386-pc/stage2 \ + $(STAGING_DIR)/usr/lib/grub/i386-pc/e2fs_stage1_5 \ + $(KDIR)/root.grub/boot/grub/ + $(CP) $(LINUX_DIR)/arch/i386/boot/bzImage $(KDIR)/root.grub/boot/vmlinuz + sed \ + -e 's#@CMDLINE@#$(strip $(call Image/cmdline/$(1)))#g' \ + -e 's#@BAUDRATE@#$(CONFIG_X86_GRUB_BAUDRATE)#g' \ + ./grub/menu.lst > $(KDIR)/root.grub/boot/grub/menu.lst + PATH="$(STAGING_DIR)/usr/sbin:$(STAGING_DIR)/bin:$(PATH)" ./gen_image.sh $(BIN_DIR)/openwrt-$(BOARD)-$(KERNEL)-$(1).image $(CONFIG_X86_GRUB_KERNELPART) $(KDIR)/root.grub $(CONFIG_X86_GRUB_FSPART) $(KDIR)/root.$(1) + endef +endif + define Image/Build - cp $(KDIR)/root.$(1) $(BIN_DIR)/openwrt-$(BOARD)-$(KERNEL)-$(1).img + $(call Image/Build/grub,$(1)) + cp $(KDIR)/root.$(1) $(BIN_DIR)/openwrt-$(BOARD)-$(KERNEL)-$(1).fs cp $(LINUX_DIR)/arch/i386/boot/bzImage $(BIN_DIR)/openwrt-$(BOARD)-$(KERNEL)-vmlinuz endef + $(eval $(call BuildImage)) diff --git a/target/image/x86/gen_image.sh b/target/image/x86/gen_image.sh new file mode 100755 index 000000000..3edce1e40 --- /dev/null +++ b/target/image/x86/gen_image.sh @@ -0,0 +1,60 @@ +#!/bin/sh +# Copyright (C) 2006 OpenWrt.org + +[ $# == 5 ] || { + echo "SYNTAX: $0 <file> <kernel size> <kernel directory> <rootfs size> <rootfs image>" + exit 1 +} + +file="$1" +part1s="$2" +part1d="$3" +part2s="$4" +part2f="$5" + +head=16 +sect=63 +cyl=$(( ($part1s + $part2s) * 1024 * 1024 / ($head * $sect * 512))) + +dd if=/dev/zero of="$file" bs=1M count=$(($part1s + $part2s)) 2>/dev/null || exit +fdisk -u -C $cyl -H $head -S $sect "$file" > /dev/null 2>/dev/null <<EOF +n +p +1 + ++${part1s}M +n +p +2 + ++${part2s}M +w +q +EOF + +block() { + echo -e 'p\nq' | fdisk -u -C $cyl -H $head -S $sect "$file" | awk -v file="$file$1" -v n="$(($2 + 2))" ' +$1 == file { + print $n * 512 +}' +} + +start="$(block 1 0)" +end="$(block 1 1)" +blocks="$(( ($end - $start) / 1024 ))" + +genext2fs -d "$part1d" -b "$blocks" "$file.kernel" +dd if="$file.kernel" of="$file" bs=512 seek="$(($start / 512))" conv=notrunc +rm -f "$file.kernel" + +start="$(block 2 0)" +dd if="$part2f" of="$file" bs=512 seek="$(($start / 512))" conv=notrunc + +which chpax >/dev/null && chpax -zp $(which grub) +grub --device-map=/dev/null <<EOF +device (hd0) $file +geometry (hd0) $cyl $head $sect +root (hd0,0) +setup (hd0) +EOF + diff --git a/target/image/x86/grub/Makefile b/target/image/x86/grub/Makefile new file mode 100644 index 000000000..86a90016a --- /dev/null +++ b/target/image/x86/grub/Makefile @@ -0,0 +1,58 @@ +# +# Copyright (C) 2006 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# +# $Id: Makefile 4855 2006-09-24 20:49:31Z nico $ + +include $(TOPDIR)/rules.mk +include $(INCLUDE_DIR)/kernel.mk + +PKG_NAME:=grub +PKG_VERSION:=0.97 +PKG_RELEASE:=1 + +PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz +PKG_SOURCE_URL:=ftp://alpha.gnu.org/gnu/grub +PKG_MD5SUM:=cd3f3eb54446be6003156158d51f4884 +PKG_CAT:=zcat + +PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/grub-$(PKG_VERSION) + +include $(INCLUDE_DIR)/package.mk + +define Build/Configure + (cd $(PKG_BUILD_DIR); \ + LDFLAGS="-static" \ + ./configure \ + --target=$(GNU_TARGET_NAME) \ + --host=$(GNU_TARGET_NAME) \ + --build=$(GNU_HOST_NAME) \ + --program-prefix="" \ + --program-suffix="" \ + --prefix=/usr \ + --exec-prefix=/usr \ + --bindir=/usr/bin \ + --sbindir=/usr/sbin \ + --libexecdir=/usr/lib \ + --sysconfdir=/etc \ + --datadir=/usr/share \ + --localstatedir=/var \ + --mandir=/usr/man \ + --infodir=/usr/info \ + $(DISABLE_NLS) \ + ) +endef + +define Build/Compile + $(MAKE) -C $(PKG_BUILD_DIR) +endef + +define Build/InstallDev + $(MAKE) -C $(PKG_BUILD_DIR) \ + DESTDIR="$(STAGING_DIR)" \ + install +endef + +$(eval $(call Build/DefaultTargets)) diff --git a/target/image/x86/grub/menu.lst b/target/image/x86/grub/menu.lst new file mode 100644 index 000000000..39803c5bb --- /dev/null +++ b/target/image/x86/grub/menu.lst @@ -0,0 +1,11 @@ +serial --unit=0 --speed=@BAUDRATE@ --word=8 --parity=no --stop=1 +terminal --timeout=10 serial + +default 0 +timeout 5 + +title OpenWrt +root (hd0,0) +kernel /boot/vmlinuz @CMDLINE@ noinitrd console=ttyS0,@BAUDRATE@n8 +boot + |