Debian Patches

Status for sparse/0.6.4-5

Patch Description Author Forwarded Bugs Origin Last update
fix-unreplaced-warnings-caused-by-using-typeof-on-in.patch [PATCH] fix "unreplaced" warnings caused by using typeof() on inline functions

Currently, sparse do all its inlining at the tree level, during
constant expansion. To not mix-up the evaluation of the original
function body in case the address of an inline function is taken or
when the function can't otherwise be inlined, the statements and
symbols lists of inline functions are kept in separated fields.
Then, if the original body must be evaluated it must first be
'uninlined' to have a copy in the usual fields.

This make sense when dealing with the definition of the function.
But, when using typeof() on functions, the resulting type doesn't
refer to this definition, it's just a copy of the type and only
of the type. There shouldn't be any reasons to uninline anything.
However, the distinction between 'full function' and 'type only'
is not made during evaluation and the uninlining attempt produce
a lot of "warning: unreplaced symbol '...'" because of the lack
of a corresponding definition.

Fix this by not doing the uninlining if the symbol lack a definition.

a stripped-own version of evaluate_symbol() doing only the
examination of the return and argument types, bypassing the
attempt to uninline the body and evaluate the initializer and
the statements since there is none of those for an EXPR_TYPE.
Luc Van Oostenryck <luc.vanoostenryck@gmail.com> no upstream, commit:0e1aae55e49cad7ea43848af5b58ff0f57e7af99 2022-06-23
linearize.c-fix-buffer-overrun-warning-from-fortify.patch linearize.c: fix buffer overrun warning from fortify
The resulting string from snprintf, won't be nearly 64 bytes, but "buf"
is only 16 bytes long here. This causes FORTIFY_SOURCE to complain when
given the right options.
Jeff Layton <jlayton@kernel.org> no upstream, https://git.kernel.org/pub/scm/devel/sparse/sparse.git/commit?id=adceff0ab6e3d8bf43de52e2c2fbebf27db30deb 2023-02-27
ld-as-needed.patch Use ld --as-needed to drop superfluous dependencies
This fixes:

dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libgio-2.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libgdk_pixbuf-2.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libpango-1.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libcairo.so.2 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libfontconfig.so.1 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libatk-1.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libpangocairo-1.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libfreetype.so.6 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libgdk-x11-2.0.so.0 (it uses none of the library's symbols)
dpkg-shlibdeps: warning: package could avoid a useless dependency if debian/sparse/usr/bin/test-inspect was not linked against libpangoft2-1.0.so.0 (it uses none of the library's symbols)
Uwe Kleine-König <uwe@kleine-koenig.org> no
use-gcc-14.patch [PATCH] cgcc: use gcc-14 explicitly
By default sparse uses include files from the compiler it is compiled with. To
prevent that these include files are removed the sparse package has an explicit
dependency on gcc-14 (i.e. the current default gcc version) in Debian and is
patched to make use of (only) this version.

Last updated: 2024-12-21
Uwe Kleine-König <uwe@kleine-koenig.org> no 2018-10-08

All known versions for source package 'sparse'

Links