*** empty log message ***
authoralehotsky <alehotsky@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 11 Jan 2001 23:01:40 +0000 (23:01 +0000)
committeralehotsky <alehotsky@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 11 Jan 2001 23:01:40 +0000 (23:01 +0000)
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@38929 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/builtins.c

index 0bb9646..b1d8c07 100644 (file)
@@ -1,3 +1,8 @@
+2001-01-11  Alan Lehotsky  <lehotsky@tiac.net>
+
+       * builtins.c (std_expand_builtin_va_start): Handle varargs when
+       sizeof (int) is larger than sizeof(__word__).
+       
 2001-01-11  Neil Booth  <neil@daikokuya.demon.co.uk>
 
         * cppinit.c (do_includes): Fix typo.
index 1ad33f2..b7db928 100644 (file)
@@ -2801,8 +2801,13 @@ std_expand_builtin_va_start (stdarg_p, valist, nextarg)
 
   if (! stdarg_p)
     {
+      /* The dummy named parameter is declared as a 'word' sized
+        object, but if a 'word' is smaller than an 'int', it would
+        have been promoted to int when it was added to the arglist.  */
       int align = PARM_BOUNDARY / BITS_PER_UNIT;
-      int offset = (((UNITS_PER_WORD + align - 1) / align) * align);
+      int size = MAX (UNITS_PER_WORD,
+                     GET_MODE_SIZE (TYPE_MODE (integer_type_node)));
+      int offset = ((size + align - 1) / align) * align;
       nextarg = plus_constant (nextarg, -offset);
     }