On Tue, 2010-01-05 at 15:42 +0800, Carrot Wei wrote:
> Hi
> 
> In function arm_load_pic_register in file arm.c there are following code:
> 
>       if (TARGET_ARM)
>       {
>               ...
>       }
>       else if (TARGET_THUMB2)
>       {
>         /* Thumb-2 only allows very limited access to the PC.  Calculate the
>            address in a temporary register.  */
>         if (arm_pic_register != INVALID_REGNUM)
>           {
>             pic_tmp = gen_rtx_REG (SImode,
>                                    thumb_find_work_register (saved_regs));
>           }
>         else
>           {
>             gcc_assert (can_create_pseudo_p ());
>             pic_tmp = gen_reg_rtx (Pmode);
>           }
> 
>         emit_insn (gen_pic_load_addr_thumb2 (pic_reg, pic_rtx));
>         emit_insn (gen_pic_load_dot_plus_four (pic_tmp, labelno));
>         emit_insn (gen_addsi3 (pic_reg, pic_reg, pic_tmp));
>       }
>       else /* TARGET_THUMB1 */
>       {
>               ...
>       }
> 
> The comment said "Thumb-2 only allows very limited access to the PC.
> Calculate the address in a temporary register.". So the generated code
> is a little more complex than thumb1. Could anybody help to give more
> explanation on the limitation thumb2 has compared to thumb1?
> 
> The generated instructions by this function for thumb1 is listed
> following, both instructions are available under thumb2.
> 
>         ldr     r3, .L2
> .LPIC0:
>         add     r3, pc

I didn't write the comment, but I think the limitation is relative to
ARM not thumb1.  Thumb2 code generator is a variation on the ARM code
generator, so the author was most likely thinking of that rather than
Thumb1.

R.


Reply via email to