OSDN Git Service

* config/c4x/c4x.c (c4x_function_arg): Check for void_type_node
authorm.hayes <m.hayes@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 2 Apr 2000 09:19:17 +0000 (09:19 +0000)
committerm.hayes <m.hayes@138bc75d-0d04-0410-961f-82ee72b054a4>
Sun, 2 Apr 2000 09:19:17 +0000 (09:19 +0000)
  before checking MUST_PASS_IN_STACK.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@32865 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/c4x/c4x.c

index 9f8c235..83c2d29 100644 (file)
@@ -1,3 +1,8 @@
+2000-04-02  Michael Hayes  <m.hayes@elec.canterbury.ac.nz>
+
+       * config/c4x/c4x.c (c4x_function_arg): Check for void_type_node
+       before checking MUST_PASS_IN_STACK.
+
 2000-04-02  Neil Booth <NeilB@earthling.net>
 
        * cppexp.c:  New FINISHED dummy token.  Combine operator initial
index 3ee934c..9972f47 100644 (file)
@@ -603,6 +603,11 @@ c4x_function_arg (cum, mode, type, named)
       cum->init = 1;
     }
 
+  /* This marks the last argument.  We don't need to pass this through
+     to the call insn.  */
+  if (type == void_type_node)
+    return 0;
+
   if (! TARGET_MEMPARM 
       && named 
       && type
@@ -742,7 +747,8 @@ c4x_assembler_function_p ()
   tree type;
 
   type = TREE_TYPE (current_function_decl);
-  return lookup_attribute ("assembler", TYPE_ATTRIBUTES (type)) != NULL;
+  return (lookup_attribute ("assembler", TYPE_ATTRIBUTES (type)) != NULL)
+    || (lookup_attribute ("naked", TYPE_ATTRIBUTES (type)) != NULL);
 }