From 40238f6439fd4250fee99bcea07e4096f34d4567 Mon Sep 17 00:00:00 2001 From: rguenth Date: Fri, 30 May 2008 19:58:30 +0000 Subject: [PATCH] 2008-05-30 Richard Guenther * builtins.c (build_string_literal): Avoid generating a non-gimple_val result. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@136222 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 5 +++++ gcc/builtins.c | 9 ++++----- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9d29edc..82739e0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2008-05-30 Richard Guenther + + * builtins.c (build_string_literal): Avoid generating + a non-gimple_val result. + 2008-05-30 DJ Delorie * exec-tool.in: Use an environment variable (private) instead of a diff --git a/gcc/builtins.c b/gcc/builtins.c index 695567c..77cd48b 100644 --- a/gcc/builtins.c +++ b/gcc/builtins.c @@ -5249,18 +5249,17 @@ build_string_literal (int len, const char *str) t = build_string (len, str); elem = build_type_variant (char_type_node, 1, 0); - index = build_index_type (build_int_cst (NULL_TREE, len - 1)); + index = build_index_type (size_int (len - 1)); type = build_array_type (elem, index); TREE_TYPE (t) = type; TREE_CONSTANT (t) = 1; TREE_READONLY (t) = 1; TREE_STATIC (t) = 1; - type = build_pointer_type (type); - t = build1 (ADDR_EXPR, type, t); - type = build_pointer_type (elem); - t = build1 (NOP_EXPR, type, t); + t = build1 (ADDR_EXPR, type, + build4 (ARRAY_REF, elem, + t, integer_zero_node, NULL_TREE, NULL_TREE)); return t; } -- 2.7.4