LLVM Bugzilla is read-only and represents the historical archive of all LLVM issues filled before November 26, 2021. Use github to submit LLVM bugs

Bug 1207 - LiveVariables assertion prevents llvm-gcc build
Summary: LiveVariables assertion prevents llvm-gcc build
Status: RESOLVED FIXED
Alias: None
Product: libraries
Classification: Unclassified
Component: Common Code Generator Code (show other bugs)
Version: trunk
Hardware: PC Linux
: P release blocker
Assignee: Evan Cheng
URL:
Keywords: compile-fail
Depends on:
Blocks:
 
Reported: 2007-02-17 17:01 PST by Reid Spencer
Modified: 2010-02-22 12:48 PST (History)
4 users (show)

See Also:
Fixed By Commit(s):


Attachments
Bytecode generated by -emit-llvm switch to llc (382 bytes, application/octet-stream)
2007-02-17 17:08 PST, Reid Spencer
Details
Script to revert Evant's changes. (1.38 KB, text/plain)
2007-02-18 01:10 PST, Reid Spencer
Details
Bytecode (84.83 KB, application/octet-stream)
2007-02-19 18:25 PST, Anton Korobeynikov
Details
LLVM source code (89.53 KB, application/octet-stream)
2007-02-19 18:25 PST, Anton Korobeynikov
Details
LiveVars patch. (37.91 KB, patch)
2007-02-20 03:19 PST, Anton Korobeynikov
Details
LLVM source (267.75 KB, text/plain)
2007-02-20 18:28 PST, Anton Korobeynikov
Details
"Bad" output (148.04 KB, text/plain)
2007-02-20 18:28 PST, Anton Korobeynikov
Details
"Good" output (148.30 KB, text/plain)
2007-02-20 18:29 PST, Anton Korobeynikov
Details

Note You need to log in before you can comment on or make changes to this bug.
Description Reid Spencer 2007-02-17 17:01:56 PST
After updating LLVM and applying recent patches to llvm-gcc
(CUMMULATIVE-276.patch sent to llvm-commits today), the llvm-gcc build now fails
while compiling libgcc, with:

