[Bug target/39179] Wrong code in c++ for const members initialized in external file

rguenth at gcc dot gnu dot org gcc-bugzilla@gcc.gnu.org
Sat Feb 14 17:03:00 GMT 2009



------- Comment #2 from rguenth at gcc dot gnu dot org  2009-02-14 17:03 -------
The problem is that targetm.binds_local_p returns true for

 <var_decl 0xb7866000 k
    type <integer_type 0xb785edd0 unsigned int readonly unsigned SI
        size <integer_cst 0xb778b4a4 constant 32>
        unit size <integer_cst 0xb778b1f8 constant 4>
        align 32 symtab 0 alias set -1 canonical type 0xb785edd0 precision 32
min <integer_cst 0xb778b4c8 0> max <integer_cst 0xb778b480 4294967295>>
    readonly used public static unsigned external nonlocal decl_3 decl_5 decl_6
SI file t.ii line 2 col 27 size <integer_cst 0xb778b4a4 32> unit size
<integer_cst 0xb778b1f8 4>
    align 32 context <record_type 0xb785ec30 K>
    chain <type_decl 0xb785ed00 K>>

though probably nobody thought of handling TREE_STATIC && DECL_EXTERNAL being
true at the same time.  Thus, this looks like a possible C++ FE problem to me?

A simple fix would be for i386_pe_binds_local_p to return false if
DECL_EXTERNAL is set, as this is what default_binds_local_p_1 does.
Or better, it should dispatch to default_binds_local_p_1 and only
adjust the shlib flag according to DECL_DLLIMPORT_P.


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=39179



More information about the Gcc-bugs mailing list