forked from csabahenk/cirros
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
91 lines (66 loc) · 2.88 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
This is a project to build a small cloud image that has useful tools and
function for debugging or developing cloud infrastructure.
The following works on Ubuntu 10.04 or 12.04 LTS.
To use it, you would do something like:
* get some build dependencies:
$ sudo apt-get -y install bison flex texinfo build-essential gettext ncurses-dev unzip bzr qemu-kvm cvs quilt ruby1.9.1
* get Cirros
$ git clone -b manila-service-generic https://github.com/csabahenk/cirros
$ cd cirros
* download buildroot and setup environment
$ git submodule init
$ git submodule update
* update ./bin/mkcabundle > src/etc/ssl/certs/ca-certificates.crt
$ ./bin/mkcabundle > src/etc/ssl/certs/ca-certificates.crt
* apply any local cirros patches to buildroot (note nfsv4 support is
available in a patch)
( cd buildroot && QUILT_PATCHES=$PWD/../patches-buildroot quilt push -a )
* download the buildroot sources
$ make ARCH=x86_64 br-source
* Build buildroot for a given arch
# ARCH should be set to 'i386', 'x86_64' or 'arm'
$ make ARCH=x86_64 OUT_D=$PWD/output/x86_64
This will do a full buildroot build, which will take a while. The output
that CirrOS is interested in is output/i386/rootfs.tar.
That file is the full buildroot filesystem, and is used as input for
subsequent steps here.
* Download a kernel to use.
The kernel input to bundle must be in deb format. The ubuntu '-virtual'
kernel is used as a starting point.
For example, to get the Ubuntu Saucy kernel for x86_64:
# Following links to find deb archive from
# https://launchpad.net/ubuntu/saucy/+package/linux-image
$ (cd download &&
wget http://launchpadlibrarian.net/164735055/linux-image-3.11.0-17-generic_3.11.0-17.31_amd64.deb)
* build disk images using bin/bundle
$ sudo ./bin/bundle -v output/$ARCH/rootfs.tar download/kernel-$ARCH.deb output/$ARCH/images
* Then, test using the images
$ kvm -drive file=disk.img,if=virtio -curses
$ kvm file=blank.img,if=virtio -curses \
-kernel kernel -initrd initrd -drive -append "debug-initrd"
To make changes in buildroot configuration:
* Have an up-to-date buildroot checkout
* Copy the conf file corresponding to your architecture
to buildroot tree
$ cp conf/buildroot-x86_64.config buildroot/.config
* Perform config changes
$ make -C buildroot menuconfig
* Copy back the config file to Cirros project space
to preserve it for further builds
$ cp buildroot/.config conf/buildroot-x86_64.config
* Commit to git
$ git commit -a
To update buildroot or switch to another version:
* Do the update and let git know of it
$ cd buildroot
$ git pull
or
$ git checkout <ref>
$ cd ..
$ git add buildroot
* Update config
$ cp conf/buildroot-x86_64.config buildroot/.config &&
make -C buildroot olddefconfig &&
cp buildroot/.config conf/buildroot-x86_64.config
* Commit to git
$ git commit -a