summaryrefslogtreecommitdiff
path: root/gcc/config/stormy16/stormy16.c
diff options
context:
space:
mode:
authornickc <nickc@138bc75d-0d04-0410-961f-82ee72b054a4>2011-05-22 14:51:34 +0000
committernickc <nickc@138bc75d-0d04-0410-961f-82ee72b054a4>2011-05-22 14:51:34 +0000
commit89a2af158ff017a1fe150ff5a5d16ce60838b977 (patch)
treea863917c2ee321f87c1dbc947e6d24315c1d944b /gcc/config/stormy16/stormy16.c
parent9d92f62db8510d49731b4031c2a13a29928b0fff (diff)
downloadgcc-89a2af158ff017a1fe150ff5a5d16ce60838b977.tar.gz
* config/stormy16/stormy16.c (xstormy16_init_builtins): prevent
initialisation of non-existant args[2] element. Use args[] array not arg[] array to pass arguments to build_function_type_list. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@174029 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/stormy16/stormy16.c')
-rw-r--r--gcc/config/stormy16/stormy16.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/gcc/config/stormy16/stormy16.c b/gcc/config/stormy16/stormy16.c
index 1a90e16da08..6edc2c1873b 100644
--- a/gcc/config/stormy16/stormy16.c
+++ b/gcc/config/stormy16/stormy16.c
@@ -2266,7 +2266,7 @@ xstormy16_init_builtins (void)
gcc_assert (n_args <= (int) ARRAY_SIZE (args));
- for (a = n_args; a >= 0; a--)
+ for (a = n_args - 1; a >= 0; a--)
args[a] = NULL_TREE;
for (a = n_args; a >= 0; a--)
@@ -2284,9 +2284,9 @@ xstormy16_init_builtins (void)
else
args[a-1] = arg;
}
- ftype = build_function_type_list (ret_type, arg[0], arg[1], NULL_TREE);
+ ftype = build_function_type_list (ret_type, args[0], args[1], NULL_TREE);
add_builtin_function (s16builtins[i].name, ftype,
- i, BUILT_IN_MD, NULL, NULL);
+ i, BUILT_IN_MD, NULL, NULL_TREE);
}
}
@@ -2407,7 +2407,8 @@ combine_bnp (rtx insn)
{
/* LT and GE conditionals should have a sign extend before
them. */
- for (and_insn = prev_real_insn (insn); and_insn;
+ for (and_insn = prev_real_insn (insn);
+ and_insn != NULL_RTX;
and_insn = prev_real_insn (and_insn))
{
int and_code = recog_memoized (and_insn);
@@ -2436,7 +2437,8 @@ combine_bnp (rtx insn)
else
{
/* EQ and NE conditionals have an AND before them. */
- for (and_insn = prev_real_insn (insn); and_insn;
+ for (and_insn = prev_real_insn (insn);
+ and_insn != NULL_RTX;
and_insn = prev_real_insn (and_insn))
{
if (recog_memoized (and_insn) == CODE_FOR_andhi3
@@ -2481,7 +2483,8 @@ combine_bnp (rtx insn)
}
}
}
- if (!and_insn)
+
+ if (and_insn == NULL_RTX)
return;
for (load = shift ? prev_real_insn (shift) : prev_real_insn (and_insn);