cc1: LiveInterval.cpp:227: void llvm::LiveInterval::removeRange(unsigned int,
unsigned int): Assertion `I->contains(Start) && I->contains(End-1) && "Range is 
not entirely in interval!"' failed.

Stack trace:
#0  0x00826402 in __kernel_vsyscall ()
#1  0x00321ee9 in raise () from /lib/libc.so.6
#2  0x003234f1 in abort () from /lib/libc.so.6
#3  0x0031b859 in __assert_fail () from /lib/libc.so.6
#4  0x08735631 in llvm::LiveInterval::removeRange (this=0xaa2f1f0, Start=14,
End=115) at LiveInterval.cpp:226
#5  0x0873cd73 in llvm::LiveInterval::removeRange (this=0xaa2f1f0, LR={start =
14, end = 115, ValId = 0})
    at /proj/llvm/llvm-1/include/llvm/CodeGen/LiveInterval.h:253
#6  0x0873bbce in llvm::LiveIntervals::runOnMachineFunction (this=0xaa410e0, fn=
#7  0x0856a4aa in llvm::MachineFunctionPass::runOnFunction (this=0xaa410e0, F=
#8  0x088c13c8 in llvm::FPPassManager::runOnFunction (this=0xaa3fda8,
F=@0xaa55978) at PassManager.cpp:998
#9  0x088c162a in llvm::FunctionPassManagerImpl::run (this=0xaa3fac8,
F=@0xaa55978) at PassManager.cpp:953
#10 0x088c16ec in llvm::FunctionPassManager::run (this=0xaa3e0f8, F=@0xaa55978)
at PassManager.cpp:895
#11 0x0833b8d8 in llvm_asm_file_end () at ../../src-1/gcc/llvm-backend.cpp:473
#12 0x0830bdc9 in toplev_main (argc=0, argv=0xbfed1fc4) at
../../src-1/gcc/toplev.c:1167
#13 0x0030f4e4 in __libc_start_main () from /lib/libc.so.6
#14 0x0804e171 in _start ()
Comment 1 Reid Spencer 2007-02-17 17:03:00 PST
Command line options (to cc1) used to generate this:

-quiet -v -I. -I. -I../../src-1/gcc -I../../src-1/gcc/.
-I../../src-1/gcc/../include -I../../src-1/gcc/../libcpp/include
-I/proj/llvm/llvm-1/include -I/proj/llvm/llvm-1/include -iprefix
/proj/llvm/cfe/build-1/gcc/../lib/gcc/i686-pc-linux-gnu/4.0.1/ -isystem
/proj/llvm/cfe/build-1/gcc/include -DIN_GCC -DHAVE_GTHR_DEFAULT -DIN_LIBGCC2
-D__GCC_FLOAT_NOT_NEEDED -DL_eprintf -isystem
/proj/llvm/cfe/install-1/i686-pc-linux-gnu/include -isystem
/proj/llvm/cfe/install-1/i686-pc-linux-gnu/sys-include -isystem ./include
../../src-1/gcc/libgcc2.c -quiet -dumpbase libgcc2.c -mtune=generic
-auxbase-strip libgcc/./_eprintf.o -g -O2 -W -Wall -Wwrite-strings
-Wstrict-prototypes -Wmissing-prototypes -Wold-style-definition -version -fPIC
-o /tmp/ccQbquX1.s

Comment 2 Reid Spencer 2007-02-17 17:08:50 PST
Created attachment 670 [details]
Bytecode generated by -emit-llvm switch to llc

This attachment was generated with these commands:

cc1 -quiet -v -I. -I. -I../../src-1/gcc -I../../src-1/gcc/.
-I../../src-1/gcc/../include -I../../src-1/gcc/../libcpp/include
-I/proj/llvm/llvm-1/include -I/proj/llvm/llvm-1/include -iprefix
/proj/llvm/cfe/build-1/gcc/../lib/gcc/i686-pc-linux-gnu/4.0.1/ -isystem
/proj/llvm/cfe/build-1/gcc/include -DIN_GCC -DHAVE_GTHR_DEFAULT -DIN_LIBGCC2
-D__GCC_FLOAT_NOT_NEEDED -DL_eprintf -isystem
/proj/llvm/cfe/install-1/i686-pc-linux-gnu/include -isystem
/proj/llvm/cfe/install-1/i686-pc-linux-gnu/sys-include -isystem ./include
../../src-1/gcc/libgcc2.c -quiet -dumpbase libgcc2.c -mtune=generic
-auxbase-strip libgcc/./_eprintf.o -g -O2 -W -Wall -Wwrite-strings
-Wstrict-prototypes -Wmissing-prototypes -Wold-style-definition -version -fPIC
-o /tmp/pr1207.ll -emit-llvm 

llvm-as /tmp/pr1207.bc

Unfortunately, running llc on this doesn't replicate the problem.
Comment 3 Anton Korobeynikov 2007-02-17 17:14:24 PST
Confirmed here.
Reproducible via "llc -relocation-model=pic"
Comment 4 Reid Spencer 2007-02-17 17:17:04 PST
Yup, stack trace for 'llc -relocation-model=pic pr1207.bc' is:

#0  0x00b25402 in __kernel_vsyscall ()
#1  0x00137ee9 in raise () from /lib/libc.so.6
#2  0x001394f1 in abort () from /lib/libc.so.6
#3  0x00131859 in __assert_fail () from /lib/libc.so.6
#4  0x08720431 in llvm::LiveInterval::removeRange (this=0xa0b0a60, Start=14,
    End=115) at LiveInterval.cpp:226
#5  0x08727b73 in llvm::LiveInterval::removeRange (this=0xa0b0a60, LR=
      {start = 14, end = 115, ValId = 0})
    at /proj/llvm/llvm-1/include/llvm/CodeGen/LiveInterval.h:253
#6  0x087269ce in llvm::LiveIntervals::runOnMachineFunction (this=0xa0a64a8,
    fn=@0xa0ad958) at LiveIntervalAnalysis.cpp:148
#7  0x083dff42 in llvm::MachineFunctionPass::runOnFunction (this=0xa0a64a8,
    F=@0xa09d810)
    at /proj/llvm/llvm-1/include/llvm/CodeGen/MachineFunctionPass.h:37
#8  0x0882adb0 in llvm::FPPassManager::runOnFunction (this=0xa09e9b0,
    F=@0xa09d810) at PassManager.cpp:998
#9  0x0882b012 in llvm::FunctionPassManagerImpl::run (this=0xa0a24d0,
    F=@0xa09d810) at PassManager.cpp:953
#10 0x0882b0d4 in llvm::FunctionPassManager::run (this=0xbfa77df4,
    F=@0xa09d810) at PassManager.cpp:895
#11 0x083b593f in main (argc=4, argv=0xbfa77ee4) at llc.cpp:290
Comment 5 Reid Spencer 2007-02-18 00:27:13 PST
Since this doesn't seem to be getting attended to, I'm going to revert Evan's
patches if it resolves this issue.
Comment 6 Reid Spencer 2007-02-18 01:10:37 PST
Created attachment 671 [details]
Script to revert Evant's changes.

I'm not going to commit this, but here's a little script that revert's Evans
changes. This allows llvm-gcc to compile. However, there are still dejagnu
failures. Additionally, a change to llvm-gcc was needed. To use this,

1. Save to /tmp/pr1207.revert
2. cd llvm
3. . /tmp/pr1207.revert
Comment 7 Reid Spencer 2007-02-18 21:23:20 PST
Evans changes have been reverted. These alleviates the issue, but I'm not
closing this until Evan can figure out why his changes caused the bug and
reapplies with a fix.

Assigning to Evan.
Comment 8 Evan Cheng 2007-02-19 15:50:57 PST
Reapplied with fix. llvm-gcc builds fine on Mac OS X. Reid / Anton, please trye to d a llvm-gcc build on 
Linux. Thanks.
Comment 10 Anton Korobeynikov 2007-02-19 17:38:24 PST
libgcc is ok for me now. I'm starting building Qt. If everything will be ok,
this bug can be closed. Ok?
Comment 11 Anton Korobeynikov 2007-02-19 18:24:33 PST
Seems, llc -debug is broken somehow. Try attached bytecode.

It should:
1. Compile ok with just "llc"
2. Cycle with "llc -relocation-model=pic".

It seems to do so, but adding -debug lead llc to segfault.
Comment 12 Anton Korobeynikov 2007-02-19 18:25:16 PST
Created attachment 672 [details]
Bytecode
Comment 13 Anton Korobeynikov 2007-02-19 18:25:39 PST
Created attachment 673 [details]
LLVM source code
Comment 14 Evan Cheng 2007-02-19 19:28:46 PST
Anton, I think llc -debug is a separate issue. Can you close this bug and open a new one for that?

Thanks!
Comment 15 Anton Korobeynikov 2007-02-20 01:54:14 PST
Qt is heavily broken. I'm investigating.
Comment 16 Anton Korobeynikov 2007-02-20 03:18:30 PST
Evan, this change definitly breaks Qt. Are there any fails in nightlytests? I'm
investigating the problem, but don't know, how much time it will take.

I'm also attaching patch which will undo recent LiveVars change.
Comment 17 Anton Korobeynikov 2007-02-20 03:19:54 PST
Created attachment 676 [details]
LiveVars patch. 

Use "patch -p1 -R" to revert.
Comment 18 Evan Cheng 2007-02-20 15:01:17 PST
There are some significant regressions which I am trying to track down. They appear to be unrelated to 
liveintervalanalysis. I'll let you know what the bug is fixed so you can try again.
Comment 19 Anton Korobeynikov 2007-02-20 15:29:21 PST
Well. Ok. I'm waiting.
Comment 20 Evan Cheng 2007-02-20 15:32:49 PST
I've fix the bug which breaks a bunch of tests that use double. Anton, can you test QT again?
Comment 21 Anton Korobeynikov 2007-02-20 15:55:32 PST
Surely.
Comment 22 Anton Korobeynikov 2007-02-20 16:27:04 PST
It's building now. However, I don't understand how this issue can cause
segfaults... But will surely check.
Comment 23 Anton Korobeynikov 2007-02-20 17:23:01 PST
Qt is still broken. It just segfaults....
Comment 24 Anton Korobeynikov 2007-02-20 17:45:06 PST
Reduced miscompilation just to one .o. Comparing.
Comment 25 Anton Korobeynikov 2007-02-20 18:28:20 PST
Created attachment 677 [details]
LLVM source
Comment 26 Anton Korobeynikov 2007-02-20 18:28:43 PST
Created attachment 678 [details]
"Bad" output
Comment 27 Anton Korobeynikov 2007-02-20 18:29:02 PST
Created attachment 679 [details]
"Good" output
Comment 28 Anton Korobeynikov 2007-02-20 18:31:38 PST
Evan, recent LiveVariables patches caused the folowing regression to Qt. Please
see attached LLVM source and 2 assembler listings. One ("Good") - without
LiveVars patch and another - with. I think, you should compile .ll with
"--relocation-model=pic" llc option.

There are only few differences, but they seems to be very strange.
Comment 29 Anton Korobeynikov 2007-02-21 02:32:56 PST
I'm sorry. "Good" output should be "Bad" and vice versa.
Comment 30 Anton Korobeynikov 2007-02-21 02:35:10 PST
Comment on attachment 678 [details]
"Bad" output

Fixed mark
Comment 31 Anton Korobeynikov 2007-02-21 02:35:14 PST
Comment on attachment 679 [details]
"Good" output

Fixed mark
Comment 32 Evan Cheng 2007-02-21 12:26:44 PST
Ah, ok. I'd suspected that. I'll try to fix this today.
Comment 33 Evan Cheng 2007-02-21 14:19:47 PST
Anton, can you confirm _ZNK11QMetaObject6methodEi is the offending function? For Linux / PIC, EBX 
must always point to the GOT, right? I see now codegen (thanks to smarter liveintervalanalysis) is making 
use of EBX as a general purpose register.
Comment 34 Anton Korobeynikov 2007-02-21 14:25:40 PST
No. Not always. Any register can be used as GOT pointer with only one
restriction: during function calls via PLT GOT pointer should be in %ebx (there
is special %ebx loading inside call lowering).

I'll check function separately and let you know.
Comment 35 Anton Korobeynikov 2007-02-21 14:39:09 PST
Well. Yes. It seems, that %ebx is changed before calls via PLT.

This applies for all 3 functions found in diff between "bad" and "good"
Comment 36 Evan Cheng 2007-02-21 15:20:35 PST
Needed to add an implicit use of EBX so the result of the instruction that calculate GOT is not dead right 
after defintion.
http://lists.cs.uiuc.edu/pipermail/llvm-commits/Week-of-Mon-20070219/044839.html

Anton, can you verify if this fixes QT?
Comment 37 Anton Korobeynikov 2007-02-21 15:27:27 PST
Verifying...
Comment 38 Anton Korobeynikov 2007-02-21 15:38:20 PST
Evan, patch fixes issue with that file. Thanks. I'll close this bug just after
Qt will be rebuilt.
Comment 39 Anton Korobeynikov 2007-02-21 16:44:31 PST
Fixed, thanks, Evan.