From ea2e5dbeca4179d9c4ab0544d17413b4b2c0715e Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Wed, 22 Mar 2000 15:09:29 -0800 Subject: [PATCH] alpha.c (function_arg): Check for void_type_node before using MUST_PASS_IN_STACK. * config/alpha/alpha.c (function_arg): Check for void_type_node before using MUST_PASS_IN_STACK. From-SVN: r32692 --- gcc/ChangeLog | 5 +++++ gcc/config/alpha/alpha.c | 9 +++++++-- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 9fe40d10a47..4a08c3258c8 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2000-03-21 Richard Henderson + + * config/alpha/alpha.c (function_arg): Check for void_type_node + before using MUST_PASS_IN_STACK. + 2000-03-21 Stephane Carrez * regmove.c (combine_stack_adjustments_for_block): Check that diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c index 601c1d2f5df..7c53f52932b 100644 --- a/gcc/config/alpha/alpha.c +++ b/gcc/config/alpha/alpha.c @@ -3697,10 +3697,15 @@ function_arg(cum, mode, type, named) { int basereg; - if (cum >= 6 || MUST_PASS_IN_STACK (mode, type)) + if (cum >= 6) return NULL_RTX; - if (FUNCTION_ARG_PASS_BY_REFERENCE (cum, mode, type, named)) + /* VOID is passed as a special flag for "last argument". */ + if (type == void_type_node) + basereg = 16; + else if (MUST_PASS_IN_STACK (mode, type)) + return NULL_RTX; + else if (FUNCTION_ARG_PASS_BY_REFERENCE (cum, mode, type, named)) basereg = 16; else if (TARGET_FPREGS && (GET_MODE_CLASS (mode) == MODE_COMPLEX_FLOAT -- 2.30.2