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

--- Comment #6 from H.J. Lu <hjl.tools at gmail dot com> 2011-07-27 15:42:37 
UTC ---
(In reply to comment #5)
> (In reply to comment #4)
> 
> > > Can you prevent x32 to generate DImode symbols? No, since Pmode is still 
> > > in
> > > DImode and DImode addresses are *valid* addresses. For the testcase from 
> > > PR,
> > > expand generates SImode symbol that is later extended to DImode and 
> > > handled
> > > through movabs.
> > 
> > This testcase is about valid address for x86_64_immediate_operand
> > and x86_64_zext_immediate_operand.  If it is valid for TARGET_32BIT,
> > it should be valid for TARGET_X32.
> 
> (define_predicate "x86_64_immediate_operand"
>   (match_code "const_int,symbol_ref,label_ref,const")
> {
>   if (!TARGET_64BIT)
>     return immediate_operand (op, mode);
>   ...

X32 != LP64.

> 
> I guess the code above speaks for itself.
> 
> > Assembler is done on purpose to catch problems like this.
> 
> This is artificial limitation.

Those generated codes aren't very efficient for x32. There is
a problem somewhere.

Reply via email to