glibc40/eglibc-mandriva-nss-upgrade.patch

26 lines
938 B
Diff

--- libc/nss/nsswitch.c.nssUpgrade~ 2012-10-10 17:35:46.000000000 +0200
+++ libc/nss/nsswitch.c 2012-12-27 20:00:24.390443900 +0100
@@ -399,9 +399,20 @@ nss_load_library (service_user *ni)
ni->library->lib_handle = __libc_dlopen (shlib_name);
if (ni->library->lib_handle == NULL)
{
- /* Failed to load the library. */
- ni->library->lib_handle = (void *) -1l;
- __set_errno (saved_errno);
+ /* Failed to load the library. Try a fallback. */
+ int n = __snprintf(shlib_name, shlen, "libnss_%s.so.%d.%d",
+ ni->library->name, __GLIBC__, __GLIBC_MINOR__);
+ if (n >= shlen)
+ ni->library->lib_handle = NULL;
+ else
+ ni->library->lib_handle = __libc_dlopen (shlib_name);
+
+ if (ni->library->lib_handle == NULL)
+ {
+ /* Ok, really fail now. */
+ ni->library->lib_handle = (void *) -1l;
+ __set_errno (saved_errno);
+ }
}
# ifdef USE_NSCD
else if (is_nscd)