aboutsummaryrefslogtreecommitdiff
path: root/gold/gold.cc
diff options
context:
space:
mode:
authorBenjamin Peterson <bp@benjamin.pe>2017-12-01 12:59:36 -0800
committerCary Coutant <ccoutant@gmail.com>2017-12-01 12:59:36 -0800
commitbd2e3511f74940beec6a39914480ed6ff88c0a71 (patch)
tree4fd2c80329f90e8957276529424e4cd5fe634981 /gold/gold.cc
parent71739b698d47945463f183619078ff680c277f0f (diff)
downloadgdb-bd2e3511f74940beec6a39914480ed6ff88c0a71.zip
gdb-bd2e3511f74940beec6a39914480ed6ff88c0a71.tar.gz
gdb-bd2e3511f74940beec6a39914480ed6ff88c0a71.tar.bz2
Fix internal error from command line with unbalanced --start-lib/--end-lib.
The problem is that while the command line isn't trivially empty, it contains no input files. As gold tries to configure the number of threads to use based on the number of input files, this causes the assertion failure above. Fix this problem by making the logic in gold.cc more robust and also adding a better error message about --start-lib to options.cc. gold/ PR gold/22406 * gold.cc (queue_initial_tasks) Check for number of real input files. * options.cc (Command_line::process) Check for unterminated --start-lib options. * testsuite/Makefile.am: Add new test script. * testsuite/Makefile.in: Regenerate. * testsuite/check_empty_command_lines.sh: New test script.
Diffstat (limited to 'gold/gold.cc')
-rw-r--r--gold/gold.cc2
1 files changed, 1 insertions, 1 deletions
diff --git a/gold/gold.cc b/gold/gold.cc
index a76d155..3916f89 100644
--- a/gold/gold.cc
+++ b/gold/gold.cc
@@ -175,7 +175,7 @@ queue_initial_tasks(const General_options& options,
Workqueue* workqueue, Input_objects* input_objects,
Symbol_table* symtab, Layout* layout, Mapfile* mapfile)
{
- if (cmdline.begin() == cmdline.end())
+ if (cmdline.number_of_input_files() == 0)
{
bool is_ok = false;
if (options.printed_version())