mirror of
https://git.yoctoproject.org/git/poky
synced 2026-01-01 13:58:04 +00:00
pseudo: Work around issues with glibc 2.24
There are issues with a change made to RTLD_NEXT behaviour in glibc 2.24 and that change was also backported to older glibc versions in some distros like Fedora 23. This adds a workaround whilst the pseudo maintainer fixes various issues properly. (From OE-Core rev: 21c38a091c4a1917f62a942c4751b0fd11dce340) (From OE-Core rev: 47f5c2a52f93e1984b0269c708ca5218b9fd41ec) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org> Signed-off-by: Armin Kuster <akuster808@gmail.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
parent
cb5649cbb8
commit
7b9e031355
|
|
@ -0,0 +1,85 @@
|
|||
We started seeing:
|
||||
|
||||
No real function for mknod: /home/paul/poky_sdk/tmp/sysroots/x86_64-
|
||||
linux/usr/bin/../lib/pseudo/lib64/libpseudo.so: undefined symbol: mknod
|
||||
No real function for mknodat: /home/paul/poky_sdk/tmp/sysroots/x86_64-
|
||||
linux/usr/bin/../lib/pseudo/lib64/libpseudo.so: undefined symbol: mknodat
|
||||
|
||||
In glibc 2.24 they've merged:
|
||||
|
||||
https://sourceware.org/git/?p=glibc.git;a=commit;h=7d45c163d00c88d5875a112343c4ea3e61349e6b
|
||||
related to bugzilla entry:
|
||||
https://sourceware.org/bugzilla/show_bug.cgi?id=19509
|
||||
|
||||
which means that the behaviour of RTLD_NEXT is slightly different.
|
||||
As far as I can tell, mknod has not been present in glibc for a while.
|
||||
To quote stat.h:
|
||||
|
||||
/* To allow the `struct stat' structure and the file type `mode_t'
|
||||
bits to vary without changing shared library major version number,
|
||||
the `stat' family of functions and `mknod' are in fact inline
|
||||
wrappers around calls to `xstat', `fxstat', `lxstat', and `xmknod',
|
||||
which all take a leading version-number argument designating the
|
||||
data structure and bits used. <bits/stat.h> defines _STAT_VER with
|
||||
the version number corresponding to `struct stat' as defined in
|
||||
that file; and _MKNOD_VER with the version number corresponding to
|
||||
the S_IF* macros defined therein. It is arranged that when not
|
||||
inlined these function are always statically linked; that way a
|
||||
dynamically-linked executable always encodes the version number
|
||||
corresponding to the data structures it uses, so the `x' functions
|
||||
in the shared library can adapt without needing to recompile all
|
||||
callers. */
|
||||
|
||||
so I suspect mknod has not existed for a while, if ever and what we
|
||||
were finding, who knows. Everying in the system links against _xmknod
|
||||
which we have a separate wrapper for.
|
||||
|
||||
Anyhow, ignoring that problem which hasn't caused a issue in the past,
|
||||
the RTLD_NEXT change causes messages to be printed to stdout which causes
|
||||
carnage if for example the packaging code is expecting a list of packages:
|
||||
|
||||
WARNING: core-image-minimal-1.0-r0 do_rootfs: No not found in the base feeds (qemux86_64 core2-64 x86_64 noarch any all).
|
||||
WARNING: core-image-minimal-1.0-r0 do_rootfs: real not found in the base feeds (qemux86_64 core2-64 x86_64 noarch any all).
|
||||
WARNING: core-image-minimal-1.0-r0 do_rootfs: function not found in the base feeds (qemux86_64 core2-64 x86_64 noarch any all).
|
||||
WARNING: core-image-minimal-1.0-r0 do_rootfs: for not found in the base feeds (qemux86_64 core2-64 x86_64 noarch any all).
|
||||
WARNING: core-image-minimal-1.0-r0 do_rootfs: mknod: not found in the base feeds (qemux86_64 core2-64 x86_64 noarch any all).
|
||||
[etc]
|
||||
|
||||
This bug will affect:
|
||||
* any distro using glibc 2.24
|
||||
* any system using a uninative tarball for glibc 2.24
|
||||
* any system which took a backport for the fix which was merged into
|
||||
the 2.23 branch for a while before it was reverted (Fedora 23 had this)
|
||||
|
||||
The easiest thing to do is to ignore the problem and disable the diag
|
||||
message which masks the problem with no ill effects.
|
||||
|
||||
As Peter notes, there are a few issues here:
|
||||
|
||||
* the fact there is no mknod symbol
|
||||
* the fact an error here isn't fatal
|
||||
* the #ifdef/#else looks suspect
|
||||
* handle RTLD_NEXT chaining properly (need more libs?)
|
||||
|
||||
which he'll work on upstream and hopefully have fixed in a new version.
|
||||
|
||||
Upstream-Status: Submitted [Peter is aware of the issue]
|
||||
|
||||
RP 2016/5/18
|
||||
|
||||
Index: pseudo-1.7.5/pseudo_wrappers.c
|
||||
===================================================================
|
||||
--- pseudo-1.7.5.orig/pseudo_wrappers.c
|
||||
+++ pseudo-1.7.5/pseudo_wrappers.c
|
||||
@@ -146,9 +146,9 @@ pseudo_init_one_wrapper(pseudo_function
|
||||
return;
|
||||
}
|
||||
#else
|
||||
- if (e != NULL) {
|
||||
+ /*if (e != NULL) {
|
||||
pseudo_diag("No real function for %s: %s\n", func->name, e);
|
||||
- }
|
||||
+ }*/
|
||||
#endif
|
||||
}
|
||||
}
|
||||
|
|
@ -7,6 +7,7 @@ SRC_URI = "http://downloads.yoctoproject.org/releases/pseudo/${BPN}-${PV}.tar.bz
|
|||
file://moreretries.patch \
|
||||
file://handle-remove-xattr.patch \
|
||||
file://obey-ldflags.patch \
|
||||
file://pseudo-glibc-rtld-next-workaround.patch \
|
||||
"
|
||||
|
||||
SRC_URI[md5sum] = "c10209938f03128d0c193f041ff3596d"
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user