blob: d32c49ac03ff5dad8183ba68eb3db428a2a02848 [file] [log] [blame]
raymes5154d7f2013-02-15 04:35:37 +00001#!/usr/bin/python2.6
2#
3# Copyright 2010 Google Inc. All Rights Reserved.
4
5"""Script to checkout the ChromeOS source.
6
7This script sets up the ChromeOS source in the given directory, matching a
8particular release of ChromeOS.
9"""
10
11__author__ = "raymes@google.com (Raymes Khoury)"
12
13import optparse
14import os
15import sys
asharife3668f12013-02-15 04:46:29 +000016import tc_enter_chroot
raymes01959ae2013-02-15 04:50:07 +000017from utils import command_executer
18from utils import logger
raymes5154d7f2013-02-15 04:35:37 +000019from utils import utils
20
asharife3668f12013-02-15 04:46:29 +000021
raymes5154d7f2013-02-15 04:35:37 +000022def Usage(parser, message):
23 print "ERROR: " + message
24 parser.print_help()
25 sys.exit(0)
26
raymes49fd5a32013-02-15 04:55:27 +000027#TODO(raymes): move this to a common utils file.
raymes5154d7f2013-02-15 04:35:37 +000028def ExecuteCommandInChroot(chromeos_root, toolchain_root, command,
raymesbfb57992013-02-15 04:35:45 +000029 return_output=False, chrome_root=""):
asharife3668f12013-02-15 04:46:29 +000030 """Executes a command in the chroot."""
raymes49fd5a32013-02-15 04:55:27 +000031 global cmd_executer
32 cmd_executer = command_executer.GetCommandExecuter()
33
raymesbfb57992013-02-15 04:35:45 +000034 chrome_mount = ""
35 if chrome_root:
36 chrome_mount = "--chrome_root=" + chromeos_root + "/" + chrome_root
raymes49fd5a32013-02-15 04:55:27 +000037 if toolchain_root is None:
38 return cmd_executer.RunCommand(chromeos_root +
39 "/src/scripts/enter_chroot.sh %s -- %s"
40 % ("chrome_root=" + chrome_root,
41 command))
42 else:
43 argv = [os.path.dirname(os.path.abspath(__file__)) + "/tc_enter_chroot.py",
44 "--chromeos_root=" + chromeos_root,
45 "--toolchain_root=" + toolchain_root,
46 chrome_mount,
47 "\n" + command]
48 return tc_enter_chroot.Main(argv)
asharife3668f12013-02-15 04:46:29 +000049
50
51def MakeChroot(chromeos_root, clobber_chroot=False):
52 """Make a chroot given a chromeos checkout."""
53 if (not os.path.isdir(chromeos_root + "/chroot")
54 or clobber_chroot):
55 commands = []
56 commands.append("cd " + chromeos_root + "/src/scripts")
57 clobber_chroot = ""
58 if clobber_chroot:
59 clobber_chroot = "--replace"
60 commands.append("./make_chroot --fast " + clobber_chroot)
asharif967d7002013-02-15 04:51:00 +000061 ret = command_executer.GetCommandExecuter().RunCommands(commands)
asharife3668f12013-02-15 04:46:29 +000062 utils.AssertTrue(ret == 0, "make_chroot failed")
63 else:
raymes01959ae2013-02-15 04:50:07 +000064 logger.GetLogger().LogOutput("Did not make_chroot because it already exists")
raymes5154d7f2013-02-15 04:35:37 +000065
66
bjanakiraman6496e5f2013-02-15 04:50:58 +000067def Main(argv):
raymes5154d7f2013-02-15 04:35:37 +000068 """Build ChromeOS."""
69 # Common initializations
asharif5a9bb462013-02-15 04:50:57 +000070 cmd_executer = command_executer.GetCommandExecuter()
raymes5154d7f2013-02-15 04:35:37 +000071
72 parser = optparse.OptionParser()
73 parser.add_option("--chromeos_root", dest="chromeos_root",
74 help="Target directory for ChromeOS installation.")
75 parser.add_option("--toolchain_root", dest="toolchain_root",
76 help="The gcctools directory of your P4 checkout.")
77 parser.add_option("--clobber_chroot", dest="clobber_chroot",
78 action="store_true", help=
79 "Delete the chroot and start fresh", default=False)
80 parser.add_option("--clobber_board", dest="clobber_board",
81 action="store_true",
82 help="Delete the board and start fresh", default=False)
83 parser.add_option("--cflags", dest="cflags",
84 help="CFLAGS for the ChromeOS packages")
85 parser.add_option("--cxxflags", dest="cxxflags",
86 help="CXXFLAGS for the ChromeOS packages")
87 parser.add_option("--ldflags", dest="ldflags",
88 help="LDFLAGS for the ChromeOS packages")
89 parser.add_option("--board", dest="board",
90 help="ChromeOS target board, e.g. x86-generic")
91
bjanakiraman6496e5f2013-02-15 04:50:58 +000092 options = parser.parse_args(argv[1:])[0]
raymes5154d7f2013-02-15 04:35:37 +000093
94 if options.chromeos_root is None:
95 Usage(parser, "--chromeos_root must be set")
96
97 if options.toolchain_root is None:
98 Usage(parser, "--toolchain_root must be set")
99
100 if options.board is None:
101 Usage(parser, "--board must be set")
102
asharife3668f12013-02-15 04:46:29 +0000103 MakeChroot(options.chromeos_root, options.clobber_chroot)
raymes5154d7f2013-02-15 04:35:37 +0000104
105 # Setup board
raymes04164a12013-02-15 04:36:03 +0000106 if not os.path.isdir(options.chromeos_root + "/chroot/build/"
107 + options.board) or options.clobber_board:
raymes5f35b922013-02-15 04:35:57 +0000108 force = ""
109 if options.clobber_board:
110 force = "--force"
raymes04164a12013-02-15 04:36:03 +0000111 # Run build_tc.py from binary package
bjanakiraman6496e5f2013-02-15 04:50:58 +0000112 rootdir = utils.GetRoot(argv[0])[0]
raymes01959ae2013-02-15 04:50:07 +0000113 ret = cmd_executer.RunCommand(rootdir + "/build_tc.py --chromeos_root=%s "
114 "--toolchain_root=%s --board=%s -B"
115 % (options.chromeos_root,
116 options.toolchain_root, options.board))
raymes04164a12013-02-15 04:36:03 +0000117 utils.AssertTrue(ret == 0, "build_tc.py failed")
raymes5f6be5f2013-02-15 04:36:13 +0000118 version_number = utils.GetRoot(rootdir)[1]
asharif541b6392013-02-15 04:50:38 +0000119 pkgdir = "/usr/local/toolchain_root/" + version_number + "/output/pkgs"
raymes5f35b922013-02-15 04:35:57 +0000120 ret = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
raymes5f6be5f2013-02-15 04:36:13 +0000121 "PKGDIR=%s ./setup_board --board=%s "
122 " --gcc_version=9999 "
123 "%s" % (pkgdir, options.board, force))
raymes5f35b922013-02-15 04:35:57 +0000124 utils.AssertTrue(ret == 0, "setup_board failed")
125 else:
raymes01959ae2013-02-15 04:50:07 +0000126 logger.GetLogger().LogOutput("Did not setup_board "
127 "because it already exists")
raymesbfb57992013-02-15 04:35:45 +0000128
129 # Modify make.conf to add CFLAGS/CXXFLAGS/LDFLAGS
raymesbfb57992013-02-15 04:35:45 +0000130 ret1 = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
131 "[ -e /build/%s/etc/make.conf.orig ] || "
132 "sudo mv /build/%s/etc/make.conf "
133 "/build/%s/etc/make.conf.orig"
134 % (options.board, options.board, options.board))
asharif541b6392013-02-15 04:50:38 +0000135 makeconf = ("source make.conf.orig\n")
raymesbfb57992013-02-15 04:35:45 +0000136 #"CFLAGS='%s'\\\nCXXFLAGS='%s'\\\nLDFLAGS='%s'\\\n" %
137 #(options.cflags, options.cxxflags, options.ldflags))
raymese91a6e62013-02-15 04:35:51 +0000138 ret2 = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
asharif541b6392013-02-15 04:50:38 +0000139 "if [ -e /build/%s/etc/make.conf.orig ] ; "
140 "then sudo echo -e \"%s\" | sudo tee "
raymese91a6e62013-02-15 04:35:51 +0000141 "/build/%s/etc/make.conf > /dev/null ;"
asharif541b6392013-02-15 04:50:38 +0000142 "else exit 1 ; fi"
raymes5f6be5f2013-02-15 04:36:13 +0000143 % (options.board, makeconf, options.board))
raymes5f35b922013-02-15 04:35:57 +0000144
raymesbfb57992013-02-15 04:35:45 +0000145 utils.AssertTrue(ret1 == 0 and ret2 == 0, "Could not modify make.conf")
raymes5154d7f2013-02-15 04:35:37 +0000146
147 # Find Chrome browser version
raymes01959ae2013-02-15 04:50:07 +0000148 chrome_version = cmd_executer.RunCommand("%s/src/scripts/chromeos_version.sh "
asharif541b6392013-02-15 04:50:38 +0000149 "| grep CHROME_VERSION"
raymes01959ae2013-02-15 04:50:07 +0000150 % options.chromeos_root, True)
raymesbfb57992013-02-15 04:35:45 +0000151
152 ret = chrome_version[0]
153 utils.AssertTrue(ret == 0, "Could not determine Chrome browser version")
raymes5154d7f2013-02-15 04:35:37 +0000154
155 chrome_version = chrome_version[1].strip().split("=")
156 if len(chrome_version) == 2:
157 chrome_version = chrome_version[1]
158 else:
159 chrome_version = ""
160
raymes5154d7f2013-02-15 04:35:37 +0000161 # Build packages
raymesbfb57992013-02-15 04:35:45 +0000162 ret = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
raymese91a6e62013-02-15 04:35:51 +0000163 "CHROME_ORIGIN=SERVER_SOURCE CHROME_VERSION=%s "
raymesbfb57992013-02-15 04:35:45 +0000164 "./build_packages --withdev "
165 "--board=%s --withtest --withautotest"
166 % (chrome_version, options.board),
167 chrome_root="chrome_browser")
168
169 utils.AssertTrue(ret == 0, "build_packages failed")
raymes5154d7f2013-02-15 04:35:37 +0000170
171 # Build image
raymesbfb57992013-02-15 04:35:45 +0000172 ret = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
173 "./build_image --board=%s" % options.board)
174
175 utils.AssertTrue(ret == 0, "build_image failed")
raymes5154d7f2013-02-15 04:35:37 +0000176
177 # Mod image for test
raymesbfb57992013-02-15 04:35:45 +0000178 ret = ExecuteCommandInChroot(options.chromeos_root, options.toolchain_root,
179 "./mod_image_for_test.sh --board=%s"
180 % options.board)
raymes5154d7f2013-02-15 04:35:37 +0000181
raymesbfb57992013-02-15 04:35:45 +0000182 utils.AssertTrue(ret == 0, "mod_image_for_test failed")
raymes5154d7f2013-02-15 04:35:37 +0000183
184if __name__ == "__main__":
bjanakiraman6496e5f2013-02-15 04:50:58 +0000185 Main(sys.argv)