diff --git a/Makefile b/Makefile index 5e8a4318..182ddf16 100644 --- a/Makefile +++ b/Makefile @@ -10,7 +10,7 @@ INSTALL := $(pwd)/install log_dir := $(build)/log BOARD ?= qemu-coreboot -CONFIG := $(pwd)/boards/$(BOARD).config +CONFIG := $(pwd)/boards/$(BOARD)/$(BOARD).config ifneq "y" "$(shell [ -r '$(CONFIG)' ] && echo y)" $(error $(CONFIG): board configuration does not exist) diff --git a/boards/kgpe-d16.config b/boards/kgpe-d16/kgpe-d16.config similarity index 100% rename from boards/kgpe-d16.config rename to boards/kgpe-d16/kgpe-d16.config diff --git a/boards/librem13v2.config b/boards/librem13v2/librem13v2.config similarity index 100% rename from boards/librem13v2.config rename to boards/librem13v2/librem13v2.config diff --git a/boards/qemu-coreboot.config b/boards/qemu-coreboot/qemu-coreboot.config similarity index 100% rename from boards/qemu-coreboot.config rename to boards/qemu-coreboot/qemu-coreboot.config diff --git a/boards/qemu-linuxboot.config b/boards/qemu-linuxboot/qemu-linuxboot.config similarity index 100% rename from boards/qemu-linuxboot.config rename to boards/qemu-linuxboot/qemu-linuxboot.config diff --git a/boards/r630.config b/boards/r630/r630.config similarity index 100% rename from boards/r630.config rename to boards/r630/r630.config diff --git a/boards/s2600wf.config b/boards/s2600wf/s2600wf.config similarity index 100% rename from boards/s2600wf.config rename to boards/s2600wf/s2600wf.config diff --git a/boards/winterfell/uinit.go b/boards/winterfell/uinit.go new file mode 100644 index 00000000..bf1d0767 --- /dev/null +++ b/boards/winterfell/uinit.go @@ -0,0 +1,44 @@ +// Copyright 2012-2017 the u-root Authors. All rights reserved +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +// This is winterfell init script +package main + +import ( + "log" + "os" + "os/exec" + "strings" +) + +var ( + commands = []string{ + "/bbin/insmod /lib/modules/nvme-core.ko", + "/bbin/insmod /lib/modules/nvme.ko", + "/bbin/insmod /lib/modules/libata.ko", + "/bbin/insmod /lib/modules/libahci.ko", + "/bbin/insmod /lib/modules/ahci.ko", + "/bbin/rsdp", + } +) + +func main() { + for _, line := range commands { + log.Printf("Executing Command: %v", line) + cmdSplit := strings.Split(line, " ") + if len(cmdSplit) == 0 { + continue + } + + cmd := exec.Command(cmdSplit[0], cmdSplit[1:]...) + cmd.Stdin = os.Stdin + cmd.Stderr = os.Stderr + cmd.Stdout = os.Stdout + if err := cmd.Run(); err != nil { + log.Print(err) + } + + } + log.Print("Uinit Done!") +} diff --git a/boards/winterfell.config b/boards/winterfell/winterfell.config similarity index 100% rename from boards/winterfell.config rename to boards/winterfell/winterfell.config diff --git a/boards/x220.config b/boards/x220/x220.config similarity index 100% rename from boards/x220.config rename to boards/x220/x220.config diff --git a/boards/x230-flash.config b/boards/x230-flash/x230-flash.config similarity index 100% rename from boards/x230-flash.config rename to boards/x230-flash/x230-flash.config diff --git a/boards/x230.config b/boards/x230/x230.config similarity index 100% rename from boards/x230.config rename to boards/x230/x230.config diff --git a/modules/u-root b/modules/u-root index 0720a640..1c936373 100644 --- a/modules/u-root +++ b/modules/u-root @@ -7,20 +7,32 @@ u-root_url := github.com/u-root/u-root u-root_output := $(build)/$(BOARD)/u-root.cpio +UROOT_CMDS ?= export GOPATH=$(build)/go +src_cmds := $(foreach cmd,$(UROOT_CMDS),github.com/u-root/u-root/cmds/$(cmd)) $(GOPATH): $(call do,GO GET,$(u-root_url),\ go get $(u-root_url) \ ) -$(u-root_output): $(GOPATH) +clean: + rm -f $(build)/$(BOARD)/u-root.cpio + +$(u-root_output): $(GOPATH) clean +ifeq ($(shell test -e boards/$(BOARD)/uinit.go && echo -n yes),yes) +ifeq ($(shell (test -d $(GOPATH)/src/github.com/u-root/u-root/cmds/uinit || echo -n yes)),yes) + mkdir $(GOPATH)/src/github.com/u-root/u-root/cmds/uinit +endif + cp boards/$(BOARD)/uinit.go $(GOPATH)/src/github.com/u-root/u-root/cmds/uinit +endif $(call do,U-ROOT,$@,\ $(GOPATH)/bin/u-root \ -build=bb \ -format=cpio \ - -o $@ \ + -o $@ \ + $(src_cmds)\ ) # Override the initrd inputs and add in the kernel modules