From: rguenth Date: Fri, 30 May 2008 19:58:30 +0000 (+0000) Subject: 2008-05-30 Richard Guenther X-Git-Url: http://git.sourceforge.jp/view?p=pf3gnuchains%2Fgcc-fork.git;a=commitdiff_plain;h=40238f6439fd4250fee99bcea07e4096f34d4567;hp=5346190fb4317c3ebaa785c8d8e39a749a385267;ds=sidebyside 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 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9d29edca4fc..82739e03eff 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 695567cfbfc..77cd48beaed 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; }