Re: sparse-llvm segfaults when passing a struct pointer

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Jonathan,

[ Please CC me on sparse-llvm related issues. ]

On Thu, Jul 19, 2012 at 4:17 PM, Jonathan Neuschäfer
<j.neuschaefer@xxxxxxx> wrote:
> compiling a little real-world program with sparse-llvm, it segfaulted.
> Using a tool called "delta"[1] and some bash scripting, I managed to
> reduce the code to this test case:
>
>     //struct foo {int a;};
>     //struct foo;
>     extern struct foo *foop;
>     extern void func(struct foo *f);
>     int main(int argc, char **argv) {
>         func(foop);
>     }
>
> (Uncommenting the commented lines doesn't change the crashing)
>
> gdb gives me this backtrace:
>
>     (gdb) bt
>     #0  0x080b86c1 in LLVMBuildPtrToInt ()
>     #1  0x080530fd in output_op_load (insn=0xb742512c, fn=0xbf85624c) at sparse-llvm.c:595
>     #2  output_insn (insn=0xb742512c, fn=0xbf85624c) at sparse-llvm.c:1008
>     #3  output_bb (generation=7, fn=0xbf85624c, bb=<optimized out>) at sparse-llvm.c:1096
>     #4  output_fn (module=0xb7738f0c, module@entry=0x8ccc750, ep=<error reading variable: Unhandled dwarf expression opcode 0xfa>,
>         ep=<error reading variable: Unhandled dwarf expression opcode 0xfa>) at sparse-llvm.c:1166
>     #5  0x080507ec in compile (list=0xb773858c, module=0x8ccc750) at sparse-llvm.c:1227
>     #6  main (argc=2, argv=0xbf856684) at sparse-llvm.c:1246
>
> I'm using llvm version 3.0 (package version 1:3.0-14) from Debian and
> sparse v0.4.4-100-g063236f (the most recent commit in git).

The SIGSEGV is caused by pseudo_to_value() returning NULL for "foop".
AFAICT, we should use LLVMGetNamedGlobal() to look it up but
unfortunately output_data() is *not* called for "foop" at all so the
backend doesn't know about it.

Linus, Jeff, how does the sparse frontend deal with externs? Why isn't
"foop" visible after linearize_symbol()?

                        Pekka
--
To unsubscribe from this list: send the line "unsubscribe linux-sparse" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Newbies FAQ]     [LKML]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Trinity Fuzzer Tool]

  Powered by Linux