From: Richard Guenther Date: Fri, 30 May 2008 19:58:30 +0000 (+0000) Subject: builtins.c (build_string_literal): Avoid generating a non-gimple_val result. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=acdfeac3e1073d863467b59f5cbe7d9f99dca74b;p=gcc.git builtins.c (build_string_literal): Avoid generating a non-gimple_val result. 2008-05-30 Richard Guenther * builtins.c (build_string_literal): Avoid generating a non-gimple_val result. From-SVN: r136222 --- 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; }