diff options
author | Arjun Shankar <arjun@redhat.com> | 2023-10-02 14:55:20 +0200 |
---|---|---|
committer | Arjun Shankar <arjun@redhat.com> | 2023-10-24 12:30:59 +0200 |
commit | 1c40266328babd3613d0fc7928449a7b53d87c73 (patch) | |
tree | 095c283352dd9ad0ddcefbca32d7fa9c462f4633 /nss | |
parent | 4298586619e4a8cf4ba0a5a9da31ae80efac173c (diff) | |
download | glibc-1c40266328babd3613d0fc7928449a7b53d87c73.zip glibc-1c40266328babd3613d0fc7928449a7b53d87c73.tar.gz glibc-1c40266328babd3613d0fc7928449a7b53d87c73.tar.bz2 |
Move 'ethers' routines from 'inet' into 'nss'
ether_hostton and ether_ntohost are entry points for nss functionality.
This commit moves them from the 'inet' subdirectory to 'nss', and
adjusts any references accordingly.
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Diffstat (limited to 'nss')
-rw-r--r-- | nss/Makefile | 6 | ||||
-rw-r--r-- | nss/Versions | 1 | ||||
-rw-r--r-- | nss/ether_hton.c | 58 | ||||
-rw-r--r-- | nss/ether_ntoh.c | 61 |
4 files changed, 126 insertions, 0 deletions
diff --git a/nss/Makefile b/nss/Makefile index 2dfa7eb..148c6dc 100644 --- a/nss/Makefile +++ b/nss/Makefile @@ -68,6 +68,12 @@ CFLAGS-getaliasent_r.c += -fexceptions CFLAGS-getaliasent.c += -fexceptions endif +# ethers routines: +routines += \ + ether_hton \ + ether_ntoh \ + # routines + # grp routines: routines += \ fgetgrent \ diff --git a/nss/Versions b/nss/Versions index 5d1b1da..99208cb 100644 --- a/nss/Versions +++ b/nss/Versions @@ -10,6 +10,7 @@ libc { endgrent; endpwent; endspent; + ether_hostton; ether_ntohost; # f* fgetgrent; fgetgrent_r; diff --git a/nss/ether_hton.c b/nss/ether_hton.c new file mode 100644 index 0000000..5419464 --- /dev/null +++ b/nss/ether_hton.c @@ -0,0 +1,58 @@ +/* Copyright (C) 1996-2023 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + <https://www.gnu.org/licenses/>. */ + +#include <errno.h> +#include <netinet/ether.h> +#include <netinet/if_ether.h> +#include <string.h> + +#include "nsswitch.h" + +/* Type of the lookup function we need here. */ +typedef int (*lookup_function) (const char *, struct etherent *, char *, int, + int *); + +int +ether_hostton (const char *hostname, struct ether_addr *addr) +{ + nss_action_list nip; + union + { + lookup_function f; + void *ptr; + } fct; + int no_more; + enum nss_status status = NSS_STATUS_UNAVAIL; + struct etherent etherent; + + no_more = __nss_ethers_lookup2 (&nip, "gethostton_r", NULL, &fct.ptr); + + while (no_more == 0) + { + char buffer[1024]; + + status = (*fct.f) (hostname, ðerent, buffer, sizeof buffer, &errno); + + no_more = __nss_next2 (&nip, "gethostton_r", NULL, &fct.ptr, status, 0); + } + + if (status == NSS_STATUS_SUCCESS) + memcpy (addr, etherent.e_addr.ether_addr_octet, + sizeof (struct ether_addr)); + + return status == NSS_STATUS_SUCCESS ? 0 : -1; +} diff --git a/nss/ether_ntoh.c b/nss/ether_ntoh.c new file mode 100644 index 0000000..2f1eb4e --- /dev/null +++ b/nss/ether_ntoh.c @@ -0,0 +1,61 @@ +/* Copyright (C) 1996-2023 Free Software Foundation, Inc. + This file is part of the GNU C Library. + + The GNU C Library is free software; you can redistribute it and/or + modify it under the terms of the GNU Lesser General Public + License as published by the Free Software Foundation; either + version 2.1 of the License, or (at your option) any later version. + + The GNU C Library is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + Lesser General Public License for more details. + + You should have received a copy of the GNU Lesser General Public + License along with the GNU C Library; if not, see + <https://www.gnu.org/licenses/>. */ + +#include <errno.h> +#include <netinet/ether.h> +#include <netinet/if_ether.h> +#include <string.h> + +#include <nsswitch.h> + + +/* Type of the lookup function we need here. */ +typedef int (*lookup_function) (const struct ether_addr *, struct etherent *, + char *, size_t, int *); + +int +ether_ntohost (char *hostname, const struct ether_addr *addr) +{ + nss_action_list nip; + union + { + lookup_function f; + void *ptr; + } fct; + int no_more; + enum nss_status status = NSS_STATUS_UNAVAIL; + struct etherent etherent; + + no_more = __nss_ethers_lookup2 (&nip, "getntohost_r", NULL, &fct.ptr); + + while (no_more == 0) + { + char buffer[1024]; + + status = (*fct.f) (addr, ðerent, buffer, sizeof buffer, &errno); + + no_more = __nss_next2 (&nip, "getntohost_r", NULL, &fct.ptr, status, 0); + } + + if (status == NSS_STATUS_SUCCESS) + /* XXX This is a potential cause of trouble because the size of + the HOSTNAME buffer is not known but the interface does not + provide this information. */ + strcpy (hostname, etherent.e_name); + + return status == NSS_STATUS_SUCCESS ? 0 : -1; +} |