summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/runqemu15
1 files changed, 14 insertions, 1 deletions
diff --git a/scripts/runqemu b/scripts/runqemu
index 7b0bcb24ee..5b719d5ac7 100755
--- a/scripts/runqemu
+++ b/scripts/runqemu
@@ -143,6 +143,7 @@ class BaseConfig(object):
143 self.nfs_server = '' 143 self.nfs_server = ''
144 self.rootfs = '' 144 self.rootfs = ''
145 self.qemuboot = '' 145 self.qemuboot = ''
146 self.qbconfload = False
146 self.kernel = '' 147 self.kernel = ''
147 self.kernel_cmdline = '' 148 self.kernel_cmdline = ''
148 self.kernel_cmdline_script = '' 149 self.kernel_cmdline_script = ''
@@ -239,6 +240,7 @@ class BaseConfig(object):
239 """ 240 """
240 if p.endswith('.qemuboot.conf'): 241 if p.endswith('.qemuboot.conf'):
241 self.qemuboot = p 242 self.qemuboot = p
243 self.qbconfload = True
242 elif re.search('\.bin$', p) or re.search('bzImage', p) or \ 244 elif re.search('\.bin$', p) or re.search('bzImage', p) or \
243 re.search('zImage', p) or re.search('vmlinux', p) or \ 245 re.search('zImage', p) or re.search('vmlinux', p) or \
244 re.search('fitImage', p) or re.search('uImage', p): 246 re.search('fitImage', p) or re.search('uImage', p):
@@ -250,7 +252,8 @@ class BaseConfig(object):
250 if m: 252 if m:
251 qb = '%s%s' % (re.sub('\.rootfs$', '', m.group(1)), '.qemuboot.conf') 253 qb = '%s%s' % (re.sub('\.rootfs$', '', m.group(1)), '.qemuboot.conf')
252 if os.path.exists(qb): 254 if os.path.exists(qb):
253 self.qemuboot = qb 255 self.qemuboot = qb
256 self.qbconfload = True
254 else: 257 else:
255 logger.warn("%s doesn't exist" % qb) 258 logger.warn("%s doesn't exist" % qb)
256 fst = m.group(2) 259 fst = m.group(2)
@@ -533,6 +536,7 @@ class BaseConfig(object):
533 qbs = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE).stdout.read().decode('utf-8') 536 qbs = subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE).stdout.read().decode('utf-8')
534 if qbs: 537 if qbs:
535 self.qemuboot = qbs.split()[0] 538 self.qemuboot = qbs.split()[0]
539 self.qbconfload = True
536 540
537 if not os.path.exists(self.qemuboot): 541 if not os.path.exists(self.qemuboot):
538 raise Exception("Failed to find <image>.qemuboot.conf!") 542 raise Exception("Failed to find <image>.qemuboot.conf!")
@@ -545,6 +549,15 @@ class BaseConfig(object):
545 k_upper = k.upper() 549 k_upper = k.upper()
546 self.set(k_upper, v) 550 self.set(k_upper, v)
547 551
552 # When we're started with a *.qemuboot.conf arg assume that image
553 # artefacts are relative to that file, rather than in whatever
554 # directory DEPLOY_DIR_IMAGE in the conf file points to.
555 if self.qbconfload:
556 imgdir = os.path.dirname(self.qemuboot)
557 if imgdir != self.get('DEPLOY_DIR_IMAGE'):
558 logger.info('Setting DEPLOY_DIR_IMAGE to folder containing %s (%s)' % (self.qemuboot, imgdir))
559 self.set('DEPLOY_DIR_IMAGE', imgdir)
560
548 def print_config(self): 561 def print_config(self):
549 logger.info('Continuing with the following parameters:\n') 562 logger.info('Continuing with the following parameters:\n')
550 if not self.fstype in self.vmtypes: 563 if not self.fstype in self.vmtypes: