blob: b2a51bdc5c12ba4647ffe4aa569012b35254eb83 [file] [log] [blame]
bjanakiraman6496e5f2013-02-15 04:50:58 +00001#!/usr/bin/python2.6
2#
3# Copyright 2010 Google Inc. All Rights Reserved.
4
5"""Script to build ChromeOS benchmarks
6
bjanakiraman229d6262013-02-15 04:56:46 +00007Inputs:
bjanakiraman6496e5f2013-02-15 04:50:58 +00008 chromeos_root
9 toolchain_root
10 board
11 [chromeos/cpu/<benchname>|chromeos/browser/[pagecycler|sunspider]|chromeos/startup]
bjanakiraman229d6262013-02-15 04:56:46 +000012
bjanakiraman6496e5f2013-02-15 04:50:58 +000013 This script assumes toolchain has already been built in toolchain_root.
14
15 chromeos/cpu/<benchname>
16 - Execute bench.py script within chroot to build benchmark
17 - Copy build results to perflab-bin
18
19 chromeos/startup
bjanakiraman229d6262013-02-15 04:56:46 +000020 - Call build_chromeos to build image.
bjanakiraman6496e5f2013-02-15 04:50:58 +000021 - Copy image to perflab-bin
bjanakiraman229d6262013-02-15 04:56:46 +000022
bjanakiraman6496e5f2013-02-15 04:50:58 +000023 chromeos/browser/*
24 - Call build_chromebrowser to build image with new browser
25 - Copy image to perflab-bin
26
27"""
28
29__author__ = "bjanakiraman@google.com (Bhaskar Janakiraman)"
30
31import optparse
32import os
33import sys
34import re
35import tc_enter_chroot
36import build_chromeos
37from utils import command_executer
38from utils import logger
39from utils import utils
40
41
42KNOWN_BENCHMARKS = [
43 'chromeos/startup',
44 'chromeos/browser/pagecycler',
45 'chromeos/browser/sunspider',
bjanakiramane7a379a2013-02-15 10:24:30 +000046 'chromeos/browser/v8bench',
bjanakiraman6496e5f2013-02-15 04:50:58 +000047 'chromeos/cpu/bikjmp' ]
48
bjanakiraman229d6262013-02-15 04:56:46 +000049# Commands to build CPU benchmarks.
bjanakiramanaabd2d12013-02-15 04:55:30 +000050
asharif8697d4e2013-02-15 09:18:09 +000051CPU_BUILDCMD_CLEAN = "cd /usr/local/toolchain_root/third_party/android_bench/v2_0/CLOSED_SOURCE/%s;\
bjanakiramanaabd2d12013-02-15 04:55:30 +000052python ../../scripts/bench.py --toolchain=/usr/bin --action=clean;"
53
asharif8697d4e2013-02-15 09:18:09 +000054CPU_BUILDCMD_BUILD = "cd /usr/local/toolchain_root/third_party/android_bench/v2_0/CLOSED_SOURCE/%s;\
bjanakiraman6496e5f2013-02-15 04:50:58 +000055python ../../scripts/bench.py --toolchain=/usr/bin --add_cflags=%s --add_ldflags=%s --makeopts=%s --action=build"
56
57
bjanakiramanaabd2d12013-02-15 04:55:30 +000058# Common initializations
59cmd_executer = command_executer.GetCommandExecuter()
60
bjanakiraman6496e5f2013-02-15 04:50:58 +000061
62def Usage(parser, message):
63 print "ERROR: " + message
64 parser.print_help()
65 sys.exit(0)
66
67
bjanakiraman229d6262013-02-15 04:56:46 +000068def CreateRunsh(destdir, benchmark):
69 """Create run.sh script to run benchmark. Perflab needs a run.sh that runs the benchmark."""
70 run_cmd = os.path.dirname(os.path.abspath(__file__)) + "/run_benchmarks.py"
71 contents = "#!/bin/sh\n%s $@ %s\n" % (run_cmd, benchmark)
72 runshfile = destdir + '/run.sh'
73 f = open(runshfile, 'w')
74 f.write(contents)
75 f.close()
asharifef75f392013-02-15 10:22:49 +000076 retval = cmd_executer.RunCommand('chmod +x %s' % runshfile)
77 return retval
bjanakiraman229d6262013-02-15 04:56:46 +000078
79
bjanakiramanaabd2d12013-02-15 04:55:30 +000080def CreateBinaryCopy(sourcedir, destdir):
bjanakiraman229d6262013-02-15 04:56:46 +000081 """Create links in perflab-bin/destdir/* to sourcedir/* for now, instead of copies"""
bjanakiramanaabd2d12013-02-15 04:55:30 +000082
bjanakiramane7a379a2013-02-15 10:24:30 +000083 retval = 0
bjanakiramanaabd2d12013-02-15 04:55:30 +000084 # check if sourcedir exists
85 if not os.path.exists(sourcedir):
kbaclawski6999ada2013-02-15 19:57:09 +000086 logger.GetLogger().LogError("benchmark results %s does not exist." %
87 sourcedir)
bjanakiraman229d6262013-02-15 04:56:46 +000088 return 1
bjanakiramanaabd2d12013-02-15 04:55:30 +000089
90 # Deal with old copies - save off old ones for now.
bjanakiraman229d6262013-02-15 04:56:46 +000091 # Note - if its a link, it doesn't save anything.
bjanakiramanaabd2d12013-02-15 04:55:30 +000092 if os.path.exists(destdir):
bjanakiraman229d6262013-02-15 04:56:46 +000093 command = 'rm -rf %s.old' % destdir
bjanakiramane7a379a2013-02-15 10:24:30 +000094 retval = cmd_executer.RunCommand(command)
95 if retval != 0:
96 return retval
bjanakiramanaabd2d12013-02-15 04:55:30 +000097 command = 'mv %s %s.old' % (destdir, destdir)
bjanakiramane7a379a2013-02-15 10:24:30 +000098 retval = cmd_executer.RunCommand(command)
99 if retval != 0:
100 return retval
bjanakiraman229d6262013-02-15 04:56:46 +0000101 os.makedirs(destdir)
bjanakiramanaabd2d12013-02-15 04:55:30 +0000102 sourcedir = os.path.abspath(sourcedir)
bjanakiraman229d6262013-02-15 04:56:46 +0000103 command = 'ln -s %s/* %s' % (sourcedir, destdir)
asharifef75f392013-02-15 10:22:49 +0000104 retval = cmd_executer.RunCommand(command)
105 return retval
bjanakiramanaabd2d12013-02-15 04:55:30 +0000106
107
bjanakiraman6496e5f2013-02-15 04:50:58 +0000108def Main(argv):
109 """Build ChromeOS."""
110 # Common initializations
111
112 parser = optparse.OptionParser()
113 parser.add_option("-c", "--chromeos_root", dest="chromeos_root",
114 help="Target directory for ChromeOS installation.")
115 parser.add_option("-t", "--toolchain_root", dest="toolchain_root",
asharif8697d4e2013-02-15 09:18:09 +0000116 help="This is obsolete. Do not use.")
117 parser.add_option("-r", "--third_party", dest="third_party",
118 help="The third_party dir containing android benchmarks.")
bjanakiramanaabd2d12013-02-15 04:55:30 +0000119 parser.add_option("-C", "--clean", dest="clean", action="store_true",
120 default=False, help="Clean up build."),
bjanakiraman229d6262013-02-15 04:56:46 +0000121 parser.add_option("-B", "--build", dest="build", action="store_true",
bjanakiramanaabd2d12013-02-15 04:55:30 +0000122 default=False, help="Build benchmark."),
bjanakiraman229d6262013-02-15 04:56:46 +0000123 parser.add_option("-O", "--only_copy", dest="only_copy", action="store_true",
bjanakiramanaabd2d12013-02-15 04:55:30 +0000124 default=False, help="Only copy to perflab-bin - no builds."),
bjanakiraman229d6262013-02-15 04:56:46 +0000125 parser.add_option("--workdir", dest="workdir", default=".",
126 help="Work directory for perflab outputs.")
bjanakiraman6496e5f2013-02-15 04:50:58 +0000127 parser.add_option("--clobber_chroot", dest="clobber_chroot",
128 action="store_true", help=
129 "Delete the chroot and start fresh", default=False)
130 parser.add_option("--clobber_board", dest="clobber_board",
131 action="store_true",
132 help="Delete the board and start fresh", default=False)
133 parser.add_option("--cflags", dest="cflags", default="",
134 help="CFLAGS for the ChromeOS packages")
135 parser.add_option("--cxxflags", dest="cxxflags",default="",
136 help="CXXFLAGS for the ChromeOS packages")
137 parser.add_option("--ldflags", dest="ldflags", default="",
138 help="LDFLAGS for the ChromeOS packages")
139 parser.add_option("--makeopts", dest="makeopts", default="",
140 help="Make options for the ChromeOS packages")
141 parser.add_option("--board", dest="board",
142 help="ChromeOS target board, e.g. x86-generic")
143
144 (options,args) = parser.parse_args(argv[1:])
145
146 # validate args
147 for arg in args:
148 if arg not in KNOWN_BENCHMARKS:
kbaclawski6999ada2013-02-15 19:57:09 +0000149 logger.GetLogger().LogFatal("Bad benchmark %s specified" % arg)
bjanakiraman6496e5f2013-02-15 04:50:58 +0000150
bjanakiraman229d6262013-02-15 04:56:46 +0000151
bjanakiraman6496e5f2013-02-15 04:50:58 +0000152 if options.chromeos_root is None:
153 Usage(parser, "--chromeos_root must be set")
154
bjanakiraman6496e5f2013-02-15 04:50:58 +0000155 if options.board is None:
156 Usage(parser, "--board must be set")
157
asharif8697d4e2013-02-15 09:18:09 +0000158 if options.toolchain_root:
159 logger.GetLogger().LogWarning("--toolchain_root should not be set")
160
161 options.chromeos_root = os.path.expanduser(options.chromeos_root)
162 options.workdir = os.path.expanduser(options.workdir)
163
bjanakiramanaabd2d12013-02-15 04:55:30 +0000164 retval = 0
asharif2198c512013-02-15 09:21:35 +0000165 if options.third_party:
166 third_party = options.third_party
167 else:
168 third_party = "%s/../../../third_party" % os.path.dirname(__file__)
169 third_party = os.path.realpath(third_party)
bjanakiraman6496e5f2013-02-15 04:50:58 +0000170 for arg in args:
171 # CPU benchmarks
172 if re.match('chromeos/cpu', arg):
173 comps = re.split('/', arg)
bjanakiramanaabd2d12013-02-15 04:55:30 +0000174 benchname = comps[2]
asharif8697d4e2013-02-15 09:18:09 +0000175
176 tec_options = []
asharif2198c512013-02-15 09:21:35 +0000177 if third_party:
178 tec_options.append("--third_party=%s" % third_party)
bjanakiramanaabd2d12013-02-15 04:55:30 +0000179 if options.clean:
asharif8697d4e2013-02-15 09:18:09 +0000180 retval = build_chromeos.ExecuteCommandInChroot(options.chromeos_root,
181 CPU_BUILDCMD_CLEAN % benchname,
182 tec_options=tec_options
183 )
kbaclawski6999ada2013-02-15 19:57:09 +0000184 logger.GetLogger().LogErrorIf(retval,
185 "clean of benchmark %s failed." % arg)
bjanakiramanaabd2d12013-02-15 04:55:30 +0000186 if options.build:
asharif8697d4e2013-02-15 09:18:09 +0000187 retval = build_chromeos.ExecuteCommandInChroot(options.chromeos_root,
bjanakiraman229d6262013-02-15 04:56:46 +0000188 CPU_BUILDCMD_BUILD % (benchname, options.cflags,
asharif8697d4e2013-02-15 09:18:09 +0000189 options.ldflags, options.makeopts),
190 tec_options=tec_options)
kbaclawski6999ada2013-02-15 19:57:09 +0000191 logger.GetLogger().LogErrorIf(retval,
192 "Build of benchmark %s failed." % arg)
bjanakiramanaabd2d12013-02-15 04:55:30 +0000193 if retval == 0 and (options.build or options.only_copy):
asharif2198c512013-02-15 09:21:35 +0000194 benchdir = ('%s/android_bench/v2_0/CLOSED_SOURCE/%s' %
195 (third_party, benchname))
bjanakiraman229d6262013-02-15 04:56:46 +0000196 linkdir = '%s/perflab-bin/%s' % (options.workdir, arg)
asharif2198c512013-02-15 09:21:35 +0000197
198 retval = CreateBinaryCopy(benchdir, linkdir)
199 if retval != 0: return retval
200 retval = CreateRunsh(linkdir, arg)
201 if retval != 0: return retval
bjanakiraman6496e5f2013-02-15 04:50:58 +0000202 elif re.match('chromeos/startup', arg):
bjanakiramanaabd2d12013-02-15 04:55:30 +0000203 if options.build:
204 # Clean for chromeos/browser and chromeos/startup is a Nop since builds are always from scratch.
205 build_args = [os.path.dirname(os.path.abspath(__file__)) + "/build_chromeos.py",
206 "--chromeos_root=" + options.chromeos_root,
bjanakiramanaabd2d12013-02-15 04:55:30 +0000207 "--board=" + options.board,
208 "--cflags=" + options.cflags,
209 "--cxxflags=" + options.cxxflags,
210 "--ldflags=" + options.ldflags,
211 "--clobber_board"
212 ]
213 retval = build_chromeos.Main(build_args)
kbaclawski6999ada2013-02-15 19:57:09 +0000214 logger.GetLogger().LogErrorIf(retval, "Build of ChromeOS failed.")
bjanakiramanaabd2d12013-02-15 04:55:30 +0000215 if retval == 0 and (options.build or options.only_copy):
216 benchdir = '%s/src/build/images/%s/latest' % (options.chromeos_root, options.board)
bjanakiraman4e8bdf22013-02-15 04:57:09 +0000217 linkdir = '%s/perflab-bin/%s' % (options.workdir, arg)
asharif2198c512013-02-15 09:21:35 +0000218 retval = CreateBinaryCopy(benchdir, linkdir)
219 if retval != 0: return retval
bjanakiraman229d6262013-02-15 04:56:46 +0000220 CreateRunsh(linkdir, arg)
asharif2198c512013-02-15 09:21:35 +0000221 if retval != 0: return retval
bjanakiraman6496e5f2013-02-15 04:50:58 +0000222 elif re.match('chromeos/browser', arg):
bjanakiramanaabd2d12013-02-15 04:55:30 +0000223 if options.build:
bjanakiraman229d6262013-02-15 04:56:46 +0000224 # For now, re-build os. TBD: Change to call build_browser
bjanakiramanaabd2d12013-02-15 04:55:30 +0000225 build_args = [os.path.dirname(os.path.abspath(__file__)) + "/build_chrome_browser.py",
226 "--chromeos_root=" + options.chromeos_root,
bjanakiramanaabd2d12013-02-15 04:55:30 +0000227 "--board=" + options.board,
228 "--cflags=" + options.cflags,
229 "--cxxflags=" + options.cxxflags,
230 "--ldflags=" + options.ldflags
231 ]
232 retval = build_chromeos.Main(build_args)
kbaclawski6999ada2013-02-15 19:57:09 +0000233 logger.GetLogger().LogErrorIf(retval, "Build of ChromeOS failed.")
bjanakiramanaabd2d12013-02-15 04:55:30 +0000234 if retval == 0 and (options.build or options.only_copy):
235 benchdir = '%s/src/build/images/%s/latest' % (options.chromeos_root, options.board)
bjanakiraman4e8bdf22013-02-15 04:57:09 +0000236 linkdir = '%s/perflab-bin/%s' % (options.workdir, arg)
asharif2198c512013-02-15 09:21:35 +0000237 retval = CreateBinaryCopy(benchdir,linkdir)
238 if retval != 0: return retval
239 retval = CreateRunsh(linkdir, arg)
240 if retval != 0: return retval
bjanakiraman6496e5f2013-02-15 04:50:58 +0000241
asharif2198c512013-02-15 09:21:35 +0000242 return 0
bjanakiraman6496e5f2013-02-15 04:50:58 +0000243
244if __name__ == "__main__":
kbaclawski5fec5502013-02-15 19:55:56 +0000245 sys.exit(Main(sys.argv))