Re: [PATCH] tests: add test to illustrate problem on git codebase

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On 06/02/2019 01:14, Ramsay Jones wrote:
> 
> Add a new test file which demonstrates some problems which can be
> seen on the git codebase. gcc does not complain about this file:
> 
>   $ gcc -Wall -c validation/function-redecl2.c
>   $
> 
> ... but sparse does:
> 
>   $ sparse validation/function-redecl2.c
>   validation/function-redecl2.c:6:5: error: symbol 'func0' redeclared with different type (originally declared at validation/function-redecl2.c:3) - different modifiers
>   validation/function-redecl2.c:13:6: error: symbol 'func1' redeclared with different type (originally declared at validation/function-redecl2.c:11) - different modifiers
>   validation/function-redecl2.c:21:6: error: symbol 'func2' redeclared with different type (originally declared at validation/function-redecl2.c:18) - different modifiers
>   $
> 
> Note that func0 and func2 are essentially the same example, apart from
> the attribute used, to demonstrate that the issue isn't caused by the
> 'pure' attribute. Also, examples like func1 have occurred several times
> in git and, although they can be worked around (eg. See [1]), it would
> be preferable if this were not necessary.
> 
> This test is marked 'check-know-to-fail'.

Heh, of course, this should be 'check-known-to-fail'. sigh. ;-)

ATB,
Ramsay Jones

> 
> [1] (git) commit 3d7dd2d3b6 ("usage: add NORETURN to BUG() function
> definitions", 2017-05-21).
> 
> Signed-off-by: Ramsay Jones <ramsay@xxxxxxxxxxxxxxxxxxxx>
> ---
> 
> Hi Luc,
> 
> As promised, a 'known-to-fail' test case.
> 
> Thanks!
> 
> ATB,
> Ramsay Jones
> 
>  validation/function-redecl2.c | 32 ++++++++++++++++++++++++++++++++
>  1 file changed, 32 insertions(+)
>  create mode 100644 validation/function-redecl2.c
> 
> diff --git a/validation/function-redecl2.c b/validation/function-redecl2.c
> new file mode 100644
> index 0000000..c7bb93b
> --- /dev/null
> +++ b/validation/function-redecl2.c
> @@ -0,0 +1,32 @@
> +extern void exit (int __status) __attribute__ ((__noreturn__));
> +
> +int func0(int a) __attribute__ ((pure));
> +
> +__attribute__ ((pure))
> +int func0(int a)
> +{
> +	return 0;
> +}
> +
> +__attribute__ ((noreturn)) void func1(int a);
> +
> +void func1(int a)
> +{
> +	exit(0);
> +}
> +
> +void func2(int a) __attribute__ ((noreturn));
> +
> +__attribute__ ((noreturn))
> +void func2(int a)
> +{
> +	exit(0);
> +}
> +
> +/*
> + * check-name: function-redecl2
> + *
> + * check-known-to-fail
> + *
> + */
> +
> 



[Index of Archives]     [Newbies FAQ]     [LKML]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Trinity Fuzzer Tool]

  Powered by Linux