mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 1 | __author__ = """Copyright Martin J. Bligh, 2006, |
| 2 | Copyright IBM Corp. 2006, Ryan Harper <ryanh@us.ibm.com>""" |
| 3 | |
mbligh | 02ff2d5 | 2008-06-03 15:00:21 +0000 | [diff] [blame] | 4 | import os, shutil, copy, pickle, re, glob |
mbligh | c61fb36 | 2008-06-05 16:22:15 +0000 | [diff] [blame] | 5 | from autotest_lib.client.bin import kernel, kernel_config, os_dep, test |
mbligh | 34d0117 | 2008-06-05 16:26:31 +0000 | [diff] [blame] | 6 | from autotest_lib.client.bin import autotest_utils |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 7 | from autotest_lib.client.common_lib import utils |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 8 | |
| 9 | |
| 10 | class xen(kernel.kernel): |
| 11 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 12 | def log(self, msg): |
| 13 | print msg |
| 14 | self.logfile.write('%s\n' % msg) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 15 | |
| 16 | |
mbligh | 8b35285 | 2008-06-07 01:07:08 +0000 | [diff] [blame] | 17 | def __init__(self, job, base_tree, results_dir, tmp_dir, build_dir, |
| 18 | leave = False, kjob = None): |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 19 | # call base-class |
mbligh | 8b35285 | 2008-06-07 01:07:08 +0000 | [diff] [blame] | 20 | kernel.kernel.__init__(self, job, base_tree, results_dir, |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 21 | tmp_dir, build_dir, leave) |
| 22 | self.kjob = kjob |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 23 | |
| 24 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 25 | def config(self, config_file, config_list = None): |
| 26 | raise NotImplementedError('config() not implemented for xen') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 27 | |
| 28 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 29 | def build(self, make_opts = '', logfile = '', extraversion='autotest'): |
| 30 | """build xen |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 31 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 32 | make_opts |
| 33 | additional options to make, if any |
| 34 | """ |
| 35 | self.log('running build') |
| 36 | os_dep.commands('gcc', 'make') |
| 37 | # build xen with extraversion flag |
| 38 | os.environ['XEN_EXTRAVERSION'] = '-unstable-%s'% extraversion |
| 39 | if logfile == '': |
| 40 | logfile = os.path.join(self.log_dir, 'xen_build') |
| 41 | os.chdir(self.build_dir) |
| 42 | self.log('log_dir: %s ' % os.path.join(self.log_dir, 'stdout')) |
| 43 | self.job.stdout.tee_redirect(logfile + '.stdout') |
| 44 | self.job.stderr.tee_redirect(logfile + '.stderr') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 45 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 46 | # build xen hypervisor and user-space tools |
| 47 | targets = ['xen', 'tools'] |
| 48 | threads = 2 * autotest_utils.count_cpus() |
| 49 | for t in targets: |
| 50 | build_string = 'make -j %d %s %s' % (threads, make_opts, t) |
| 51 | self.log('build_string: %s' % build_string) |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 52 | utils.system(build_string) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 53 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 54 | # make a kernel job out of the kernel from the xen src if one isn't provided |
| 55 | if self.kjob == None: |
| 56 | # get xen kernel tree ready |
| 57 | self.log("prep-ing xen'ified kernel source tree") |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 58 | utils.system('make prep-kernels') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 59 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 60 | v = self.get_xen_kernel_build_ver() |
| 61 | self.log('building xen kernel version: %s' % v) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 62 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 63 | # build xen-ified kernel in xen tree |
| 64 | kernel_base_tree = os.path.join(self.build_dir, \ |
| 65 | 'linux-%s' % self.get_xen_kernel_build_ver()) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 66 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 67 | self.log('kernel_base_tree = %s' % kernel_base_tree) |
| 68 | # fix up XENGUEST value in EXTRAVERSION; we can't have |
| 69 | # files with '$(XENGEUST)' in the name, =( |
| 70 | self.fix_up_xen_kernel_makefile(kernel_base_tree) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 71 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 72 | # make the kernel job |
| 73 | self.kjob = self.job.kernel(kernel_base_tree) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 74 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 75 | # hardcoding dom0 config (no modules for testing, yay!) |
| 76 | # FIXME: probe host to determine which config to pick |
| 77 | c = self.build_dir + '/buildconfigs/linux-defconfig_xen0_x86_32' |
| 78 | self.log('using kernel config: %s ' % c) |
| 79 | self.kjob.config(c) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 80 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 81 | # Xen's kernel tree sucks; doesn't use bzImage, but vmlinux |
| 82 | self.kjob.set_build_target('vmlinuz') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 83 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 84 | # also, the vmlinuz is not out in arch/*/boot, ARGH! more hackery |
| 85 | self.kjob.set_build_image(self.job.tmpdir + '/build/linux/vmlinuz') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 86 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 87 | self.kjob.build() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 88 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 89 | self.job.stdout.restore() |
| 90 | self.job.stderr.restore() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 91 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 92 | xen_version = self.get_xen_build_ver() |
| 93 | self.log('BUILD VERSION: Xen: %s Kernel:%s' % \ |
| 94 | (xen_version, self.kjob.get_kernel_build_ver())) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 95 | |
| 96 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 97 | def build_timed(self, *args, **kwds): |
| 98 | raise NotImplementedError('build_timed() not implemented') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 99 | |
| 100 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 101 | def install(self, tag='', prefix = '/', extraversion='autotest'): |
| 102 | """make install in the kernel tree""" |
| 103 | self.log('Installing ...') |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 104 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 105 | os.chdir(self.build_dir) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 106 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 107 | if not os.path.isdir(prefix): |
| 108 | os.mkdir(prefix) |
| 109 | self.boot_dir = os.path.join(prefix, 'boot') |
| 110 | if not os.path.isdir(self.boot_dir): |
| 111 | os.mkdir(self.boot_dir) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 112 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 113 | # remember what we are going to install |
| 114 | xen_version = '%s-%s' % (self.get_xen_build_ver(), extraversion) |
| 115 | self.xen_image = self.boot_dir + '/xen-' + xen_version + '.gz' |
| 116 | self.xen_syms = self.boot_dir + '/xen-syms-' + xen_version |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 117 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 118 | self.log('Installing Xen ...') |
| 119 | os.environ['XEN_EXTRAVERSION'] = '-unstable-%s'% extraversion |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 120 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 121 | # install xen |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 122 | utils.system('make DESTDIR=%s -C xen install' % prefix) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 123 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 124 | # install tools |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 125 | utils.system('make DESTDIR=%s -C tools install' % prefix) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 126 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 127 | # install kernel |
| 128 | ktag = self.kjob.get_kernel_build_ver() |
| 129 | kprefix = prefix |
| 130 | self.kjob.install(tag=ktag, prefix=kprefix) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 131 | |
| 132 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 133 | def add_to_bootloader(self, tag='autotest', args=''): |
| 134 | """ add this kernel to bootloader, taking an |
| 135 | optional parameter of space separated parameters |
| 136 | e.g.: kernel.add_to_bootloader('mykernel', 'ro acpi=off') |
| 137 | """ |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 138 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 139 | # turn on xen mode |
| 140 | self.job.bootloader.enable_xen_mode() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 141 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 142 | # remove existing entry if present |
| 143 | self.job.bootloader.remove_kernel(tag) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 144 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 145 | # add xen and xen kernel |
mbligh | 8b35285 | 2008-06-07 01:07:08 +0000 | [diff] [blame] | 146 | self.job.bootloader.add_kernel(self.kjob.image, tag, |
| 147 | self.kjob.initrd, self.xen_image) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 148 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 149 | # if no args passed, populate from /proc/cmdline |
| 150 | if not args: |
| 151 | args = open('/proc/cmdline', 'r').readline().strip() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 152 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 153 | # add args to entry one at a time |
| 154 | for a in args.split(' '): |
| 155 | self.job.bootloader.add_args(tag, a) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 156 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 157 | # turn off xen mode |
| 158 | self.job.bootloader.disable_xen_mode() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 159 | |
| 160 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 161 | def get_xen_kernel_build_ver(self): |
| 162 | """Check xen buildconfig for current kernel version""" |
| 163 | version = patchlevel = sublevel = '' |
| 164 | extraversion = localversion = '' |
mbligh | f25cde1 | 2006-12-17 23:13:48 +0000 | [diff] [blame] | 165 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 166 | version_file = self.build_dir + '/buildconfigs/mk.linux-2.6-xen' |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 167 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 168 | for line in open(version_file, 'r').readlines(): |
| 169 | if line.startswith('LINUX_VER'): |
| 170 | start = line.index('=') + 1 |
| 171 | version = line[start:].strip() + "-xen" |
| 172 | break |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 173 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 174 | return version |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 175 | |
| 176 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 177 | def fix_up_xen_kernel_makefile(self, kernel_dir): |
| 178 | """Fix up broken EXTRAVERSION in xen-ified Linux kernel Makefile""" |
| 179 | xenguest = '' |
| 180 | makefile = kernel_dir + '/Makefile' |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 181 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 182 | for line in open(makefile, 'r').readlines(): |
| 183 | if line.startswith('XENGUEST'): |
| 184 | start = line.index('=') + 1 |
| 185 | xenguest = line[start:].strip() |
| 186 | break; |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 187 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 188 | # change out $XENGUEST in EXTRAVERSION line |
mbligh | 23955fc | 2008-06-12 17:41:18 +0000 | [diff] [blame^] | 189 | utils.system('sed -i.old "s,\$(XENGUEST),%s," %s' % (xenguest, |
| 190 | makefile)) |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 191 | |
| 192 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 193 | def get_xen_build_ver(self): |
| 194 | """Check Makefile and .config to return kernel version""" |
| 195 | version = patchlevel = sublevel = '' |
| 196 | extraversion = localversion = '' |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 197 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 198 | for line in open(self.build_dir + '/xen/Makefile', 'r').readlines(): |
| 199 | if line.startswith('export XEN_VERSION'): |
| 200 | start = line.index('=') + 1 |
| 201 | version = line[start:].strip() |
| 202 | if line.startswith('export XEN_SUBVERSION'): |
| 203 | start = line.index('=') + 1 |
| 204 | sublevel = line[start:].strip() |
| 205 | if line.startswith('export XEN_EXTRAVERSION'): |
| 206 | start = line.index('=') + 1 |
| 207 | extraversion = line[start:].strip() |
mbligh | 8baa2ea | 2006-12-17 23:01:24 +0000 | [diff] [blame] | 208 | |
jadmanski | 0afbb63 | 2008-06-06 21:10:57 +0000 | [diff] [blame] | 209 | return "%s.%s%s" % (version, sublevel, extraversion) |