aboutsummaryrefslogtreecommitdiff
path: root/gcc/builtins.c
diff options
context:
space:
mode:
authorAndrew Pinski <apinski@cavium.com>2014-02-26 00:51:56 +0000
committerAndrew Pinski <pinskia@gcc.gnu.org>2014-02-25 16:51:56 -0800
commitb8a542c64830635d1716130f41da4c7a165b5872 (patch)
tree1eba01a5eec5c3344112839c52aa60900e983919 /gcc/builtins.c
parentfa5d996595fca63a657647ee94cd4d4792b46d75 (diff)
downloadgcc-b8a542c64830635d1716130f41da4c7a165b5872.zip
gcc-b8a542c64830635d1716130f41da4c7a165b5872.tar.gz
gcc-b8a542c64830635d1716130f41da4c7a165b5872.tar.bz2
builtins.c (expand_builtin_thread_pointer): Create a new target when the target is NULL.
2014-02-25 Andrew Pinski <apinski@cavium.com> * builtins.c (expand_builtin_thread_pointer): Create a new target when the target is NULL. From-SVN: r208163
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r--gcc/builtins.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 35969ad..7c6318e 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -5712,7 +5712,10 @@ expand_builtin_thread_pointer (tree exp, rtx target)
if (icode != CODE_FOR_nothing)
{
struct expand_operand op;
- if (!REG_P (target) || GET_MODE (target) != Pmode)
+ /* If the target is not sutitable then create a new target. */
+ if (target == NULL_RTX
+ || !REG_P (target)
+ || GET_MODE (target) != Pmode)
target = gen_reg_rtx (Pmode);
create_output_operand (&op, target, Pmode);
expand_insn (icode, 1, &op);