Date: Tue, 17 Jun 1997 03:40:01 -0700 (PDT) From: Bruce Evans <bde@zeta.org.au> To: freebsd-bugs Subject: Re: bin/3884: stdarg.h fails for data types < 4 bytes Message-ID: <199706171040.DAA07953@hub.freebsd.org>
next in thread | raw e-mail | index | archive | help
The following reply was made to PR bin/3884; it has been noted by GNATS.
From: Bruce Evans <bde@zeta.org.au>
To: arnej@mail.math.ntnu.no, arnej@math.ntnu.no, bde@zeta.org.au,
FreeBSD-gnats-submit@FreeBSD.ORG
Cc: Subject: Re: bin/3884: stdarg.h fails for data types < 4 bytes
Date: Tue, 17 Jun 1997 20:20:32 +1000
>> >>How-To-Repeat:
>> >
>> > Inspect <stdarg.h>, or compile and run the following test
>> > program, gotten from c-torture.
>>
>> This program does not conform to standard C.
>
>If it used short, I would agree with you. However, it uses a struct,
>and structs doesn't promote at all. Therefore, the program is
>conforming (maybe even strictly conforming) Ansi C and must work.
You are right. I should have read your example more carefully.
Your patch can be improved by fixing the KERNEL case too and renaming
__va_promote - there is no way to determine the promoted sizes without a
builtin, and the args may have additional padding anyway, so __va_promote
is a confusing name. The corresponding macro is named __va_rounded_size
in gcc/ginclude/stdarg.h and __va_size in NetBSD.
Bruce
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199706171040.DAA07953>
