From: DJ Delorie <dj@redhat.com>
To: Andreas Schwab <schwab@linux-m68k.org>
Cc: libc-alpha@sourceware.org
Subject: Re: v5 [PATCH 6/6] nsswitch: use new internal API (callers)
Date: Mon, 15 Feb 2021 21:36:20 -0500 [thread overview]
Message-ID: <xn8s7oagd7.fsf@greed.delorie.com> (raw)
In-Reply-To: <87wnv9z6ab.fsf@igel.home> (message from Andreas Schwab on Mon, 15 Feb 2021 16:42:36 +0100)
Andreas Schwab <schwab@linux-m68k.org> writes:
> This makes nss_compat non-functional.
Since you have a way to test it, and have not included a reproducer,
could you please test this patch?
Thanks!
From 85b77876abf0d98eb57bf692499fd1f229459f72 Mon Sep 17 00:00:00 2001
From: DJ Delorie <dj@redhat.com>
Date: Mon, 15 Feb 2021 21:34:23 -0500
Subject: nss: fix nss_database_lookup2's alternate handling [27416]
diff --git a/nss/nsswitch.c b/nss/nsswitch.c
index 46f232d720..6d4aa3b019 100644
--- a/nss/nsswitch.c
+++ b/nss/nsswitch.c
@@ -76,24 +76,25 @@ __nss_database_lookup2 (const char *database, const char *alternate_name,
for (database_id = 0; database_names[database_id]; database_id++)
if (strcmp (database_names[database_id], database) == 0)
- break;
+ /* If *NI is NULL, the database was not mentioned in nsswitch.conf.
+ If *NI is not NULL, but *NI->module is NULL, the database was in
+ nsswitch.conf but listed no actions. We test for the former. */
+ if (__nss_database_get (database_id, ni) && *ni != NULL)
+ return 0;
- if (database_names[database_id] == NULL)
- return -1;
+ /* Primary name not found, try alternate. */
+ for (database_id = 0; database_names[database_id]; database_id++)
+ if (strcmp (database_names[database_id], alternate_name) == 0)
+ if (__nss_database_get (database_id, ni) && *ni != NULL)
+ return 0;
- /* If *NI is NULL, the database was not mentioned in nsswitch.conf.
- If *NI is not NULL, but *NI->module is NULL, the database was in
- nsswitch.conf but listed no actions. We test for the former. */
- if (__nss_database_get (database_id, ni) && *ni != NULL)
- {
- /* Success. */
- return 0;
- }
- else
- {
- /* Failure. */
- return -1;
- }
+ /* Neither found, use default config. */
+ *ni = __nss_action_parse (defconfig);
+ if (*ni != NULL)
+ return 0;
+
+ /* Failure. */
+ return -1;
}
libc_hidden_def (__nss_database_lookup2)
next prev parent reply other threads:[~2021-02-16 2:36 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-12-03 20:34 DJ Delorie
2020-12-04 3:29 ` Siddhesh Poyarekar
2021-02-15 15:42 ` Andreas Schwab
2021-02-16 2:36 ` DJ Delorie [this message]
2021-02-16 8:38 ` Andreas Schwab
2021-02-17 5:42 ` DJ Delorie
2021-02-17 13:27 ` Andreas Schwab
2021-02-17 20:44 ` DJ Delorie
2021-02-17 21:09 ` Andreas Schwab
2021-02-17 21:15 ` DJ Delorie
2021-02-17 22:31 ` Andreas Schwab
2021-02-17 22:51 ` DJ Delorie
2021-02-17 23:23 ` Andreas Schwab
2021-02-18 4:55 ` DJ Delorie
2021-02-18 8:43 ` Andreas Schwab
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=xn8s7oagd7.fsf@greed.delorie.com \
--to=dj@redhat.com \
--cc=libc-alpha@sourceware.org \
--cc=schwab@linux-m68k.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).