X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=Makefile.am;h=05613bbd00d7bb717cf4b269fbab27d8e82ea6b0;hb=8d0068a752ee8e6bc223de5cb7cac5d190a8855e;hp=cb1fdd2b87436c73b31b5745c08b58b54bb7ba18;hpb=b6233d1fff5d9a6bbc61e7123a57bdd7d8cbc792;p=libguestfs.git diff --git a/Makefile.am b/Makefile.am index cb1fdd2..05613bb 100644 --- a/Makefile.am +++ b/Makefile.am @@ -15,4 +15,67 @@ # along with this program; if not, write to the Free Software # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. -SUBDIRS = src examples +ACLOCAL_AMFLAGS = -I m4 + +SUBDIRS = src daemon examples + +EXTRA_DIST = make-initramfs.sh + +# Build the root filesystem. +# Currently this is arch-dependent, so it seems like putting it in +# $(libdir) is best. When we build cross-architecture filesystems we +# should probably move them to $(datadir). + +fsdir = $(libdir)/guestfs + +INITRAMFSIMG = initramfs.$(REPO).$(host_cpu).img +VMLINUZ = vmlinuz.$(REPO).$(host_cpu) + +fs_DATA = $(INITRAMFSIMG) $(VMLINUZ) + +$(INITRAMFSIMG) $(VMLINUZ): initramfs/fakeroot.log + +initramfs/fakeroot.log: make-initramfs.sh.in + -mv $(INITRAMFSIMG) $(INITRAMFSIMG).bak + -mv $(VMLINUZ) $(VMLINUZ).bak + bash $(builddir)/make-initramfs.sh || rm -f $@ + +$(INITRAMFSIMG): initramfs/fakeroot.log daemon/guestfsd + rm -f $@ + bash $(builddir)/update-initramfs.sh + touch $@ + +# Make clean. + +CLEANFILES = $(fs_DATA) emptydisk + +clean-local: + rm -rf initramfs + +# Test-boot the image. + +test-boot: emptydisk + qemu-system-$(host_cpu) \ + -m 384 \ + -kernel $(VMLINUZ) -initrd $(INITRAMFSIMG) \ + -hda emptydisk + +emptydisk: + rm -f emptydisk + dd if=/dev/zero of=emptydisk bs=1024 count=1440 + echo 0, | sfdisk -q -C 80 -H 2 -S 18 emptydisk > /dev/null + +# This is a more realistic test boot command line which better +# reflects what the library does. + +test-boot-realistic: emptydisk + qemu-system-$(host_cpu) \ + -m 384 \ + -kernel $(VMLINUZ) -initrd $(INITRAMFSIMG) \ + -hda emptydisk \ + -append "console=ttyS0 guestfs=10.0.2.4:6666" \ + -nographic \ + -serial stdio \ + -net channel,6666:unix:/tmp/sock,server,nowait \ + -net user,vlan=0 \ + -net nic,vlan=0