raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 1 | #!/usr/bin/python2.6 |
| 2 | # |
| 3 | # Copyright 2010 Google Inc. All Rights Reserved. |
| 4 | |
| 5 | """Script to checkout the ChromeOS source. |
| 6 | |
| 7 | This script sets up the ChromeOS source in the given directory, matching a |
| 8 | particular release of ChromeOS. |
| 9 | """ |
| 10 | |
| 11 | __author__ = "raymes@google.com (Raymes Khoury)" |
| 12 | |
| 13 | import optparse |
| 14 | import os |
| 15 | import sys |
asharif | e3668f1 | 2013-02-15 04:46:29 +0000 | [diff] [blame] | 16 | import tc_enter_chroot |
raymes | 01959ae | 2013-02-15 04:50:07 +0000 | [diff] [blame] | 17 | from utils import command_executer |
| 18 | from utils import logger |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 19 | from utils import utils |
| 20 | |
asharif | e3668f1 | 2013-02-15 04:46:29 +0000 | [diff] [blame] | 21 | |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 22 | def Usage(parser, message): |
| 23 | print "ERROR: " + message |
| 24 | parser.print_help() |
| 25 | sys.exit(0) |
| 26 | |
asharif | e3668f1 | 2013-02-15 04:46:29 +0000 | [diff] [blame] | 27 | |
| 28 | def MakeChroot(chromeos_root, clobber_chroot=False): |
| 29 | """Make a chroot given a chromeos checkout.""" |
| 30 | if (not os.path.isdir(chromeos_root + "/chroot") |
| 31 | or clobber_chroot): |
| 32 | commands = [] |
| 33 | commands.append("cd " + chromeos_root + "/src/scripts") |
| 34 | clobber_chroot = "" |
| 35 | if clobber_chroot: |
| 36 | clobber_chroot = "--replace" |
| 37 | commands.append("./make_chroot --fast " + clobber_chroot) |
asharif | 967d700 | 2013-02-15 04:51:00 +0000 | [diff] [blame] | 38 | ret = command_executer.GetCommandExecuter().RunCommands(commands) |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 39 | logger.GetLogger().LogFatalIf(ret, "make_chroot failed") |
asharif | e3668f1 | 2013-02-15 04:46:29 +0000 | [diff] [blame] | 40 | else: |
raymes | 01959ae | 2013-02-15 04:50:07 +0000 | [diff] [blame] | 41 | logger.GetLogger().LogOutput("Did not make_chroot because it already exists") |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 42 | |
| 43 | |
bjanakiraman | 6496e5f | 2013-02-15 04:50:58 +0000 | [diff] [blame] | 44 | def Main(argv): |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 45 | """Build ChromeOS.""" |
| 46 | # Common initializations |
asharif | 5a9bb46 | 2013-02-15 04:50:57 +0000 | [diff] [blame] | 47 | cmd_executer = command_executer.GetCommandExecuter() |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 48 | |
| 49 | parser = optparse.OptionParser() |
| 50 | parser.add_option("--chromeos_root", dest="chromeos_root", |
| 51 | help="Target directory for ChromeOS installation.") |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 52 | parser.add_option("--clobber_chroot", dest="clobber_chroot", |
| 53 | action="store_true", help= |
| 54 | "Delete the chroot and start fresh", default=False) |
| 55 | parser.add_option("--clobber_board", dest="clobber_board", |
| 56 | action="store_true", |
| 57 | help="Delete the board and start fresh", default=False) |
asharif | 80b47dc | 2013-02-15 06:31:19 +0000 | [diff] [blame] | 58 | parser.add_option("--rebuild", dest="rebuild", |
| 59 | action="store_true", |
| 60 | help="Rebuild all board packages except the toolchain.", |
| 61 | default=False) |
raymes | 9b8305c | 2013-02-15 04:56:27 +0000 | [diff] [blame] | 62 | parser.add_option("--cflags", dest="cflags", default="", |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 63 | help="CFLAGS for the ChromeOS packages") |
raymes | 9b8305c | 2013-02-15 04:56:27 +0000 | [diff] [blame] | 64 | parser.add_option("--cxxflags", dest="cxxflags", default="", |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 65 | help="CXXFLAGS for the ChromeOS packages") |
raymes | 9b8305c | 2013-02-15 04:56:27 +0000 | [diff] [blame] | 66 | parser.add_option("--ldflags", dest="ldflags", default="", |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 67 | help="LDFLAGS for the ChromeOS packages") |
| 68 | parser.add_option("--board", dest="board", |
| 69 | help="ChromeOS target board, e.g. x86-generic") |
asharif | 8697d4e | 2013-02-15 09:18:09 +0000 | [diff] [blame] | 70 | parser.add_option("--label", dest="label", |
| 71 | help="Optional label symlink to point to build dir.") |
asharif | 0341d30 | 2013-02-15 04:56:38 +0000 | [diff] [blame] | 72 | parser.add_option("--vanilla", dest="vanilla", |
asharif | b1752c8 | 2013-02-15 04:56:37 +0000 | [diff] [blame] | 73 | default=False, |
| 74 | action="store_true", |
asharif | 0341d30 | 2013-02-15 04:56:38 +0000 | [diff] [blame] | 75 | help="Use default ChromeOS toolchain.") |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 76 | |
bjanakiraman | 6496e5f | 2013-02-15 04:50:58 +0000 | [diff] [blame] | 77 | options = parser.parse_args(argv[1:])[0] |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 78 | |
| 79 | if options.chromeos_root is None: |
| 80 | Usage(parser, "--chromeos_root must be set") |
| 81 | |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 82 | if options.board is None: |
| 83 | Usage(parser, "--board must be set") |
| 84 | |
asharif | 80b47dc | 2013-02-15 06:31:19 +0000 | [diff] [blame] | 85 | build_packages_env = "" |
| 86 | if options.rebuild == True: |
| 87 | build_packages_env = "EXTRA_BOARD_FLAGS=-e" |
| 88 | |
asharif | 01e29a5 | 2013-02-15 04:56:41 +0000 | [diff] [blame] | 89 | options.chromeos_root = os.path.expanduser(options.chromeos_root) |
asharif | 01e29a5 | 2013-02-15 04:56:41 +0000 | [diff] [blame] | 90 | |
asharif | e3668f1 | 2013-02-15 04:46:29 +0000 | [diff] [blame] | 91 | MakeChroot(options.chromeos_root, options.clobber_chroot) |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 92 | |
asharif | e0cc305 | 2013-02-15 05:20:48 +0000 | [diff] [blame] | 93 | build_packages_command = utils.GetBuildPackagesCommand(options.board) |
| 94 | build_image_command = utils.GetBuildImageCommand(options.board) |
| 95 | mod_image_command = utils.GetModImageForTestCommand(options.board) |
asharif | ca8c5ef | 2013-02-15 04:57:02 +0000 | [diff] [blame] | 96 | |
asharif | 0341d30 | 2013-02-15 04:56:38 +0000 | [diff] [blame] | 97 | if options.vanilla == True: |
asharif | e0cc305 | 2013-02-15 05:20:48 +0000 | [diff] [blame] | 98 | command = utils.GetSetupBoardCommand(options.board, |
| 99 | usepkg=False, |
| 100 | force=options.clobber_board) |
asharif | c380f61 | 2013-02-15 09:13:07 +0000 | [diff] [blame] | 101 | command += "; " + build_packages_env + " " + build_packages_command |
asharif | ca8c5ef | 2013-02-15 04:57:02 +0000 | [diff] [blame] | 102 | command += "&& " + build_image_command |
| 103 | command += "&& " + mod_image_command |
asharif | ca3c6c1 | 2013-02-15 23:17:54 +0000 | [diff] [blame^] | 104 | ret = cmd_executer.ChrootRunCommand(options.chromeos_root, command) |
asharif | b1752c8 | 2013-02-15 04:56:37 +0000 | [diff] [blame] | 105 | return ret |
| 106 | |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 107 | # Setup board |
raymes | 04164a1 | 2013-02-15 04:36:03 +0000 | [diff] [blame] | 108 | if not os.path.isdir(options.chromeos_root + "/chroot/build/" |
| 109 | + options.board) or options.clobber_board: |
raymes | 04164a1 | 2013-02-15 04:36:03 +0000 | [diff] [blame] | 110 | # Run build_tc.py from binary package |
bjanakiraman | 6496e5f | 2013-02-15 04:50:58 +0000 | [diff] [blame] | 111 | rootdir = utils.GetRoot(argv[0])[0] |
raymes | 5f6be5f | 2013-02-15 04:36:13 +0000 | [diff] [blame] | 112 | version_number = utils.GetRoot(rootdir)[1] |
asharif | ca3c6c1 | 2013-02-15 23:17:54 +0000 | [diff] [blame^] | 113 | ret = cmd_executer.ChrootRunCommand( |
| 114 | options.chromeos_root, |
| 115 | utils.GetSetupBoardCommand(options.board, |
asharif | e0cc305 | 2013-02-15 05:20:48 +0000 | [diff] [blame] | 116 | gcc_version="9999", |
| 117 | binutils_version="9999", |
| 118 | force=options.clobber_board)) |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 119 | logger.GetLogger().LogFatalIf(ret, "setup_board failed") |
raymes | 5f35b92 | 2013-02-15 04:35:57 +0000 | [diff] [blame] | 120 | else: |
raymes | 01959ae | 2013-02-15 04:50:07 +0000 | [diff] [blame] | 121 | logger.GetLogger().LogOutput("Did not setup_board " |
| 122 | "because it already exists") |
raymes | bfb5799 | 2013-02-15 04:35:45 +0000 | [diff] [blame] | 123 | |
raymes | 9b8305c | 2013-02-15 04:56:27 +0000 | [diff] [blame] | 124 | # Build packages |
asharif | ca3c6c1 | 2013-02-15 23:17:54 +0000 | [diff] [blame^] | 125 | ret = cmd_executer.ChrootRunCommand( |
| 126 | options.chromeos_root, |
| 127 | "CFLAGS=\"$(portageq-%s envvar CFLAGS) %s\" " |
| 128 | "LDFLAGS=\"$(portageq-%s envvar LDFLAGS) %s\" " |
| 129 | "CXXFLAGS=\"$(portageq-%s envvar CXXFLAGS) %s\" " |
| 130 | "CHROME_ORIGIN=SERVER_SOURCE " |
| 131 | "%s " |
| 132 | "%s" |
| 133 | % (options.board, options.cflags, |
| 134 | options.board, options.cxxflags, |
| 135 | options.board, options.ldflags, |
| 136 | build_packages_env, |
| 137 | build_packages_command)) |
raymes | bfb5799 | 2013-02-15 04:35:45 +0000 | [diff] [blame] | 138 | |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 139 | logger.GetLogger().LogFatalIf(ret, "build_packages failed") |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 140 | |
| 141 | # Build image |
asharif | ca3c6c1 | 2013-02-15 23:17:54 +0000 | [diff] [blame^] | 142 | ret = cmd_executer.ChrootRunCommand(options.chromeos_root, |
| 143 | build_image_command) |
raymes | bfb5799 | 2013-02-15 04:35:45 +0000 | [diff] [blame] | 144 | |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 145 | logger.GetLogger().LogFatalIf(ret, "build_image failed") |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 146 | |
| 147 | # Mod image for test |
asharif | ca3c6c1 | 2013-02-15 23:17:54 +0000 | [diff] [blame^] | 148 | ret = cmd_executer.ChrootRunCommand(options.chromeos_root, mod_image_command) |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 149 | |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 150 | logger.GetLogger().LogFatalIf(ret, "mod_image_for_test failed") |
asharif | 8697d4e | 2013-02-15 09:18:09 +0000 | [diff] [blame] | 151 | |
| 152 | flags_file_name = "flags.txt" |
| 153 | flags_file_path = ("%s/src/build/images/%s/latest/%s" % |
| 154 | (options.chromeos_root, |
| 155 | options.board, |
| 156 | flags_file_name)) |
| 157 | flags_file = open(flags_file_path, "wb") |
| 158 | flags_file.write("CFLAGS=%s\n" % options.cflags) |
| 159 | flags_file.write("CXXFLAGS=%s\n" % options.cxxflags) |
| 160 | flags_file.write("LDFLAGS=%s\n" % options.ldflags) |
| 161 | flags_file.close() |
| 162 | |
| 163 | if options.label: |
| 164 | image_dir_path = ("%s/src/build/images/%s/latest" % |
| 165 | (options.chromeos_root, |
| 166 | options.board)) |
| 167 | real_image_dir_path = os.path.realpath(image_dir_path) |
| 168 | command = ("ln -sf -T %s %s/%s" % |
| 169 | (os.path.basename(real_image_dir_path), |
| 170 | os.path.dirname(real_image_dir_path), |
| 171 | options.label)) |
| 172 | |
| 173 | ret = cmd_executer.RunCommand(command) |
kbaclawski | 6999ada | 2013-02-15 19:57:09 +0000 | [diff] [blame] | 174 | logger.GetLogger().LogFatalIf(ret, "Failed to apply symlink label %s" % |
| 175 | options.label) |
asharif | 8697d4e | 2013-02-15 09:18:09 +0000 | [diff] [blame] | 176 | |
| 177 | return ret |
raymes | 5154d7f | 2013-02-15 04:35:37 +0000 | [diff] [blame] | 178 | |
| 179 | if __name__ == "__main__": |
asharif | 2198c51 | 2013-02-15 09:21:35 +0000 | [diff] [blame] | 180 | retval = Main(sys.argv) |
| 181 | sys.exit(retval) |