* nis/nss_nisplus/nisplus-ethers.c (struct etherent): Removed.
* inet/ether_hton.c: Likewise * inet/ether_ntoh.c: Likewise. * nis/nss_nis/nis-ethers.c (_nss_nis_getntohost_r): Fix declaration to match prototype. * include/netinet/ether.h (struct etherent): Declare here so that all implementations use the same struct. * nis/nss_nis/nis-ethers.c: Include netinet/ether.h to get prototypes. (struct ether): Removed. Use struct etherent instead of ether everywhere. * include/rpc/auth.h (DECLARE_NSS_PROTOTYPES): New. * include/rpc/auth_des.h (DECLARE_NSS_PROTOTYPES): New. * sunrpc/publickey.c: Include auth_des.h for prototypes.
This commit is contained in:
parent
e3bb40e6bf
commit
6b083d46e4
@ -1,7 +1,14 @@
|
||||
#ifndef _NETINET_ETHER_H
|
||||
#include <inet/netinet/ether.h>
|
||||
|
||||
struct etherent;
|
||||
/* Because the `ethers' lookup does not fit so well in the scheme we
|
||||
define a dummy struct here which helps us to use the available
|
||||
functions. */
|
||||
struct etherent
|
||||
{
|
||||
const char *e_name;
|
||||
struct ether_addr e_addr;
|
||||
};
|
||||
|
||||
#define DECLARE_NSS_PROTOTYPES(service) \
|
||||
extern enum nss_status _nss_ ## service ## _setetherent (void); \
|
||||
|
@ -1 +1,15 @@
|
||||
#ifndef _RPC_AUTH_H
|
||||
#include <sunrpc/rpc/auth.h>
|
||||
|
||||
#define DECLARE_NSS_PROTOTYPES(service) \
|
||||
extern enum nss_status _nss_ ##service ## _netname2user \
|
||||
(char netname[MAXNETNAMELEN + 1], uid_t *uidp, \
|
||||
gid_t *gidp, int *gidlenp, gid_t *gidlist, \
|
||||
int *errnop);
|
||||
|
||||
DECLARE_NSS_PROTOTYPES (nis)
|
||||
DECLARE_NSS_PROTOTYPES (nisplus)
|
||||
|
||||
#undef DECLARE_NSS_PROTOTYPES
|
||||
|
||||
#endif
|
||||
|
@ -1 +1,18 @@
|
||||
#ifndef _RPC_AUTH_DES_H
|
||||
|
||||
#include <sunrpc/rpc/auth_des.h>
|
||||
|
||||
#define DECLARE_NSS_PROTOTYPES(service) \
|
||||
extern enum nss_status _nss_ ## service ## _getpublickey \
|
||||
(const char *netname, char *pkey, int *errnop); \
|
||||
extern enum nss_status _nss_ ## service ## _getsecretkey \
|
||||
(const char *netname, char *skey, char *passwd, \
|
||||
int *errnop);
|
||||
|
||||
DECLARE_NSS_PROTOTYPES (files)
|
||||
DECLARE_NSS_PROTOTYPES (nis)
|
||||
DECLARE_NSS_PROTOTYPES (nisplus)
|
||||
|
||||
#undef DECLARE_NSS_PROTOTYPES
|
||||
|
||||
#endif
|
||||
|
@ -24,16 +24,6 @@
|
||||
|
||||
#include "../nss/nsswitch.h"
|
||||
|
||||
/* Because the `ethers' lookup does not fit so well in the scheme so
|
||||
we define a dummy struct here which helps us to use the available
|
||||
functions. */
|
||||
struct etherent
|
||||
{
|
||||
const char *e_name;
|
||||
struct ether_addr e_addr;
|
||||
};
|
||||
|
||||
|
||||
/* Type of the lookup function we need here. */
|
||||
typedef int (*lookup_function) (const char *, struct etherent *, char *, int,
|
||||
int *);
|
||||
|
@ -23,15 +23,6 @@
|
||||
|
||||
#include <nss/nsswitch.h>
|
||||
|
||||
/* Because the `ethers' lookup does not fit so well in the scheme so
|
||||
we define a dummy struct here which helps us to use the available
|
||||
functions. */
|
||||
struct etherent
|
||||
{
|
||||
const char *e_name;
|
||||
struct ether_addr e_addr;
|
||||
};
|
||||
|
||||
|
||||
/* Type of the lookup function we need here. */
|
||||
typedef int (*lookup_function) (const struct ether_addr *, struct etherent *,
|
||||
|
@ -24,6 +24,7 @@
|
||||
#include <bits/libc-lock.h>
|
||||
#include <rpcsvc/yp.h>
|
||||
#include <rpcsvc/ypclnt.h>
|
||||
#include <netinet/ether.h>
|
||||
#include <netinet/if_ether.h>
|
||||
|
||||
#include "nss-nis.h"
|
||||
@ -31,15 +32,9 @@
|
||||
/* Protect global state against multiple changers */
|
||||
__libc_lock_define_initialized (static, lock)
|
||||
|
||||
struct ether
|
||||
{
|
||||
const char *e_name;
|
||||
struct ether_addr e_addr;
|
||||
};
|
||||
|
||||
/* Get the declaration of the parser function. */
|
||||
#define ENTNAME etherent
|
||||
#define STRUCTURE ether
|
||||
#define STRUCTURE etherent
|
||||
#define EXTERN_PARSER
|
||||
#include <nss/nss_files/files-parse.c>
|
||||
|
||||
@ -149,7 +144,7 @@ _nss_nis_endetherent (void)
|
||||
}
|
||||
|
||||
static enum nss_status
|
||||
internal_nis_getetherent_r (struct ether *eth, char *buffer, size_t buflen,
|
||||
internal_nis_getetherent_r (struct etherent *eth, char *buffer, size_t buflen,
|
||||
int *errnop)
|
||||
{
|
||||
struct parser_data *data = (void *) buffer;
|
||||
@ -184,7 +179,7 @@ internal_nis_getetherent_r (struct ether *eth, char *buffer, size_t buflen,
|
||||
}
|
||||
|
||||
enum nss_status
|
||||
_nss_nis_getetherent_r (struct ether *result, char *buffer, size_t buflen,
|
||||
_nss_nis_getetherent_r (struct etherent *result, char *buffer, size_t buflen,
|
||||
int *errnop)
|
||||
{
|
||||
int status;
|
||||
@ -199,7 +194,7 @@ _nss_nis_getetherent_r (struct ether *result, char *buffer, size_t buflen,
|
||||
}
|
||||
|
||||
enum nss_status
|
||||
_nss_nis_gethostton_r (const char *name, struct ether *eth,
|
||||
_nss_nis_gethostton_r (const char *name, struct etherent *eth,
|
||||
char *buffer, size_t buflen, int *errnop)
|
||||
{
|
||||
struct parser_data *data = (void *) buffer;
|
||||
@ -256,7 +251,7 @@ _nss_nis_gethostton_r (const char *name, struct ether *eth,
|
||||
}
|
||||
|
||||
enum nss_status
|
||||
_nss_nis_getntohost_r (struct ether_addr *addr, struct ether *eth,
|
||||
_nss_nis_getntohost_r (const struct ether_addr *addr, struct etherent *eth,
|
||||
char *buffer, size_t buflen, int *errnop)
|
||||
{
|
||||
struct parser_data *data = (void *) buffer;
|
||||
|
@ -35,15 +35,6 @@ static nis_result *result = NULL;
|
||||
static nis_name tablename_val = NULL;
|
||||
static u_long tablename_len = 0;
|
||||
|
||||
/* Because the `ethers' lookup does not fit so well in the scheme so
|
||||
we define a dummy struct here which helps us to use the available
|
||||
functions. */
|
||||
struct etherent
|
||||
{
|
||||
const char *e_name;
|
||||
struct ether_addr e_addr;
|
||||
};
|
||||
struct etherent_data {};
|
||||
|
||||
#define NISENTRYVAL(idx,col,res) \
|
||||
((res)->objects.objects_val[(idx)].zo_data.objdata_u.en_data.en_cols.en_cols_val[(col)].ec_value.ec_value_val)
|
||||
@ -53,7 +44,7 @@ struct etherent_data {};
|
||||
|
||||
static int
|
||||
_nss_nisplus_parse_etherent (nis_result *result, struct etherent *ether,
|
||||
char *buffer, size_t buflen, int *errnop)
|
||||
char *buffer, size_t buflen, int *errnop)
|
||||
{
|
||||
char *p = buffer;
|
||||
size_t room_left = buflen;
|
||||
|
@ -20,6 +20,7 @@
|
||||
|
||||
#include <errno.h>
|
||||
#include <rpc/netdb.h>
|
||||
#include <rpc/auth_des.h>
|
||||
|
||||
#include "nsswitch.h"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user