Skip to content

Commit

Permalink
* nis/nss_nisplus/nisplus-ethers.c (struct etherent): Removed.
Browse files Browse the repository at this point in the history
* 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.
  • Loading branch information
ajaeger committed Dec 21, 2000
1 parent e3bb40e commit 6b083d4
Show file tree
Hide file tree
Showing 8 changed files with 47 additions and 41 deletions.
9 changes: 8 additions & 1 deletion include/netinet/ether.h
Original file line number Diff line number Diff line change
@@ -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); \
Expand Down
14 changes: 14 additions & 0 deletions include/rpc/auth.h
Original file line number Diff line number Diff line change
@@ -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
17 changes: 17 additions & 0 deletions include/rpc/auth_des.h
Original file line number Diff line number Diff line change
@@ -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
10 changes: 0 additions & 10 deletions inet/ether_hton.c
Original file line number Diff line number Diff line change
Expand Up @@ -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 *);
Expand Down
9 changes: 0 additions & 9 deletions inet/ether_ntoh.c
Original file line number Diff line number Diff line change
Expand Up @@ -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 *,
Expand Down
17 changes: 6 additions & 11 deletions nis/nss_nis/nis-ethers.c
Original file line number Diff line number Diff line change
Expand Up @@ -24,22 +24,17 @@
#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"

/* 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>

Expand Down Expand Up @@ -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;
Expand Down Expand Up @@ -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;
Expand All @@ -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;
Expand Down Expand Up @@ -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;
Expand Down
11 changes: 1 addition & 10 deletions nis/nss_nisplus/nisplus-ethers.c
Original file line number Diff line number Diff line change
Expand Up @@ -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)
Expand All @@ -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;
Expand Down
1 change: 1 addition & 0 deletions sunrpc/publickey.c
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@

#include <errno.h>
#include <rpc/netdb.h>
#include <rpc/auth_des.h>

#include "nsswitch.h"

Expand Down

0 comments on commit 6b083d4

Please sign in to comment.