re-format
This commit is contained in:
parent
634ac82d1c
commit
94f842e473
@ -47,7 +47,6 @@ static char copyright[] =
|
||||
#include <stropts.h>
|
||||
#include <unistd.h>
|
||||
|
||||
|
||||
/*
|
||||
* Local static values
|
||||
*/
|
||||
@ -60,7 +59,6 @@ static int Sd = -1; /* stream device descriptor; not open
|
||||
* if -1 */
|
||||
static char ErrMsg[GET_MIB2_ERRMSGL]; /* error message buffer */
|
||||
|
||||
|
||||
/*
|
||||
* close_mib2() - close MIB2 access
|
||||
*
|
||||
@ -72,32 +70,29 @@ static char ErrMsg[GET_MIB2_ERRMSGL]; /* error message buffer */
|
||||
*/
|
||||
|
||||
int
|
||||
close_mib2(
|
||||
char **errmsg /* error message buffer return
|
||||
* address */
|
||||
)
|
||||
close_mib2(char **errmsg)
|
||||
{
|
||||
*errmsg = ErrMsg;
|
||||
if (Sd < 0) {
|
||||
(void) strcpy(ErrMsg, "close_mib2: socket not open");
|
||||
return(GET_MIB2_ERR_NOTOPEN);
|
||||
}
|
||||
if (close(Sd)) {
|
||||
(void) sprintf(ErrMsg, "close_mib2: %s", strerror(errno));
|
||||
return(GET_MIB2_ERR_CLOSE);
|
||||
}
|
||||
Sd = -1;
|
||||
if (Dbl && Db) {
|
||||
Dbl = 0;
|
||||
free((void *)Db);
|
||||
Db = NULL;
|
||||
}
|
||||
if (Smbl && Smb) {
|
||||
Smbl = 0;
|
||||
free((void *)Smb);
|
||||
Smb = NULL;
|
||||
}
|
||||
return(GET_MIB2_OK);
|
||||
*errmsg = ErrMsg;
|
||||
if (Sd < 0) {
|
||||
(void) strcpy(ErrMsg, "close_mib2: socket not open");
|
||||
return(GET_MIB2_ERR_NOTOPEN);
|
||||
}
|
||||
if (close(Sd)) {
|
||||
(void) sprintf(ErrMsg, "close_mib2: %s", strerror(errno));
|
||||
return(GET_MIB2_ERR_CLOSE);
|
||||
}
|
||||
Sd = -1;
|
||||
if (Dbl && Db) {
|
||||
Dbl = 0;
|
||||
free((void *)Db);
|
||||
Db = NULL;
|
||||
}
|
||||
if (Smbl && Smb) {
|
||||
Smbl = 0;
|
||||
free((void *)Smb);
|
||||
Smb = NULL;
|
||||
}
|
||||
return(GET_MIB2_OK);
|
||||
}
|
||||
|
||||
|
||||
@ -115,160 +110,164 @@ close_mib2(
|
||||
*/
|
||||
|
||||
int
|
||||
get_mib2(
|
||||
struct opthdr **opt, /* opthdr struct pointer return
|
||||
* address */
|
||||
char **data, /* data buffer return address */
|
||||
int *datalen, /* data length return address */
|
||||
char **errmsg /* error message buffer return
|
||||
* address */
|
||||
)
|
||||
get_mib2(struct opthdr **opt,
|
||||
char **data,
|
||||
int *datalen,
|
||||
char **errmsg)
|
||||
{
|
||||
static struct T_optmgmt_ack *a; /* message ACK pointer */
|
||||
static struct strbuf c; /* streams control buffer */
|
||||
struct strbuf d; /* streams data buffer */
|
||||
static struct T_error_ack *e; /* message error pointer */
|
||||
int err; /* error code */
|
||||
int f; /* flags */
|
||||
static struct opthdr *o; /* message option pointer */
|
||||
static struct T_optmgmt_req *r; /* message request pointer */
|
||||
int rc; /* reply code */
|
||||
static struct T_optmgmt_ack *a; /* message ACK pointer */
|
||||
static struct strbuf c; /* streams control buffer */
|
||||
struct strbuf d; /* streams data buffer */
|
||||
static struct T_error_ack *e; /* message error pointer */
|
||||
int err; /* error code */
|
||||
int f; /* flags */
|
||||
static struct opthdr *o; /* message option pointer */
|
||||
static struct T_optmgmt_req *r; /* message request pointer */
|
||||
int rc; /* reply code */
|
||||
|
||||
*errmsg = ErrMsg;
|
||||
/*
|
||||
* If MIB2 access isn't open, open it and issue the preliminary stream
|
||||
* messages.
|
||||
*/
|
||||
if (Sd < 0) {
|
||||
*errmsg = ErrMsg;
|
||||
/*
|
||||
* If MIB2 access isn't open, open it and issue the preliminary stream
|
||||
* messages.
|
||||
*/
|
||||
if (Sd < 0) {
|
||||
|
||||
/*
|
||||
* Open access. Return on error.
|
||||
*/
|
||||
if ((err = open_mib2(errmsg)))
|
||||
return(err);
|
||||
if ((err = open_mib2(errmsg))) {
|
||||
return(err);
|
||||
}
|
||||
/*
|
||||
* Set up message request and option.
|
||||
*/
|
||||
r = (struct T_optmgmt_req *)Smb;
|
||||
o = (struct opthdr *)&Smb[sizeof(struct T_optmgmt_req)];
|
||||
r->PRIM_type = T_OPTMGMT_REQ;
|
||||
r->OPT_offset = sizeof(struct T_optmgmt_req);
|
||||
r->OPT_length = sizeof(struct opthdr);
|
||||
r = (struct T_optmgmt_req *)Smb;
|
||||
o = (struct opthdr *)&Smb[sizeof(struct T_optmgmt_req)];
|
||||
r->PRIM_type = T_OPTMGMT_REQ;
|
||||
r->OPT_offset = sizeof(struct T_optmgmt_req);
|
||||
r->OPT_length = sizeof(struct opthdr);
|
||||
|
||||
#if defined(MI_T_CURRENT)
|
||||
r->MGMT_flags = MI_T_CURRENT;
|
||||
r->MGMT_flags = MI_T_CURRENT;
|
||||
#else /* !defined(MI_T_CURRENT) */
|
||||
# if defined(T_CURRENT)
|
||||
r->MGMT_flags = T_CURRENT;
|
||||
r->MGMT_flags = T_CURRENT;
|
||||
# else /* !defined(T_CURRENT) */
|
||||
#error "Neither MI_T_CURRENT nor T_CURRENT are defined."
|
||||
# endif /* defined(T_CURRENT) */
|
||||
#endif /* defined(MI_T_CURRENT) */
|
||||
|
||||
o->level = MIB2_IP;
|
||||
o->name = o->len = 0;
|
||||
c.buf = Smb;
|
||||
c.len = r->OPT_offset + r->OPT_length;
|
||||
o->level = MIB2_IP;
|
||||
o->name = o->len = 0;
|
||||
c.buf = Smb;
|
||||
c.len = r->OPT_offset + r->OPT_length;
|
||||
/*
|
||||
* Put the message.
|
||||
*/
|
||||
if (putmsg(Sd, &c, (struct strbuf *)NULL, 0) == -1) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: putmsg request: %s", strerror(errno));
|
||||
return(GET_MIB2_ERR_PUTMSG);
|
||||
}
|
||||
if (putmsg(Sd, &c, (struct strbuf *)NULL, 0) == -1) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: putmsg request: %s", strerror(errno));
|
||||
return(GET_MIB2_ERR_PUTMSG);
|
||||
}
|
||||
/*
|
||||
* Set up to process replies.
|
||||
*/
|
||||
a = (struct T_optmgmt_ack *)Smb;
|
||||
c.maxlen = Smbl;
|
||||
e = (struct T_error_ack *)Smb;
|
||||
o = (struct opthdr *)&Smb[sizeof(struct T_optmgmt_ack)];
|
||||
}
|
||||
/*
|
||||
* Get the next (first) reply message.
|
||||
*/
|
||||
f = 0;
|
||||
if ((rc = getmsg(Sd, &c, NULL, &f)) < 0) {
|
||||
(void) sprintf(ErrMsg, "get_mib2: getmsg(reply): %s",
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGR);
|
||||
}
|
||||
/*
|
||||
* Check for end of data.
|
||||
*/
|
||||
if (rc == 0
|
||||
a = (struct T_optmgmt_ack *)Smb;
|
||||
c.maxlen = Smbl;
|
||||
e = (struct T_error_ack *)Smb;
|
||||
o = (struct opthdr *)&Smb[sizeof(struct T_optmgmt_ack)];
|
||||
}
|
||||
/*
|
||||
* Get the next (first) reply message.
|
||||
*/
|
||||
f = 0;
|
||||
if ((rc = getmsg(Sd, &c, NULL, &f)) < 0) {
|
||||
(void) sprintf(ErrMsg, "get_mib2: getmsg(reply): %s",
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGR);
|
||||
}
|
||||
/*
|
||||
* Check for end of data.
|
||||
*/
|
||||
if (rc == 0
|
||||
&& c.len >= sizeof(struct T_optmgmt_ack)
|
||||
&& a->PRIM_type == T_OPTMGMT_ACK
|
||||
&& a->MGMT_flags == T_SUCCESS
|
||||
&& o->len == 0) {
|
||||
err = close_mib2(errmsg);
|
||||
if (err)
|
||||
return(err);
|
||||
return(GET_MIB2_EOD);
|
||||
}
|
||||
/*
|
||||
* Check for error.
|
||||
*/
|
||||
if (c.len >= sizeof(struct T_error_ack)
|
||||
&& e->PRIM_type == T_ERROR_ACK) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: T_ERROR_ACK: len=%d, TLI=%#x, UNIX=%#x",
|
||||
c.len, (int)e->TLI_error, (int)e->UNIX_error);
|
||||
return(GET_MIB2_ERR_ACK);
|
||||
}
|
||||
/*
|
||||
* Check for no data.
|
||||
*/
|
||||
if (rc != MOREDATA
|
||||
&& o->len == 0)
|
||||
{
|
||||
err = close_mib2(errmsg);
|
||||
if (err) {
|
||||
return(err);
|
||||
}
|
||||
return(GET_MIB2_EOD);
|
||||
}
|
||||
/*
|
||||
* Check for error.
|
||||
*/
|
||||
if (c.len >= sizeof(struct T_error_ack)
|
||||
&& e->PRIM_type == T_ERROR_ACK)
|
||||
{
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: T_ERROR_ACK: len=%d, TLI=%#x, UNIX=%#x",
|
||||
c.len, (int)e->TLI_error, (int)e->UNIX_error);
|
||||
return(GET_MIB2_ERR_ACK);
|
||||
}
|
||||
/*
|
||||
* Check for no data.
|
||||
*/
|
||||
if (rc != MOREDATA
|
||||
|| c.len < sizeof(struct T_optmgmt_ack)
|
||||
|| a->PRIM_type != T_OPTMGMT_ACK
|
||||
|| a->MGMT_flags != T_SUCCESS) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: T_OPTMGMT_ACK: rc=%d len=%d type=%#x flags=%#x",
|
||||
rc, c.len, (int)a->PRIM_type, (int)a->MGMT_flags);
|
||||
return(GET_MIB2_ERR_NODATA);
|
||||
}
|
||||
/*
|
||||
* Allocate (or enlarge) the data buffer.
|
||||
*/
|
||||
if (o->len >= Dbl) {
|
||||
Dbl = o->len;
|
||||
if (Db == NULL)
|
||||
Db = (char *)malloc(Dbl);
|
||||
else
|
||||
Db = (char *)realloc(Db, Dbl);
|
||||
if (Db == NULL) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: no space for %d byte data buffer", Dbl);
|
||||
return(GET_MIB2_ERR_NOSPC);
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Get the data part of the message -- the MIB2 part.
|
||||
*/
|
||||
d.maxlen = o->len;
|
||||
d.buf = Db;
|
||||
d.len = 0;
|
||||
f = 0;
|
||||
if ((rc = getmsg(Sd, NULL, &d, &f)) < 0) {
|
||||
(void) sprintf(ErrMsg, "get_mib2: getmsg(data): %s",
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGD);
|
||||
}
|
||||
if (rc) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: getmsg(data): rc=%d maxlen=%d len=%d: %s",
|
||||
rc, d.maxlen, d.len, strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGD);
|
||||
}
|
||||
/*
|
||||
* Compose a successful return.
|
||||
*/
|
||||
*opt = o;
|
||||
*data = Db;
|
||||
*datalen = d.len;
|
||||
return(GET_MIB2_OK);
|
||||
|| a->MGMT_flags != T_SUCCESS)
|
||||
{
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: T_OPTMGMT_ACK: "
|
||||
"rc=%d len=%d type=%#x flags=%#x",
|
||||
rc, c.len, (int)a->PRIM_type, (int)a->MGMT_flags);
|
||||
return(GET_MIB2_ERR_NODATA);
|
||||
}
|
||||
/*
|
||||
* Allocate (or enlarge) the data buffer.
|
||||
*/
|
||||
if (o->len >= Dbl) {
|
||||
Dbl = o->len;
|
||||
if (Db == NULL) {
|
||||
Db = (char *)malloc(Dbl);
|
||||
}
|
||||
else {
|
||||
Db = (char *)realloc(Db, Dbl);
|
||||
}
|
||||
if (Db == NULL) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: no space for %d byte data buffer", Dbl);
|
||||
return(GET_MIB2_ERR_NOSPC);
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Get the data part of the message -- the MIB2 part.
|
||||
*/
|
||||
d.maxlen = o->len;
|
||||
d.buf = Db;
|
||||
d.len = 0;
|
||||
f = 0;
|
||||
if ((rc = getmsg(Sd, NULL, &d, &f)) < 0) {
|
||||
(void) sprintf(ErrMsg, "get_mib2: getmsg(data): %s",
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGD);
|
||||
}
|
||||
if (rc) {
|
||||
(void) sprintf(ErrMsg,
|
||||
"get_mib2: getmsg(data): rc=%d maxlen=%d len=%d: %s",
|
||||
rc, d.maxlen, d.len, strerror(errno));
|
||||
return(GET_MIB2_ERR_GETMSGD);
|
||||
}
|
||||
/*
|
||||
* Compose a successful return.
|
||||
*/
|
||||
*opt = o;
|
||||
*data = Db;
|
||||
*datalen = d.len;
|
||||
return(GET_MIB2_OK);
|
||||
}
|
||||
|
||||
|
||||
@ -283,52 +282,51 @@ get_mib2(
|
||||
*/
|
||||
|
||||
int
|
||||
open_mib2(
|
||||
char **errmsg /* error message buffer return
|
||||
* address */
|
||||
)
|
||||
open_mib2(char **errmsg)
|
||||
{
|
||||
*errmsg = ErrMsg;
|
||||
/*
|
||||
* It's an error if the stream device is already open.
|
||||
*/
|
||||
if (Sd >= 0) {
|
||||
(void) strcpy(ErrMsg, "open_mib2: MIB2 access already open");
|
||||
return(GET_MIB2_ERR_OPEN);
|
||||
}
|
||||
/*
|
||||
* Open the ARP stream device, push TCP and UDP on it.
|
||||
*/
|
||||
if ((Sd = open(GET_MIB2_ARPDEV, O_RDWR, 0600)) < 0) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: %s: %s", GET_MIB2_ARPDEV,
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_ARPOPEN);
|
||||
}
|
||||
if (ioctl(Sd, I_PUSH, GET_MIB2_TCPSTREAM) == -1) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: push %s: %s",
|
||||
GET_MIB2_TCPSTREAM, strerror(errno));
|
||||
return(GET_MIB2_ERR_TCPPUSH);
|
||||
}
|
||||
if (ioctl(Sd, I_PUSH, GET_MIB2_UDPSTREAM) == -1) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: push %s: %s",
|
||||
GET_MIB2_UDPSTREAM, strerror(errno));
|
||||
return(GET_MIB2_ERR_UDPPUSH);
|
||||
}
|
||||
/*
|
||||
* Allocate a stream message buffer.
|
||||
*/
|
||||
Smbl = sizeof(struct opthdr) + sizeof(struct T_optmgmt_req);
|
||||
if (Smbl < (sizeof (struct opthdr) + sizeof(struct T_optmgmt_ack)))
|
||||
Smbl = sizeof (struct opthdr) + sizeof(struct T_optmgmt_ack);
|
||||
if (Smbl < sizeof(struct T_error_ack))
|
||||
Smbl = sizeof(struct T_error_ack);
|
||||
if ((Smb = (char *)malloc(Smbl)) == NULL) {
|
||||
(void) strcpy(ErrMsg,
|
||||
"open_mib2: no space for stream message buffer");
|
||||
return(GET_MIB2_ERR_NOSPC);
|
||||
}
|
||||
/*
|
||||
* All is OK. Return that indication.
|
||||
*/
|
||||
return(GET_MIB2_OK);
|
||||
*errmsg = ErrMsg;
|
||||
/*
|
||||
* It's an error if the stream device is already open.
|
||||
*/
|
||||
if (Sd >= 0) {
|
||||
(void) strcpy(ErrMsg, "open_mib2: MIB2 access already open");
|
||||
return(GET_MIB2_ERR_OPEN);
|
||||
}
|
||||
/*
|
||||
* Open the ARP stream device, push TCP and UDP on it.
|
||||
*/
|
||||
if ((Sd = open(GET_MIB2_ARPDEV, O_RDWR, 0600)) < 0) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: %s: %s", GET_MIB2_ARPDEV,
|
||||
strerror(errno));
|
||||
return(GET_MIB2_ERR_ARPOPEN);
|
||||
}
|
||||
if (ioctl(Sd, I_PUSH, GET_MIB2_TCPSTREAM) == -1) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: push %s: %s",
|
||||
GET_MIB2_TCPSTREAM, strerror(errno));
|
||||
return(GET_MIB2_ERR_TCPPUSH);
|
||||
}
|
||||
if (ioctl(Sd, I_PUSH, GET_MIB2_UDPSTREAM) == -1) {
|
||||
(void) sprintf(ErrMsg, "open_mib2: push %s: %s",
|
||||
GET_MIB2_UDPSTREAM, strerror(errno));
|
||||
return(GET_MIB2_ERR_UDPPUSH);
|
||||
}
|
||||
/*
|
||||
* Allocate a stream message buffer.
|
||||
*/
|
||||
Smbl = sizeof(struct opthdr) + sizeof(struct T_optmgmt_req);
|
||||
if (Smbl < (sizeof (struct opthdr) + sizeof(struct T_optmgmt_ack))) {
|
||||
Smbl = sizeof (struct opthdr) + sizeof(struct T_optmgmt_ack);
|
||||
}
|
||||
if (Smbl < sizeof(struct T_error_ack)) {
|
||||
Smbl = sizeof(struct T_error_ack);
|
||||
}
|
||||
if ((Smb = (char *)malloc(Smbl)) == NULL) {
|
||||
(void) strcpy(ErrMsg,
|
||||
"open_mib2: no space for stream message buffer");
|
||||
return(GET_MIB2_ERR_NOSPC);
|
||||
}
|
||||
/*
|
||||
* All is OK. Return that indication.
|
||||
*/
|
||||
return(GET_MIB2_OK);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user