Make ppp WARNS=5 clean
This commit is contained in:
parent
3f61368f03
commit
057f1760a8
@ -8,6 +8,7 @@ SRCS= acf.c arp.c async.c auth.c bundle.c cbcp.c ccp.c chap.c chat.c \
|
||||
mbuf.c mp.c ncp.c ncpaddr.c pap.c physical.c pred.c probe.c prompt.c \
|
||||
proto.c route.c server.c sig.c slcompress.c sync.c systems.c tcp.c \
|
||||
tcpmss.c throughput.c timer.c tty.c tun.c udp.c vjcomp.c
|
||||
WARNS?= 5
|
||||
.if defined(RELEASE_CRUNCH)
|
||||
CFLAGS+=-DRELEASE_CRUNCH
|
||||
NOATM= true
|
||||
|
@ -56,8 +56,8 @@ acf_WrapperOctets(struct lcp *lcp, u_short proto)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
acf_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
acf_LayerPush(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
const u_char cp[2] = { HDLC_ADDR, HDLC_UI };
|
||||
|
||||
@ -70,7 +70,8 @@ acf_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
acf_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp, u_short *proto)
|
||||
acf_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto __unused)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
u_char cp[2];
|
||||
|
@ -97,7 +97,7 @@ static struct {
|
||||
} arpmsg;
|
||||
|
||||
static int
|
||||
arp_ProxySub(struct bundle *bundle, struct in_addr addr, int add, int s)
|
||||
arp_ProxySub(struct bundle *bundle, struct in_addr addr, int add)
|
||||
{
|
||||
int routes;
|
||||
|
||||
@ -107,7 +107,7 @@ arp_ProxySub(struct bundle *bundle, struct in_addr addr, int add, int s)
|
||||
*/
|
||||
|
||||
memset(&arpmsg, 0, sizeof arpmsg);
|
||||
if (!arp_EtherAddr(s, addr, &arpmsg.hwa, 0)) {
|
||||
if (!arp_EtherAddr(addr, &arpmsg.hwa, 0)) {
|
||||
log_Printf(LogWARN, "%s: Cannot determine ethernet address for proxy ARP\n",
|
||||
inet_ntoa(addr));
|
||||
return 0;
|
||||
@ -145,18 +145,18 @@ arp_ProxySub(struct bundle *bundle, struct in_addr addr, int add, int s)
|
||||
}
|
||||
|
||||
int
|
||||
arp_SetProxy(struct bundle *bundle, struct in_addr addr, int s)
|
||||
arp_SetProxy(struct bundle *bundle, struct in_addr addr)
|
||||
{
|
||||
return (arp_ProxySub(bundle, addr, 1, s));
|
||||
return (arp_ProxySub(bundle, addr, 1));
|
||||
}
|
||||
|
||||
/*
|
||||
* arp_ClearProxy - Delete the proxy ARP entry for the peer.
|
||||
*/
|
||||
int
|
||||
arp_ClearProxy(struct bundle *bundle, struct in_addr addr, int s)
|
||||
arp_ClearProxy(struct bundle *bundle, struct in_addr addr)
|
||||
{
|
||||
return (arp_ProxySub(bundle, addr, 0, s));
|
||||
return (arp_ProxySub(bundle, addr, 0));
|
||||
}
|
||||
|
||||
#else /* RTM_VERSION */
|
||||
@ -179,7 +179,7 @@ arp_SetProxy(struct bundle *bundle, struct in_addr addr, int s)
|
||||
* Get the hardware address of an interface on the same subnet as our local
|
||||
* address.
|
||||
*/
|
||||
if (!arp_EtherAddr(s, addr, &dls.sdl, 1)) {
|
||||
if (!arp_EtherAddr(addr, &dls.sdl, 1)) {
|
||||
log_Printf(LOG_PHASE_BIT, "Cannot determine ethernet address for "
|
||||
"proxy ARP\n");
|
||||
return 0;
|
||||
@ -226,7 +226,7 @@ arp_ClearProxy(struct bundle *bundle, struct in_addr addr, int s)
|
||||
*/
|
||||
|
||||
int
|
||||
arp_EtherAddr(int s, struct in_addr ipaddr, struct sockaddr_dl *hwaddr,
|
||||
arp_EtherAddr(struct in_addr ipaddr, struct sockaddr_dl *hwaddr,
|
||||
int verbose)
|
||||
{
|
||||
int mib[6], skip;
|
||||
|
@ -31,6 +31,6 @@
|
||||
struct sockaddr_dl;
|
||||
struct bundle;
|
||||
|
||||
extern int arp_ClearProxy(struct bundle *, struct in_addr, int);
|
||||
extern int arp_SetProxy(struct bundle *, struct in_addr, int);
|
||||
extern int arp_EtherAddr(int, struct in_addr, struct sockaddr_dl *, int);
|
||||
extern int arp_ClearProxy(struct bundle *, struct in_addr);
|
||||
extern int arp_SetProxy(struct bundle *, struct in_addr);
|
||||
extern int arp_EtherAddr(struct in_addr, struct sockaddr_dl *, int);
|
||||
|
@ -100,14 +100,14 @@ async_Encode(struct async *async, u_char **cp, u_char c, int proto)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
async_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
async_LayerPush(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
u_char *cp, *sp, *ep;
|
||||
struct mbuf *wp;
|
||||
size_t oldcnt;
|
||||
int cnt;
|
||||
size_t cnt;
|
||||
|
||||
if (!p || m_length(bp) > HDLCSIZE) {
|
||||
m_freem(bp);
|
||||
@ -187,8 +187,8 @@ async_Decode(struct async *async, u_char c)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
async_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
async_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto __unused)
|
||||
{
|
||||
struct mbuf *nbp, **last;
|
||||
struct physical *p = link2physical(l);
|
||||
|
@ -68,7 +68,7 @@ struct atmdevice {
|
||||
|
||||
#define device2atm(d) ((d)->type == ATM_DEVICE ? (struct atmdevice *)d : NULL)
|
||||
|
||||
int
|
||||
unsigned
|
||||
atm_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct atmdevice);
|
||||
@ -106,7 +106,7 @@ atm_Free(struct physical *p)
|
||||
|
||||
static void
|
||||
atm_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
int sz = physical_MaxDeviceSize();
|
||||
|
||||
@ -142,7 +142,7 @@ static const struct device baseatmdevice = {
|
||||
|
||||
struct device *
|
||||
atm_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
if (type == ATM_DEVICE) {
|
||||
struct atmdevice *dev = (struct atmdevice *)iov[(*niov)++].iov_base;
|
||||
|
@ -32,4 +32,4 @@ struct device;
|
||||
extern struct device *atm_Create(struct physical *);
|
||||
extern struct device *atm_iov2device(int, struct physical *,
|
||||
struct iovec *, int *, int, int *, int *);
|
||||
extern int atm_DeviceSize(void);
|
||||
extern unsigned atm_DeviceSize(void);
|
||||
|
@ -285,8 +285,7 @@ again:
|
||||
}
|
||||
|
||||
int
|
||||
auth_Validate(struct bundle *bundle, const char *name,
|
||||
const char *key, struct physical *physical)
|
||||
auth_Validate(struct bundle *bundle, const char *name, const char *key)
|
||||
{
|
||||
/* Used by PAP routines */
|
||||
|
||||
@ -337,8 +336,7 @@ again:
|
||||
}
|
||||
|
||||
char *
|
||||
auth_GetSecret(struct bundle *bundle, const char *name, int len,
|
||||
struct physical *physical)
|
||||
auth_GetSecret(const char *name, size_t len)
|
||||
{
|
||||
/* Used by CHAP routines */
|
||||
|
||||
@ -437,7 +435,7 @@ auth_StopTimer(struct authinfo *authp)
|
||||
struct mbuf *
|
||||
auth_ReadHeader(struct authinfo *authp, struct mbuf *bp)
|
||||
{
|
||||
int len;
|
||||
size_t len;
|
||||
|
||||
len = m_length(bp);
|
||||
if (len >= sizeof authp->in.hdr) {
|
||||
@ -445,11 +443,11 @@ auth_ReadHeader(struct authinfo *authp, struct mbuf *bp)
|
||||
if (len >= ntohs(authp->in.hdr.length))
|
||||
return bp;
|
||||
authp->in.hdr.length = htons(0);
|
||||
log_Printf(LogWARN, "auth_ReadHeader: Short packet (%d > %d) !\n",
|
||||
log_Printf(LogWARN, "auth_ReadHeader: Short packet (%u > %u) !\n",
|
||||
ntohs(authp->in.hdr.length), len);
|
||||
} else {
|
||||
authp->in.hdr.length = htons(0);
|
||||
log_Printf(LogWARN, "auth_ReadHeader: Short packet header (%d > %d) !\n",
|
||||
log_Printf(LogWARN, "auth_ReadHeader: Short packet header (%u > %u) !\n",
|
||||
(int)(sizeof authp->in.hdr), len);
|
||||
}
|
||||
|
||||
@ -458,15 +456,15 @@ auth_ReadHeader(struct authinfo *authp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
struct mbuf *
|
||||
auth_ReadName(struct authinfo *authp, struct mbuf *bp, int len)
|
||||
auth_ReadName(struct authinfo *authp, struct mbuf *bp, size_t len)
|
||||
{
|
||||
if (len > sizeof authp->in.name - 1)
|
||||
log_Printf(LogWARN, "auth_ReadName: Name too long (%d) !\n", len);
|
||||
log_Printf(LogWARN, "auth_ReadName: Name too long (%u) !\n", len);
|
||||
else {
|
||||
int mlen = m_length(bp);
|
||||
size_t mlen = m_length(bp);
|
||||
|
||||
if (len > mlen)
|
||||
log_Printf(LogWARN, "auth_ReadName: Short packet (%d > %d) !\n",
|
||||
log_Printf(LogWARN, "auth_ReadName: Short packet (%u > %u) !\n",
|
||||
len, mlen);
|
||||
else {
|
||||
bp = mbuf_Read(bp, (u_char *)authp->in.name, len);
|
||||
|
@ -60,11 +60,9 @@ extern void auth_Init(struct authinfo *, struct physical *,
|
||||
auth_func, auth_func, auth_func);
|
||||
extern void auth_StopTimer(struct authinfo *);
|
||||
extern void auth_StartReq(struct authinfo *);
|
||||
extern int auth_Validate(struct bundle *, const char *, const char *,
|
||||
struct physical *);
|
||||
extern char *auth_GetSecret(struct bundle *, const char *, int,
|
||||
struct physical *);
|
||||
extern int auth_Validate(struct bundle *, const char *, const char *);
|
||||
extern char *auth_GetSecret(const char *, size_t);
|
||||
extern int auth_SetPhoneList(const char *, char *, int);
|
||||
extern int auth_Select(struct bundle *, const char *);
|
||||
extern struct mbuf *auth_ReadHeader(struct authinfo *, struct mbuf *);
|
||||
extern struct mbuf *auth_ReadName(struct authinfo *, struct mbuf *, int);
|
||||
extern struct mbuf *auth_ReadName(struct authinfo *, struct mbuf *, size_t);
|
||||
|
@ -164,7 +164,7 @@ bundle_NewPhase(struct bundle *bundle, u_int new)
|
||||
}
|
||||
|
||||
static void
|
||||
bundle_LayerStart(void *v, struct fsm *fp)
|
||||
bundle_LayerStart(void *v __unused, struct fsm *fp __unused)
|
||||
{
|
||||
/* The given FSM is about to start up ! */
|
||||
}
|
||||
@ -529,7 +529,7 @@ bundle_IsSet(struct fdescriptor *d, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static void
|
||||
bundle_DescriptorRead(struct fdescriptor *d, struct bundle *bundle,
|
||||
bundle_DescriptorRead(struct fdescriptor *d __unused, struct bundle *bundle,
|
||||
const fd_set *fdset)
|
||||
{
|
||||
struct datalink *dl;
|
||||
@ -641,7 +641,7 @@ bundle_DescriptorRead(struct fdescriptor *d, struct bundle *bundle,
|
||||
}
|
||||
|
||||
static int
|
||||
bundle_DescriptorWrite(struct fdescriptor *d, struct bundle *bundle,
|
||||
bundle_DescriptorWrite(struct fdescriptor *d __unused, struct bundle *bundle,
|
||||
const fd_set *fdset)
|
||||
{
|
||||
struct datalink *dl;
|
||||
@ -1092,7 +1092,7 @@ bundle_ShowStatus(struct cmdargs const *arg)
|
||||
else
|
||||
prompt_Printf(arg->prompt, "none\n");
|
||||
|
||||
prompt_Printf(arg->prompt, " Choked Timer: %ds\n",
|
||||
prompt_Printf(arg->prompt, " Choked Timer: %us\n",
|
||||
arg->bundle->cfg.choked.timeout);
|
||||
|
||||
#ifndef NORADIUS
|
||||
@ -1101,9 +1101,9 @@ bundle_ShowStatus(struct cmdargs const *arg)
|
||||
|
||||
prompt_Printf(arg->prompt, " Idle Timer: ");
|
||||
if (arg->bundle->cfg.idle.timeout) {
|
||||
prompt_Printf(arg->prompt, "%ds", arg->bundle->cfg.idle.timeout);
|
||||
prompt_Printf(arg->prompt, "%us", arg->bundle->cfg.idle.timeout);
|
||||
if (arg->bundle->cfg.idle.min_timeout)
|
||||
prompt_Printf(arg->prompt, ", min %ds",
|
||||
prompt_Printf(arg->prompt, ", min %us",
|
||||
arg->bundle->cfg.idle.min_timeout);
|
||||
remaining = bundle_RemainingIdleTime(arg->bundle);
|
||||
if (remaining != -1)
|
||||
@ -1173,9 +1173,10 @@ bundle_StartIdleTimer(struct bundle *bundle, unsigned secs)
|
||||
|
||||
/* We want at least `secs' */
|
||||
if (bundle->cfg.idle.min_timeout > secs && bundle->upat) {
|
||||
int up = now - bundle->upat;
|
||||
unsigned up = now - bundle->upat;
|
||||
|
||||
if ((long long)bundle->cfg.idle.min_timeout - up > (long long)secs)
|
||||
if (bundle->cfg.idle.min_timeout > up &&
|
||||
bundle->cfg.idle.min_timeout - up > (long long)secs)
|
||||
/* Only increase from the current `remaining' value */
|
||||
secs = bundle->cfg.idle.min_timeout - up;
|
||||
}
|
||||
@ -1189,11 +1190,11 @@ bundle_StartIdleTimer(struct bundle *bundle, unsigned secs)
|
||||
}
|
||||
|
||||
void
|
||||
bundle_SetIdleTimer(struct bundle *bundle, int timeout, int min_timeout)
|
||||
bundle_SetIdleTimer(struct bundle *bundle, unsigned timeout,
|
||||
unsigned min_timeout)
|
||||
{
|
||||
bundle->cfg.idle.timeout = timeout;
|
||||
if (min_timeout >= 0)
|
||||
bundle->cfg.idle.min_timeout = min_timeout;
|
||||
bundle->cfg.idle.min_timeout = min_timeout;
|
||||
if (ncp_LayersOpen(&bundle->ncp))
|
||||
bundle_StartIdleTimer(bundle, 0);
|
||||
}
|
||||
@ -1370,7 +1371,8 @@ void
|
||||
bundle_ReceiveDatalink(struct bundle *bundle, int s)
|
||||
{
|
||||
char cmsgbuf[sizeof(struct cmsghdr) + sizeof(int) * SEND_MAXFD];
|
||||
int niov, expect, f, *fd, nfd, onfd, got;
|
||||
int niov, expect, f, *fd, nfd, onfd;
|
||||
ssize_t got;
|
||||
struct iovec iov[SCATTER_SEGMENTS];
|
||||
struct cmsghdr *cmsg;
|
||||
struct msghdr msg;
|
||||
@ -1419,7 +1421,7 @@ bundle_ReceiveDatalink(struct bundle *bundle, int s)
|
||||
log_Printf(LogDEBUG, "Expecting %u scatter/gather bytes\n",
|
||||
(unsigned)iov[0].iov_len);
|
||||
|
||||
if ((got = recvmsg(s, &msg, MSG_WAITALL)) != iov[0].iov_len) {
|
||||
if ((got = recvmsg(s, &msg, MSG_WAITALL)) != (ssize_t)iov[0].iov_len) {
|
||||
if (got == -1)
|
||||
log_Printf(LogERROR, "Failed recvmsg: %s\n", strerror(errno));
|
||||
else
|
||||
@ -1536,7 +1538,8 @@ bundle_SendDatalink(struct datalink *dl, int s, struct sockaddr_un *sun)
|
||||
struct cmsghdr *cmsg;
|
||||
struct msghdr msg;
|
||||
struct iovec iov[SCATTER_SEGMENTS];
|
||||
int niov, f, expect, newsid, fd[SEND_MAXFD], nfd, reply[2], got;
|
||||
int niov, f, expect, newsid, fd[SEND_MAXFD], nfd, reply[2];
|
||||
ssize_t got;
|
||||
pid_t newpid;
|
||||
|
||||
log_Printf(LogPHASE, "Transmitting datalink %s\n", dl->name);
|
||||
@ -1608,7 +1611,7 @@ bundle_SendDatalink(struct datalink *dl, int s, struct sockaddr_un *sun)
|
||||
if ((got = sendmsg(s, &msg, 0)) == -1)
|
||||
log_Printf(LogERROR, "Failed sendmsg: %s: %s\n",
|
||||
sun->sun_path, strerror(errno));
|
||||
else if (got != iov[0].iov_len)
|
||||
else if (got != (ssize_t)iov[0].iov_len)
|
||||
log_Printf(LogERROR, "%s: Failed initial sendmsg: Only sent %d of %u\n",
|
||||
sun->sun_path, got, (unsigned)iov[0].iov_len);
|
||||
else {
|
||||
@ -1819,11 +1822,11 @@ bundle_setsid(struct bundle *bundle, int holdsession)
|
||||
}
|
||||
}
|
||||
|
||||
int
|
||||
unsigned
|
||||
bundle_HighestState(struct bundle *bundle)
|
||||
{
|
||||
struct datalink *dl;
|
||||
int result = DATALINK_CLOSED;
|
||||
unsigned result = DATALINK_CLOSED;
|
||||
|
||||
for (dl = bundle->links; dl; dl = dl->next)
|
||||
if (result < dl->state)
|
||||
@ -1916,7 +1919,7 @@ bundle_CalculateBandwidth(struct bundle *bundle)
|
||||
#endif
|
||||
|
||||
if (maxoverhead) {
|
||||
log_Printf(LogLCP, "Reducing MTU from %d to %d (CCP requirement)\n",
|
||||
log_Printf(LogLCP, "Reducing MTU from %lu to %lu (CCP requirement)\n",
|
||||
bundle->iface->mtu, bundle->iface->mtu - maxoverhead);
|
||||
bundle->iface->mtu -= maxoverhead;
|
||||
}
|
||||
|
@ -98,8 +98,8 @@ struct bundle {
|
||||
|
||||
struct {
|
||||
struct {
|
||||
int timeout; /* NCP Idle timeout value */
|
||||
int min_timeout; /* Don't idle out before this */
|
||||
unsigned timeout; /* NCP Idle timeout value */
|
||||
unsigned min_timeout; /* Don't idle out before this */
|
||||
} idle;
|
||||
struct {
|
||||
char name[AUTHLEN]; /* PAP/CHAP system name */
|
||||
@ -110,7 +110,7 @@ struct bundle {
|
||||
u_short ifqueue; /* Interface queue size */
|
||||
|
||||
struct {
|
||||
int timeout; /* How long to leave the output queue choked */
|
||||
unsigned timeout; /* How long to leave the output queue choked */
|
||||
} choked;
|
||||
} cfg;
|
||||
|
||||
@ -169,7 +169,7 @@ extern void bundle_LinkClosed(struct bundle *, struct datalink *);
|
||||
extern int bundle_ShowLinks(struct cmdargs const *);
|
||||
extern int bundle_ShowStatus(struct cmdargs const *);
|
||||
extern void bundle_StartIdleTimer(struct bundle *, unsigned secs);
|
||||
extern void bundle_SetIdleTimer(struct bundle *, int, int);
|
||||
extern void bundle_SetIdleTimer(struct bundle *, unsigned, unsigned);
|
||||
extern void bundle_StopIdleTimer(struct bundle *);
|
||||
extern int bundle_IsDead(struct bundle *);
|
||||
extern struct datalink *bundle2datalink(struct bundle *, const char *);
|
||||
@ -198,7 +198,7 @@ extern int bundle_RenameDatalink(struct bundle *, struct datalink *,
|
||||
const char *);
|
||||
extern void bundle_setsid(struct bundle *, int);
|
||||
extern void bundle_LockTun(struct bundle *);
|
||||
extern int bundle_HighestState(struct bundle *);
|
||||
extern unsigned bundle_HighestState(struct bundle *);
|
||||
extern int bundle_Exception(struct bundle *, int);
|
||||
extern void bundle_AdjustFilters(struct bundle *, struct ncpaddr *,
|
||||
struct ncpaddr *);
|
||||
|
@ -150,7 +150,7 @@ static const char * const cbcpname[] = {
|
||||
};
|
||||
|
||||
static const char *
|
||||
cbcpstate(int s)
|
||||
cbcpstate(unsigned s)
|
||||
{
|
||||
if (s < sizeof cbcpname / sizeof cbcpname[0])
|
||||
return cbcpname[s];
|
||||
@ -210,7 +210,7 @@ cbcp_Output(struct cbcp *cbcp, u_char code, struct cbcp_data *data)
|
||||
}
|
||||
|
||||
static const char *
|
||||
cbcp_data_Type(int type)
|
||||
cbcp_data_Type(unsigned type)
|
||||
{
|
||||
static const char * const types[] = {
|
||||
"No callback", "User-spec", "Server-spec", "list"
|
||||
@ -615,13 +615,13 @@ cbcp_SendAck(struct cbcp *cbcp)
|
||||
}
|
||||
|
||||
extern struct mbuf *
|
||||
cbcp_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
cbcp_Input(struct bundle *bundle __unused, struct link *l, struct mbuf *bp)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
struct cbcp_header *head;
|
||||
struct cbcp_data *data;
|
||||
struct cbcp *cbcp = &p->dl->cbcp;
|
||||
int len;
|
||||
size_t len;
|
||||
|
||||
if (p == NULL) {
|
||||
log_Printf(LogERROR, "cbcp_Input: Not a physical link - dropped\n");
|
||||
@ -637,7 +637,7 @@ cbcp_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
}
|
||||
head = (struct cbcp_header *)MBUF_CTOP(bp);
|
||||
if (ntohs(head->length) != len) {
|
||||
log_Printf(LogWARN, "Corrupt CBCP packet (code %d, length %d not %d)"
|
||||
log_Printf(LogWARN, "Corrupt CBCP packet (code %d, length %u not %u)"
|
||||
" - ignored\n", head->code, ntohs(head->length), len);
|
||||
m_freem(bp);
|
||||
return NULL;
|
||||
|
@ -133,7 +133,7 @@ protoname(int proto)
|
||||
"DEFLATE", /* 26: Deflate (rfc1979) */
|
||||
};
|
||||
|
||||
if (proto < 0 || proto > sizeof cftypes / sizeof *cftypes ||
|
||||
if (proto < 0 || (unsigned)proto > sizeof cftypes / sizeof *cftypes ||
|
||||
cftypes[proto] == NULL) {
|
||||
if (proto == -1)
|
||||
return "none";
|
||||
@ -297,7 +297,7 @@ ccp_Setup(struct ccp *ccp)
|
||||
int
|
||||
ccp_Required(struct ccp *ccp)
|
||||
{
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < NALGORITHMS; f++)
|
||||
if (IsEnabled(ccp->cfg.neg[algorithm[f]->Neg]) &&
|
||||
@ -347,7 +347,8 @@ CcpSendConfigReq(struct fsm *fp)
|
||||
struct ccp *ccp = fsm2ccp(fp);
|
||||
struct ccp_opt **o;
|
||||
u_char *cp, buff[100];
|
||||
int f, alloc;
|
||||
unsigned f;
|
||||
int alloc;
|
||||
|
||||
cp = buff;
|
||||
o = &ccp->out.opt;
|
||||
@ -361,7 +362,7 @@ CcpSendConfigReq(struct fsm *fp)
|
||||
|
||||
if (!alloc)
|
||||
for (o = &ccp->out.opt; *o != NULL; o = &(*o)->next)
|
||||
if ((*o)->val.hdr.id == algorithm[f]->id && (*o)->algorithm == f)
|
||||
if ((*o)->val.hdr.id == algorithm[f]->id && (*o)->algorithm == (int)f)
|
||||
break;
|
||||
|
||||
if (alloc || *o == NULL) {
|
||||
@ -402,7 +403,7 @@ ccp_SendResetReq(struct fsm *fp)
|
||||
}
|
||||
|
||||
static void
|
||||
CcpSentTerminateReq(struct fsm *fp)
|
||||
CcpSentTerminateReq(struct fsm *fp __unused)
|
||||
{
|
||||
/* Term REQ just sent by FSM */
|
||||
}
|
||||
@ -495,12 +496,12 @@ CcpLayerUp(struct fsm *fp)
|
||||
/* We're now up */
|
||||
struct ccp *ccp = fsm2ccp(fp);
|
||||
struct ccp_opt **o;
|
||||
int f, fail;
|
||||
unsigned f, fail;
|
||||
|
||||
for (f = fail = 0; f < NALGORITHMS; f++)
|
||||
if (IsEnabled(ccp->cfg.neg[algorithm[f]->Neg]) &&
|
||||
(*algorithm[f]->Required)(&ccp->fsm) &&
|
||||
(ccp->in.algorithm != f || ccp->out.algorithm != f)) {
|
||||
(ccp->in.algorithm != (int)f || ccp->out.algorithm != (int)f)) {
|
||||
/* Blow it all away - we haven't negotiated a required algorithm */
|
||||
log_Printf(LogWARN, "%s: Failed to negotiate (required) %s\n",
|
||||
fp->link->name, protoname(algorithm[f]->id));
|
||||
@ -517,7 +518,7 @@ CcpLayerUp(struct fsm *fp)
|
||||
log_Printf(LogCCP, "%s: LayerUp.\n", fp->link->name);
|
||||
|
||||
if (ccp->in.state == NULL && ccp->in.algorithm >= 0 &&
|
||||
ccp->in.algorithm < NALGORITHMS) {
|
||||
ccp->in.algorithm < (int)NALGORITHMS) {
|
||||
ccp->in.state = (*algorithm[ccp->in.algorithm]->i.Init)
|
||||
(fp->bundle, &ccp->in.opt);
|
||||
if (ccp->in.state == NULL) {
|
||||
@ -530,12 +531,13 @@ CcpLayerUp(struct fsm *fp)
|
||||
}
|
||||
|
||||
o = &ccp->out.opt;
|
||||
for (f = 0; f < ccp->out.algorithm; f++)
|
||||
if (IsEnabled(ccp->cfg.neg[algorithm[f]->Neg]))
|
||||
o = &(*o)->next;
|
||||
if (ccp->out.algorithm > 0)
|
||||
for (f = 0; f < (unsigned)ccp->out.algorithm; f++)
|
||||
if (IsEnabled(ccp->cfg.neg[algorithm[f]->Neg]))
|
||||
o = &(*o)->next;
|
||||
|
||||
if (ccp->out.state == NULL && ccp->out.algorithm >= 0 &&
|
||||
ccp->out.algorithm < NALGORITHMS) {
|
||||
ccp->out.algorithm < (int)NALGORITHMS) {
|
||||
ccp->out.state = (*algorithm[ccp->out.algorithm]->o.Init)
|
||||
(fp->bundle, &(*o)->val);
|
||||
if (ccp->out.state == NULL) {
|
||||
@ -569,7 +571,7 @@ CcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
if (mode_type == MODE_REQ)
|
||||
ccp->in.algorithm = -1; /* In case we've received two REQs in a row */
|
||||
|
||||
while (end - cp >= sizeof(opt->hdr)) {
|
||||
while (end >= cp + sizeof(opt->hdr)) {
|
||||
if ((opt = fsm_readopt(&cp)) == NULL)
|
||||
break;
|
||||
|
||||
@ -609,7 +611,7 @@ CcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
case MODE_ACK:
|
||||
fsm_ack(dec, &ccp->in.opt);
|
||||
ccp->his_proto = opt->hdr.id;
|
||||
ccp->in.algorithm = f; /* This one'll do :-) */
|
||||
ccp->in.algorithm = (int)f; /* This one'll do :-) */
|
||||
break;
|
||||
}
|
||||
} else {
|
||||
@ -709,7 +711,7 @@ CcpRecvResetAck(struct fsm *fp, u_char id)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
ccp_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
ccp_LayerPush(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
{
|
||||
if (PROTO_COMPRESSIBLE(*proto)) {
|
||||
@ -739,7 +741,8 @@ ccp_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
ccp_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp, u_short *proto)
|
||||
ccp_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
{
|
||||
/*
|
||||
* If proto isn't PROTO_[I]COMPD, we still want to pass it to the
|
||||
@ -805,13 +808,13 @@ ccp_SetOpenMode(struct ccp *ccp)
|
||||
}
|
||||
|
||||
int
|
||||
ccp_DefaultUsable(struct fsm *fp)
|
||||
ccp_DefaultUsable(struct fsm *fp __unused)
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
ccp_DefaultRequired(struct fsm *fp)
|
||||
ccp_DefaultRequired(struct fsm *fp __unused)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
@ -35,6 +35,7 @@
|
||||
#include <sys/socket.h>
|
||||
#include <sys/un.h>
|
||||
|
||||
#include <ctype.h>
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#ifndef NODES
|
||||
@ -121,9 +122,10 @@ ChapOutput(struct physical *physical, u_int code, u_int id,
|
||||
}
|
||||
|
||||
static char *
|
||||
chap_BuildAnswer(char *name, char *key, u_char id, char *challenge, u_char type
|
||||
chap_BuildAnswer(char *name, char *key, u_char id, char *challenge
|
||||
#ifndef NODES
|
||||
, char *peerchallenge, char *authresponse, int lanman
|
||||
, u_char type, char *peerchallenge, char *authresponse,
|
||||
int lanman
|
||||
#endif
|
||||
)
|
||||
{
|
||||
@ -137,7 +139,7 @@ chap_BuildAnswer(char *name, char *key, u_char id, char *challenge, u_char type
|
||||
if (type == 0x80) {
|
||||
char expkey[AUTHLEN << 2];
|
||||
MD4_CTX MD4context;
|
||||
int f;
|
||||
size_t f;
|
||||
|
||||
if ((result = malloc(1 + nlen + MS_CHAP_RESPONSE_LEN)) == NULL)
|
||||
return result;
|
||||
@ -184,7 +186,7 @@ chap_BuildAnswer(char *name, char *key, u_char id, char *challenge, u_char type
|
||||
char pwdhash[CHAP81_HASH_LEN];
|
||||
char pwdhashhash[CHAP81_HASH_LEN];
|
||||
char *ntresponse;
|
||||
int f;
|
||||
size_t f;
|
||||
|
||||
if ((result = malloc(1 + nlen + CHAP81_RESPONSE_LEN)) == NULL)
|
||||
return result;
|
||||
@ -210,7 +212,7 @@ chap_BuildAnswer(char *name, char *key, u_char id, char *challenge, u_char type
|
||||
HashNtPasswordHash(pwdhash, pwdhashhash);
|
||||
|
||||
/* Generate NTRESPONSE to respond on challenge call */
|
||||
GenerateNTResponse(challenge + 1, peerchallenge + 1, name, nlen,
|
||||
GenerateNTResponse(challenge + 1, peerchallenge + 1, name,
|
||||
expkey, klen * 2, ntresponse);
|
||||
|
||||
/* Generate MPPE MASTERKEY */
|
||||
@ -218,7 +220,7 @@ chap_BuildAnswer(char *name, char *key, u_char id, char *challenge, u_char type
|
||||
|
||||
/* Generate AUTHRESPONSE to verify on auth success */
|
||||
GenerateAuthenticatorResponse(expkey, klen * 2, ntresponse,
|
||||
peerchallenge + 1, challenge + 1, name, nlen,
|
||||
peerchallenge + 1, challenge + 1, name,
|
||||
authresponse);
|
||||
|
||||
authresponse[CHAP81_AUTHRESPONSE_LEN] = 0;
|
||||
@ -363,17 +365,17 @@ chap_Cleanup(struct chap *chap, int sig)
|
||||
}
|
||||
|
||||
static void
|
||||
chap_Respond(struct chap *chap, char *name, char *key, u_char type
|
||||
chap_Respond(struct chap *chap, char *name, char *key
|
||||
#ifndef NODES
|
||||
, int lm
|
||||
, u_char type, int lm
|
||||
#endif
|
||||
)
|
||||
{
|
||||
u_char *ans;
|
||||
|
||||
ans = chap_BuildAnswer(name, key, chap->auth.id, chap->challenge.peer, type
|
||||
ans = chap_BuildAnswer(name, key, chap->auth.id, chap->challenge.peer
|
||||
#ifndef NODES
|
||||
, chap->challenge.local, chap->authresponse, lm
|
||||
, type, chap->challenge.local, chap->authresponse, lm
|
||||
#endif
|
||||
);
|
||||
|
||||
@ -391,7 +393,8 @@ chap_Respond(struct chap *chap, char *name, char *key, u_char type
|
||||
}
|
||||
|
||||
static int
|
||||
chap_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w, fd_set *e, int *n)
|
||||
chap_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w __unused,
|
||||
fd_set *e __unused, int *n)
|
||||
{
|
||||
struct chap *chap = descriptor2chap(d);
|
||||
|
||||
@ -415,7 +418,8 @@ chap_IsSet(struct fdescriptor *d, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static void
|
||||
chap_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
chap_Read(struct fdescriptor *d, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct chap *chap = descriptor2chap(d);
|
||||
int got;
|
||||
@ -460,9 +464,9 @@ chap_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
*end-- = '\0';
|
||||
key += strspn(key, " \t");
|
||||
|
||||
chap_Respond(chap, name, key, chap->auth.physical->link.lcp.his_authtype
|
||||
chap_Respond(chap, name, key
|
||||
#ifndef NODES
|
||||
, lanman
|
||||
, chap->auth.physical->link.lcp.his_authtype, lanman
|
||||
#endif
|
||||
);
|
||||
chap_Cleanup(chap, 0);
|
||||
@ -471,7 +475,8 @@ chap_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static int
|
||||
chap_Write(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
chap_Write(struct fdescriptor *d __unused, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
/* We never want to write here ! */
|
||||
log_Printf(LogALERT, "chap_Write: Internal error: Bad call !\n");
|
||||
@ -618,9 +623,9 @@ chap_Failure(struct authinfo *authp)
|
||||
}
|
||||
|
||||
static int
|
||||
chap_Cmp(u_char type, char *myans, int mylen, char *hisans, int hislen
|
||||
chap_Cmp(char *myans, int mylen, char *hisans, int hislen
|
||||
#ifndef NODES
|
||||
, int lm
|
||||
, u_char type, int lm
|
||||
#endif
|
||||
)
|
||||
{
|
||||
@ -690,7 +695,8 @@ chap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
struct physical *p = link2physical(l);
|
||||
struct chap *chap = &p->dl->chap;
|
||||
char *name, *key, *ans;
|
||||
int len, nlen;
|
||||
int len;
|
||||
size_t nlen;
|
||||
u_char alen;
|
||||
#ifndef NODES
|
||||
int lanman;
|
||||
@ -833,10 +839,10 @@ chap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
bundle->cfg.auth.name);
|
||||
else
|
||||
chap_Respond(chap, bundle->cfg.auth.name, bundle->cfg.auth.key +
|
||||
(*bundle->cfg.auth.key == '!' ? 1 : 0),
|
||||
p->link.lcp.his_authtype
|
||||
(*bundle->cfg.auth.key == '!' ? 1 : 0)
|
||||
|
||||
#ifndef NODES
|
||||
, lanman
|
||||
, p->link.lcp.his_authtype, lanman
|
||||
#endif
|
||||
);
|
||||
break;
|
||||
@ -872,7 +878,7 @@ chap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
"CHAP81 RESPONSE\n", l->name);
|
||||
resp->Flags = '\0'; /* rfc2759 says it *MUST* be zero */
|
||||
}
|
||||
key = auth_GetSecret(bundle, name, nlen, p);
|
||||
key = auth_GetSecret(name, nlen);
|
||||
if (key) {
|
||||
#ifndef NODES
|
||||
if (p->link.lcp.want_authtype == 0x80 &&
|
||||
@ -895,11 +901,11 @@ chap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
#endif
|
||||
{
|
||||
char *myans = chap_BuildAnswer(name, key, chap->auth.id,
|
||||
chap->challenge.local,
|
||||
p->link.lcp.want_authtype
|
||||
chap->challenge.local
|
||||
#ifndef NODES
|
||||
, chap->challenge.peer,
|
||||
chap->authresponse, lanman);
|
||||
, p->link.lcp.want_authtype,
|
||||
chap->challenge.peer,
|
||||
chap->authresponse, lanman);
|
||||
MPPE_IsServer = 1; /* XXX Global ! */
|
||||
#else
|
||||
);
|
||||
@ -907,10 +913,9 @@ chap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
if (myans == NULL)
|
||||
key = NULL;
|
||||
else {
|
||||
if (!chap_Cmp(p->link.lcp.want_authtype, myans + 1, *myans,
|
||||
ans + 1, alen
|
||||
if (!chap_Cmp(myans + 1, *myans, ans + 1, alen
|
||||
#ifndef NODES
|
||||
, lanman
|
||||
, p->link.lcp.want_authtype, lanman
|
||||
#endif
|
||||
))
|
||||
key = NULL;
|
||||
|
@ -150,9 +150,9 @@ HashNtPasswordHash(char *hash, char *hashhash)
|
||||
MD4Final(hashhash, &MD4context);
|
||||
}
|
||||
|
||||
void
|
||||
static void
|
||||
ChallengeHash(char *PeerChallenge, char *AuthenticatorChallenge,
|
||||
char *UserName, int UserNameLen, char *Challenge)
|
||||
char *UserName, char *Challenge)
|
||||
{
|
||||
SHA_CTX Context;
|
||||
char Digest[SHA_DIGEST_LENGTH];
|
||||
@ -176,14 +176,13 @@ ChallengeHash(char *PeerChallenge, char *AuthenticatorChallenge,
|
||||
|
||||
void
|
||||
GenerateNTResponse(char *AuthenticatorChallenge, char *PeerChallenge,
|
||||
char *UserName, int UserNameLen, char *Password,
|
||||
char *UserName, char *Password,
|
||||
int PasswordLen, char *Response)
|
||||
{
|
||||
char Challenge[8];
|
||||
char PasswordHash[16];
|
||||
|
||||
ChallengeHash(PeerChallenge, AuthenticatorChallenge, UserName, UserNameLen,
|
||||
Challenge);
|
||||
ChallengeHash(PeerChallenge, AuthenticatorChallenge, UserName, Challenge);
|
||||
NtPasswordHash(Password, PasswordLen, PasswordHash);
|
||||
ChallengeResponse(Challenge, PasswordHash, Response);
|
||||
}
|
||||
@ -215,7 +214,7 @@ void
|
||||
GenerateAuthenticatorResponse(char *Password, int PasswordLen,
|
||||
char *NTResponse, char *PeerChallenge,
|
||||
char *AuthenticatorChallenge, char *UserName,
|
||||
int UserNameLen, char *AuthenticatorResponse)
|
||||
char *AuthenticatorResponse)
|
||||
{
|
||||
SHA_CTX Context;
|
||||
char PasswordHash[16];
|
||||
@ -254,8 +253,7 @@ GenerateAuthenticatorResponse(char *Password, int PasswordLen,
|
||||
SHA1_Update(&Context, NTResponse, 24);
|
||||
SHA1_Update(&Context, Magic1, 39);
|
||||
SHA1_Final(Digest, &Context);
|
||||
ChallengeHash(PeerChallenge, AuthenticatorChallenge, UserName, UserNameLen,
|
||||
Challenge);
|
||||
ChallengeHash(PeerChallenge, AuthenticatorChallenge, UserName, Challenge);
|
||||
SHA1_Init(&Context);
|
||||
SHA1_Update(&Context, Digest, 20);
|
||||
SHA1_Update(&Context, Challenge, 8);
|
||||
|
@ -43,11 +43,10 @@
|
||||
|
||||
extern void mschap_NT(char *, char *);
|
||||
extern void mschap_LANMan(char *, char *, char *);
|
||||
extern void GenerateNTResponse(char *, char *, char *, int, char *, int , char *);
|
||||
extern void GenerateNTResponse(char *, char *, char *, char *, int , char *);
|
||||
extern void HashNtPasswordHash(char *, char *);
|
||||
extern void NtPasswordHash(char *, int, char *);
|
||||
extern void ChallengeHash(char *, char *, char *UserName, int, char *);
|
||||
extern void GenerateAuthenticatorResponse(char *, int, char *, char *, char *, char *, int, char *);
|
||||
extern void GenerateAuthenticatorResponse(char *, int, char *, char *, char *, char *, char *);
|
||||
extern void GetAsymetricStartKey(char *, char *, int, int, int);
|
||||
extern void GetMasterKey(char *, char *, char *);
|
||||
extern void GetNewKeyFromSHA(char *, char *, long, char *);
|
||||
|
@ -370,7 +370,8 @@ chat_UpdateLog(struct chat *c, int in)
|
||||
}
|
||||
|
||||
static void
|
||||
chat_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
chat_Read(struct fdescriptor *d, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct chat *c = descriptor2chat(d);
|
||||
|
||||
@ -384,7 +385,7 @@ chat_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
* swallow any ppp talk from the peer ?
|
||||
*/
|
||||
in = BUFLEFT(c);
|
||||
if (in > sizeof c->buf / 2)
|
||||
if (in > (ssize_t)sizeof c->buf / 2)
|
||||
in = sizeof c->buf / 2;
|
||||
|
||||
in = physical_Read(c->physical, c->bufend, in);
|
||||
@ -484,7 +485,8 @@ chat_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static int
|
||||
chat_Write(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
chat_Write(struct fdescriptor *d, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct chat *c = descriptor2chat(d);
|
||||
int result = 0;
|
||||
|
@ -167,7 +167,7 @@
|
||||
#define NEG_MPPE 54
|
||||
#define NEG_CHAP81 55
|
||||
|
||||
const char Version[] = "3.2";
|
||||
const char Version[] = "3.3";
|
||||
|
||||
static int ShowCommand(struct cmdargs const *);
|
||||
static int TerminalCommand(struct cmdargs const *);
|
||||
@ -364,7 +364,7 @@ LogCommand(struct cmdargs const *arg)
|
||||
char *argv[MAXARGS];
|
||||
int argc = arg->argc - arg->argn;
|
||||
|
||||
if (argc >= sizeof argv / sizeof argv[0]) {
|
||||
if (argc >= (int)(sizeof argv / sizeof argv[0])) {
|
||||
argc = sizeof argv / sizeof argv[0] - 1;
|
||||
log_Printf(LogWARN, "Truncating log command to %d args\n", argc);
|
||||
}
|
||||
@ -379,7 +379,7 @@ LogCommand(struct cmdargs const *arg)
|
||||
}
|
||||
|
||||
static int
|
||||
SaveCommand(struct cmdargs const *arg)
|
||||
SaveCommand(struct cmdargs const *arg __unused)
|
||||
{
|
||||
log_Printf(LogWARN, "save command is not yet implemented.\n");
|
||||
return 1;
|
||||
@ -673,7 +673,7 @@ ShellCommand(struct cmdargs const *arg, int bg)
|
||||
char *argv[MAXARGS];
|
||||
int argc = arg->argc - arg->argn;
|
||||
|
||||
if (argc >= sizeof argv / sizeof argv[0]) {
|
||||
if (argc >= (int)(sizeof argv / sizeof argv[0])) {
|
||||
argc = sizeof argv / sizeof argv[0] - 1;
|
||||
log_Printf(LogWARN, "Truncating shell command to %d args\n", argc);
|
||||
}
|
||||
@ -756,32 +756,32 @@ ResolvCommand(struct cmdargs const *arg)
|
||||
static struct cmdtab const NatCommands[] =
|
||||
{
|
||||
{"addr", NULL, nat_RedirectAddr, LOCAL_AUTH,
|
||||
"static address translation", "nat addr [addr_local addr_alias]"},
|
||||
"static address translation", "nat addr [addr_local addr_alias]", NULL},
|
||||
{"deny_incoming", NULL, NatOption, LOCAL_AUTH,
|
||||
"stop incoming connections", "nat deny_incoming yes|no",
|
||||
(const void *) PKT_ALIAS_DENY_INCOMING},
|
||||
{"enable", NULL, NatEnable, LOCAL_AUTH,
|
||||
"enable NAT", "nat enable yes|no"},
|
||||
"enable NAT", "nat enable yes|no", NULL},
|
||||
{"log", NULL, NatOption, LOCAL_AUTH,
|
||||
"log NAT link creation", "nat log yes|no",
|
||||
(const void *) PKT_ALIAS_LOG},
|
||||
{"port", NULL, nat_RedirectPort, LOCAL_AUTH, "port redirection",
|
||||
"nat port proto localaddr:port[-port] aliasport[-aliasport]"},
|
||||
"nat port proto localaddr:port[-port] aliasport[-aliasport]", NULL},
|
||||
{"proto", NULL, nat_RedirectProto, LOCAL_AUTH, "protocol redirection",
|
||||
"nat proto proto localIP [publicIP [remoteIP]]"},
|
||||
"nat proto proto localIP [publicIP [remoteIP]]", NULL},
|
||||
{"proxy", NULL, nat_ProxyRule, LOCAL_AUTH,
|
||||
"proxy control", "nat proxy server host[:port] ..."},
|
||||
"proxy control", "nat proxy server host[:port] ...", NULL},
|
||||
#ifndef NO_FW_PUNCH
|
||||
{"punch_fw", NULL, nat_PunchFW, LOCAL_AUTH,
|
||||
"firewall control", "nat punch_fw [base count]"},
|
||||
"firewall control", "nat punch_fw [base count]", NULL},
|
||||
#endif
|
||||
{"skinny_port", NULL, nat_SkinnyPort, LOCAL_AUTH,
|
||||
"TCP port used by Skinny Station protocol", "nat skinny_port [port]"},
|
||||
"TCP port used by Skinny Station protocol", "nat skinny_port [port]", NULL},
|
||||
{"same_ports", NULL, NatOption, LOCAL_AUTH,
|
||||
"try to leave port numbers unchanged", "nat same_ports yes|no",
|
||||
(const void *) PKT_ALIAS_SAME_PORTS},
|
||||
{"target", NULL, nat_SetTarget, LOCAL_AUTH,
|
||||
"Default address for incoming connections", "nat target addr" },
|
||||
"Default address for incoming connections", "nat target addr", NULL},
|
||||
{"unregistered_only", NULL, NatOption, LOCAL_AUTH,
|
||||
"translate unregistered (private) IP address space only",
|
||||
"nat unregistered_only yes|no",
|
||||
@ -791,18 +791,18 @@ static struct cmdtab const NatCommands[] =
|
||||
(const void *) PKT_ALIAS_USE_SOCKETS},
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "nat help|? [command]", NatCommands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
#endif
|
||||
|
||||
static struct cmdtab const AllowCommands[] = {
|
||||
{"modes", "mode", AllowModes, LOCAL_AUTH,
|
||||
"Only allow certain ppp modes", "allow modes mode..."},
|
||||
"Only allow certain ppp modes", "allow modes mode...", NULL},
|
||||
{"users", "user", AllowUsers, LOCAL_AUTH,
|
||||
"Only allow ppp access to certain users", "allow users logname..."},
|
||||
"Only allow ppp access to certain users", "allow users logname...", NULL},
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "allow help|? [command]", AllowCommands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static struct cmdtab const IfaceCommands[] =
|
||||
@ -813,7 +813,7 @@ static struct cmdtab const IfaceCommands[] =
|
||||
"Add or change an iface address", "iface add! addr[/bits| mask] peer",
|
||||
(void *)1},
|
||||
{"clear", NULL, IfaceClearCommand, LOCAL_AUTH,
|
||||
"Clear iface address(es)", "iface clear [INET | INET6]"},
|
||||
"Clear iface address(es)", "iface clear [INET | INET6]", NULL},
|
||||
{"delete", "rm", IfaceDeleteCommand, LOCAL_AUTH,
|
||||
"Delete iface address", "iface delete addr", NULL},
|
||||
{NULL, "rm!", IfaceDeleteCommand, LOCAL_AUTH,
|
||||
@ -821,15 +821,15 @@ static struct cmdtab const IfaceCommands[] =
|
||||
{NULL, "delete!", IfaceDeleteCommand, LOCAL_AUTH,
|
||||
"Delete iface address", "iface delete addr", (void *)1},
|
||||
{"show", NULL, iface_Show, LOCAL_AUTH,
|
||||
"Show iface address(es)", "iface show"},
|
||||
"Show iface address(es)", "iface show", NULL},
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "nat help|? [command]", IfaceCommands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static struct cmdtab const Commands[] = {
|
||||
{"accept", NULL, NegotiateCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"accept option request", "accept option .."},
|
||||
"accept option request", "accept option ..", NULL},
|
||||
{"add", NULL, AddCommand, LOCAL_AUTH,
|
||||
"add route", "add dest mask gateway", NULL},
|
||||
{NULL, "add!", AddCommand, LOCAL_AUTH,
|
||||
@ -837,38 +837,38 @@ static struct cmdtab const Commands[] = {
|
||||
{"allow", "auth", RunListCommand, LOCAL_AUTH,
|
||||
"Allow ppp access", "allow users|modes ....", AllowCommands},
|
||||
{"bg", "!bg", BgShellCommand, LOCAL_AUTH,
|
||||
"Run a background command", "[!]bg command"},
|
||||
"Run a background command", "[!]bg command", NULL},
|
||||
{"clear", NULL, ClearCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Clear throughput statistics",
|
||||
"clear ipcp|ipv6cp|physical [current|overall|peak]..."},
|
||||
"clear ipcp|ipv6cp|physical [current|overall|peak]...", NULL},
|
||||
{"clone", NULL, CloneCommand, LOCAL_AUTH | LOCAL_CX,
|
||||
"Clone a link", "clone newname..."},
|
||||
"Clone a link", "clone newname...", NULL},
|
||||
{"close", NULL, CloseCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Close an FSM", "close [lcp|ccp]"},
|
||||
"Close an FSM", "close [lcp|ccp]", NULL},
|
||||
{"delete", NULL, DeleteCommand, LOCAL_AUTH,
|
||||
"delete route", "delete dest", NULL},
|
||||
{NULL, "delete!", DeleteCommand, LOCAL_AUTH,
|
||||
"delete a route if it exists", "delete! dest", (void *)1},
|
||||
{"deny", NULL, NegotiateCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Deny option request", "deny option .."},
|
||||
"Deny option request", "deny option ..", NULL},
|
||||
{"dial", "call", DialCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Dial and login", "dial|call [system ...]", NULL},
|
||||
{"disable", NULL, NegotiateCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Disable option", "disable option .."},
|
||||
"Disable option", "disable option ..", NULL},
|
||||
{"down", NULL, DownCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Generate a down event", "down [ccp|lcp]"},
|
||||
"Generate a down event", "down [ccp|lcp]", NULL},
|
||||
{"enable", NULL, NegotiateCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Enable option", "enable option .."},
|
||||
"Enable option", "enable option ..", NULL},
|
||||
{"ident", NULL, IdentCommand, LOCAL_AUTH | LOCAL_CX,
|
||||
"Set the link identity", "ident text..."},
|
||||
"Set the link identity", "ident text...", NULL},
|
||||
{"iface", "interface", RunListCommand, LOCAL_AUTH,
|
||||
"interface control", "iface option ...", IfaceCommands},
|
||||
{"link", "datalink", LinkCommand, LOCAL_AUTH,
|
||||
"Link specific commands", "link name command ..."},
|
||||
"Link specific commands", "link name command ...", NULL},
|
||||
{"load", NULL, LoadCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Load settings", "load [system ...]"},
|
||||
"Load settings", "load [system ...]", NULL},
|
||||
{"log", NULL, LogCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"log information", "log word ..."},
|
||||
"log information", "log word ...", NULL},
|
||||
#ifndef NONAT
|
||||
{"nat", "alias", RunListCommand, LOCAL_AUTH,
|
||||
"NAT control", "nat option yes|no", NatCommands},
|
||||
@ -876,30 +876,31 @@ static struct cmdtab const Commands[] = {
|
||||
{"open", NULL, OpenCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Open an FSM", "open! [lcp|ccp|ipcp]", (void *)1},
|
||||
{"passwd", NULL, PasswdCommand, LOCAL_NO_AUTH,
|
||||
"Password for manipulation", "passwd LocalPassword"},
|
||||
"Password for manipulation", "passwd LocalPassword", NULL},
|
||||
{"quit", "bye", QuitCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Quit PPP program", "quit|bye [all]"},
|
||||
"Quit PPP program", "quit|bye [all]", NULL},
|
||||
{"remove", "rm", RemoveCommand, LOCAL_AUTH | LOCAL_CX,
|
||||
"Remove a link", "remove"},
|
||||
"Remove a link", "remove", NULL},
|
||||
{"rename", "mv", RenameCommand, LOCAL_AUTH | LOCAL_CX,
|
||||
"Rename a link", "rename name"},
|
||||
"Rename a link", "rename name", NULL},
|
||||
{"resolv", NULL, ResolvCommand, LOCAL_AUTH,
|
||||
"Manipulate resolv.conf", "resolv readonly|reload|restore|rewrite|writable"},
|
||||
"Manipulate resolv.conf", "resolv readonly|reload|restore|rewrite|writable",
|
||||
NULL},
|
||||
{"save", NULL, SaveCommand, LOCAL_AUTH,
|
||||
"Save settings", "save"},
|
||||
"Save settings", "save", NULL},
|
||||
{"sendident", NULL, SendIdentification, LOCAL_AUTH | LOCAL_CX,
|
||||
"Transmit the link identity", "sendident"},
|
||||
"Transmit the link identity", "sendident", NULL},
|
||||
{"set", "setup", SetCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Set parameters", "set[up] var value"},
|
||||
"Set parameters", "set[up] var value", NULL},
|
||||
{"shell", "!", FgShellCommand, LOCAL_AUTH,
|
||||
"Run a subshell", "shell|! [sh command]"},
|
||||
"Run a subshell", "shell|! [sh command]", NULL},
|
||||
{"show", NULL, ShowCommand, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Show status and stats", "show var"},
|
||||
"Show status and stats", "show var", NULL},
|
||||
{"term", NULL, TerminalCommand, LOCAL_AUTH | LOCAL_CX,
|
||||
"Enter terminal mode", "term"},
|
||||
"Enter terminal mode", "term", NULL},
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "help|? [command]", Commands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static int
|
||||
@ -969,58 +970,58 @@ ShowProtocolStats(struct cmdargs const *arg)
|
||||
|
||||
static struct cmdtab const ShowCommands[] = {
|
||||
{"bundle", NULL, bundle_ShowStatus, LOCAL_AUTH,
|
||||
"bundle details", "show bundle"},
|
||||
"bundle details", "show bundle", NULL},
|
||||
{"ccp", NULL, ccp_ReportStatus, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"CCP status", "show cpp"},
|
||||
"CCP status", "show cpp", NULL},
|
||||
{"compress", NULL, sl_Show, LOCAL_AUTH,
|
||||
"VJ compression stats", "show compress"},
|
||||
"VJ compression stats", "show compress", NULL},
|
||||
{"escape", NULL, ShowEscape, LOCAL_AUTH | LOCAL_CX,
|
||||
"escape characters", "show escape"},
|
||||
"escape characters", "show escape", NULL},
|
||||
{"filter", NULL, filter_Show, LOCAL_AUTH,
|
||||
"packet filters", "show filter [in|out|dial|alive]"},
|
||||
"packet filters", "show filter [in|out|dial|alive]", NULL},
|
||||
{"hdlc", NULL, hdlc_ReportStatus, LOCAL_AUTH | LOCAL_CX,
|
||||
"HDLC errors", "show hdlc"},
|
||||
"HDLC errors", "show hdlc", NULL},
|
||||
{"iface", "interface", iface_Show, LOCAL_AUTH,
|
||||
"Interface status", "show iface"},
|
||||
"Interface status", "show iface", NULL},
|
||||
{"ipcp", NULL, ipcp_Show, LOCAL_AUTH,
|
||||
"IPCP status", "show ipcp"},
|
||||
"IPCP status", "show ipcp", NULL},
|
||||
#ifndef NOINET6
|
||||
{"ipv6cp", NULL, ipv6cp_Show, LOCAL_AUTH,
|
||||
"IPV6CP status", "show ipv6cp"},
|
||||
"IPV6CP status", "show ipv6cp", NULL},
|
||||
#endif
|
||||
{"layers", NULL, link_ShowLayers, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"Protocol layers", "show layers"},
|
||||
"Protocol layers", "show layers", NULL},
|
||||
{"lcp", NULL, lcp_ReportStatus, LOCAL_AUTH | LOCAL_CX,
|
||||
"LCP status", "show lcp"},
|
||||
"LCP status", "show lcp", NULL},
|
||||
{"link", "datalink", datalink_Show, LOCAL_AUTH | LOCAL_CX,
|
||||
"(high-level) link info", "show link"},
|
||||
"(high-level) link info", "show link", NULL},
|
||||
{"links", NULL, bundle_ShowLinks, LOCAL_AUTH,
|
||||
"available link names", "show links"},
|
||||
"available link names", "show links", NULL},
|
||||
{"log", NULL, log_ShowLevel, LOCAL_AUTH,
|
||||
"log levels", "show log"},
|
||||
"log levels", "show log", NULL},
|
||||
{"mem", NULL, mbuf_Show, LOCAL_AUTH,
|
||||
"mbuf allocations", "show mem"},
|
||||
"mbuf allocations", "show mem", NULL},
|
||||
{"ncp", NULL, ncp_Show, LOCAL_AUTH,
|
||||
"NCP status", "show ncp"},
|
||||
"NCP status", "show ncp", NULL},
|
||||
{"physical", NULL, physical_ShowStatus, LOCAL_AUTH | LOCAL_CX,
|
||||
"(low-level) link info", "show physical"},
|
||||
"(low-level) link info", "show physical", NULL},
|
||||
{"mp", "multilink", mp_ShowStatus, LOCAL_AUTH,
|
||||
"multilink setup", "show mp"},
|
||||
"multilink setup", "show mp", NULL},
|
||||
{"proto", NULL, ShowProtocolStats, LOCAL_AUTH | LOCAL_CX_OPT,
|
||||
"protocol summary", "show proto"},
|
||||
"protocol summary", "show proto", NULL},
|
||||
{"route", NULL, route_Show, LOCAL_AUTH,
|
||||
"routing table", "show route"},
|
||||
"routing table", "show route", NULL},
|
||||
{"stopped", NULL, ShowStopped, LOCAL_AUTH | LOCAL_CX,
|
||||
"STOPPED timeout", "show stopped"},
|
||||
"STOPPED timeout", "show stopped", NULL},
|
||||
{"timers", NULL, ShowTimerList, LOCAL_AUTH,
|
||||
"alarm timers", "show timers"},
|
||||
"alarm timers", "show timers", NULL},
|
||||
{"version", NULL, ShowVersion, LOCAL_NO_AUTH | LOCAL_AUTH,
|
||||
"version string", "show version"},
|
||||
"version string", "show version", NULL},
|
||||
{"who", NULL, log_ShowWho, LOCAL_AUTH,
|
||||
"client list", "show who"},
|
||||
"client list", "show who", NULL},
|
||||
{"help", "?", HelpCommand, LOCAL_NO_AUTH | LOCAL_AUTH,
|
||||
"Display this message", "show help|? [command]", ShowCommands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static struct cmdtab const *
|
||||
@ -1152,7 +1153,7 @@ command_Interpret(char *buff, int nb, char *argv[MAXARGS])
|
||||
}
|
||||
|
||||
static int
|
||||
arghidden(int argc, char const *const *argv, int n)
|
||||
arghidden(char const *const *argv, int n)
|
||||
{
|
||||
/* Is arg n of the given command to be hidden from the log ? */
|
||||
|
||||
@ -1181,7 +1182,8 @@ command_Run(struct bundle *bundle, int argc, char const *const *argv,
|
||||
if (argc > 0) {
|
||||
if (log_IsKept(LogCOMMAND)) {
|
||||
char buf[LINE_LEN];
|
||||
int f, n;
|
||||
int f;
|
||||
size_t n;
|
||||
|
||||
if (label) {
|
||||
strncpy(buf, label, sizeof buf - 3);
|
||||
@ -1197,7 +1199,7 @@ command_Run(struct bundle *bundle, int argc, char const *const *argv,
|
||||
for (f = 0; f < argc; f++) {
|
||||
if (n < sizeof buf - 1 && f)
|
||||
buf[n++] = ' ';
|
||||
if (arghidden(argc, argv, f))
|
||||
if (arghidden(argv, f))
|
||||
strncpy(buf+n, "********", sizeof buf - n - 1);
|
||||
else
|
||||
strncpy(buf+n, argv[f], sizeof buf - n - 1);
|
||||
@ -1262,7 +1264,7 @@ QuitCommand(struct cmdargs const *arg)
|
||||
if (!arg->prompt || prompt_IsController(arg->prompt) ||
|
||||
(arg->argc > arg->argn && !strcasecmp(arg->argv[arg->argn], "all") &&
|
||||
(arg->prompt->auth & LOCAL_AUTH)))
|
||||
Cleanup(EX_NORMAL);
|
||||
Cleanup();
|
||||
if (arg->prompt)
|
||||
prompt_Destroy(arg->prompt, 1);
|
||||
|
||||
@ -1389,7 +1391,7 @@ SetModemSpeed(struct cmdargs const *arg)
|
||||
}
|
||||
end = NULL;
|
||||
speed = strtol(arg->argv[arg->argn], &end, 10);
|
||||
if (*end) {
|
||||
if (*end || speed < 0) {
|
||||
log_Printf(LogWARN, "SetModemSpeed: Bad argument \"%s\"",
|
||||
arg->argv[arg->argn]);
|
||||
return -1;
|
||||
@ -1428,7 +1430,7 @@ SetServer(struct cmdargs const *arg)
|
||||
|
||||
if (arg->argc > arg->argn && arg->argc < arg->argn+4) {
|
||||
const char *port, *passwd, *mask;
|
||||
int mlen;
|
||||
size_t mlen;
|
||||
|
||||
/* What's what ? */
|
||||
port = arg->argv[arg->argn];
|
||||
@ -2021,10 +2023,12 @@ SetVariable(struct cmdargs const *arg)
|
||||
log_Printf(LogWARN, "Too few idle timeout values\n");
|
||||
res = 1;
|
||||
} else {
|
||||
int timeout, min;
|
||||
unsigned long timeout, min;
|
||||
|
||||
timeout = atoi(argp);
|
||||
min = arg->argc == arg->argn + 2 ? atoi(arg->argv[arg->argn + 1]) : -1;
|
||||
timeout = strtoul(argp, NULL, 10);
|
||||
min = arg->bundle->cfg.idle.min_timeout;
|
||||
if (arg->argc == arg->argn + 2)
|
||||
min = strtoul(arg->argv[arg->argn + 1], NULL, 10);
|
||||
bundle_SetIdleTimer(arg->bundle, timeout, min);
|
||||
}
|
||||
break;
|
||||
@ -2323,7 +2327,7 @@ static struct cmdtab const SetCommands[] = {
|
||||
"auto link [de]activation", "set autoload maxtime maxload mintime minload",
|
||||
(const void *)VAR_AUTOLOAD},
|
||||
{"bandwidth", NULL, mp_SetDatalinkBandwidth, LOCAL_AUTH | LOCAL_CX,
|
||||
"datalink bandwidth", "set bandwidth value"},
|
||||
"datalink bandwidth", "set bandwidth value", NULL},
|
||||
{"callback", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX,
|
||||
"callback control", "set callback [none|auth|cbcp|"
|
||||
"E.164 *|number[,number]...]...", (const void *)VAR_CALLBACK},
|
||||
@ -2358,17 +2362,17 @@ static struct cmdtab const SetCommands[] = {
|
||||
{"dns", NULL, SetVariable, LOCAL_AUTH, "Domain Name Server",
|
||||
"set dns pri-addr [sec-addr]", (const void *)VAR_DNS},
|
||||
{"enddisc", NULL, mp_SetEnddisc, LOCAL_AUTH,
|
||||
"Endpoint Discriminator", "set enddisc [IP|magic|label|psn value]"},
|
||||
"Endpoint Discriminator", "set enddisc [IP|magic|label|psn value]", NULL},
|
||||
{"escape", NULL, SetEscape, LOCAL_AUTH | LOCAL_CX,
|
||||
"escape characters", "set escape hex-digit ..."},
|
||||
"escape characters", "set escape hex-digit ...", NULL},
|
||||
{"filter", NULL, filter_Set, LOCAL_AUTH,
|
||||
"packet filters", "set filter alive|dial|in|out rule-no permit|deny "
|
||||
"[src_addr[/width]] [dst_addr[/width]] [proto "
|
||||
"[src [lt|eq|gt port]] [dst [lt|eq|gt port]] [estab] [syn] [finrst]]"},
|
||||
"[src [lt|eq|gt port]] [dst [lt|eq|gt port]] [estab] [syn] [finrst]]", NULL},
|
||||
{"hangup", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX,
|
||||
"hangup script", "set hangup chat-script", (const void *) VAR_HANGUP},
|
||||
{"ifaddr", NULL, SetInterfaceAddr, LOCAL_AUTH, "destination address",
|
||||
"set ifaddr [src-addr [dst-addr [netmask [trg-addr]]]]"},
|
||||
"set ifaddr [src-addr [dst-addr [netmask [trg-addr]]]]", NULL},
|
||||
{"ifqueue", NULL, SetVariable, LOCAL_AUTH, "interface queue",
|
||||
"set ifqueue packets", (const void *)VAR_IFQUEUE},
|
||||
{"ipcpretry", "ipcpretries", SetVariable, LOCAL_AUTH, "IPCP retries",
|
||||
@ -2379,7 +2383,7 @@ static struct cmdtab const SetCommands[] = {
|
||||
"set lcpretry value [attempts]", (const void *)VAR_LCPRETRY},
|
||||
{"log", NULL, log_SetLevel, LOCAL_AUTH, "log level",
|
||||
"set log [local] [+|-]all|async|cbcp|ccp|chat|command|connect|debug|dns|hdlc|"
|
||||
"id0|ipcp|lcp|lqm|phase|physical|radius|sync|tcp/ip|timer|tun..."},
|
||||
"id0|ipcp|lcp|lqm|phase|physical|radius|sync|tcp/ip|timer|tun...", NULL},
|
||||
{"login", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX,
|
||||
"login script", "set login chat-script", (const void *) VAR_LOGIN},
|
||||
{"logout", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX,
|
||||
@ -2405,7 +2409,7 @@ static struct cmdtab const SetCommands[] = {
|
||||
{"phone", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX, "telephone number(s)",
|
||||
"set phone phone1[:phone2[...]]", (const void *)VAR_PHONE},
|
||||
{"proctitle", "title", SetProcTitle, LOCAL_AUTH,
|
||||
"Process title", "set proctitle [value]"},
|
||||
"Process title", "set proctitle [value]", NULL},
|
||||
#ifndef NORADIUS
|
||||
{"radius", NULL, SetVariable, LOCAL_AUTH,
|
||||
"RADIUS Config", "set radius cfgfile", (const void *)VAR_RADIUS},
|
||||
@ -2414,31 +2418,32 @@ static struct cmdtab const SetCommands[] = {
|
||||
(const void *)VAR_RAD_ALIVE},
|
||||
#endif
|
||||
{"reconnect", NULL, datalink_SetReconnect, LOCAL_AUTH | LOCAL_CX,
|
||||
"Reconnect timeout", "set reconnect value ntries"},
|
||||
"Reconnect timeout", "set reconnect value ntries", NULL},
|
||||
{"recvpipe", NULL, SetVariable, LOCAL_AUTH,
|
||||
"RECVPIPE value", "set recvpipe value", (const void *)VAR_RECVPIPE},
|
||||
{"redial", NULL, datalink_SetRedial, LOCAL_AUTH | LOCAL_CX,
|
||||
"Redial timeout", "set redial secs[+inc[-incmax]][.next] [attempts]"},
|
||||
"Redial timeout", "set redial secs[+inc[-incmax]][.next] [attempts]", NULL},
|
||||
{"sendpipe", NULL, SetVariable, LOCAL_AUTH,
|
||||
"SENDPIPE value", "set sendpipe value", (const void *)VAR_SENDPIPE},
|
||||
{"server", "socket", SetServer, LOCAL_AUTH, "diagnostic port",
|
||||
"set server|socket TcpPort|LocalName|none|open|closed [password [mask]]"},
|
||||
"set server|socket TcpPort|LocalName|none|open|closed [password [mask]]",
|
||||
NULL},
|
||||
{"speed", NULL, SetModemSpeed, LOCAL_AUTH | LOCAL_CX,
|
||||
"physical speed", "set speed value|sync"},
|
||||
"physical speed", "set speed value|sync", NULL},
|
||||
{"stopped", NULL, SetStoppedTimeout, LOCAL_AUTH | LOCAL_CX,
|
||||
"STOPPED timeouts", "set stopped [LCPseconds [CCPseconds]]"},
|
||||
"STOPPED timeouts", "set stopped [LCPseconds [CCPseconds]]", NULL},
|
||||
{"timeout", NULL, SetVariable, LOCAL_AUTH, "Idle timeout",
|
||||
"set timeout idletime", (const void *)VAR_IDLETIMEOUT},
|
||||
{"urgent", NULL, SetVariable, LOCAL_AUTH, "urgent ports",
|
||||
"set urgent [tcp|udp] [+|-]port...", (const void *)VAR_URGENTPORTS},
|
||||
{"vj", NULL, ipcp_vjset, LOCAL_AUTH,
|
||||
"vj values", "set vj slots|slotcomp [value]"},
|
||||
"vj values", "set vj slots|slotcomp [value]", NULL},
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "set help|? [command]", SetCommands},
|
||||
{"pppoe", NULL, SetVariable, LOCAL_AUTH | LOCAL_CX,
|
||||
"Connect using standard/3Com mode", "set pppoe [standard|3Com]",
|
||||
(const char *)VAR_PPPOE},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static int
|
||||
@ -2995,7 +3000,7 @@ static struct cmdtab const NegotiateCommands[] = {
|
||||
{"help", "?", HelpCommand, LOCAL_AUTH | LOCAL_NO_AUTH,
|
||||
"Display this message", "accept|deny|disable|enable help|? [value]",
|
||||
NegotiateCommands},
|
||||
{NULL, NULL, NULL},
|
||||
{NULL, NULL, NULL, 0, NULL, NULL, NULL},
|
||||
};
|
||||
|
||||
static int
|
||||
@ -3228,12 +3233,12 @@ SetProcTitle(struct cmdargs const *arg)
|
||||
char *argv[MAXARGS];
|
||||
int argc = arg->argc - arg->argn;
|
||||
|
||||
if (arg->argc == arg->argn) {
|
||||
if (arg->argc <= arg->argn) {
|
||||
SetTitle(NULL);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (argc >= sizeof argv / sizeof argv[0]) {
|
||||
if ((unsigned)argc >= sizeof argv / sizeof argv[0]) {
|
||||
argc = sizeof argv / sizeof argv[0] - 1;
|
||||
log_Printf(LogWARN, "Truncating proc title to %d args\n", argc);
|
||||
}
|
||||
|
@ -79,7 +79,7 @@
|
||||
#include "datalink.h"
|
||||
|
||||
static void datalink_LoginDone(struct datalink *);
|
||||
static void datalink_NewState(struct datalink *, int);
|
||||
static void datalink_NewState(struct datalink *, unsigned);
|
||||
|
||||
static void
|
||||
datalink_OpenTimeout(void *v)
|
||||
@ -274,7 +274,7 @@ datalink_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w, fd_set *e,
|
||||
if (dl->dial.timer.state != TIMER_RUNNING) {
|
||||
if (--dl->dial.tries < 0)
|
||||
dl->dial.tries = 0;
|
||||
if (physical_Open(dl->physical, dl->bundle) >= 0) {
|
||||
if (physical_Open(dl->physical) >= 0) {
|
||||
log_WritePrompts(dl, "%s: Entering terminal mode on %s\r\n"
|
||||
"Type `~?' for help\r\n", dl->name,
|
||||
dl->physical->name.full);
|
||||
@ -1269,16 +1269,16 @@ static const char * const states[] = {
|
||||
const char *
|
||||
datalink_State(struct datalink *dl)
|
||||
{
|
||||
if (dl->state < 0 || dl->state >= sizeof states / sizeof states[0])
|
||||
if (dl->state >= sizeof states / sizeof states[0])
|
||||
return "unknown";
|
||||
return states[dl->state];
|
||||
}
|
||||
|
||||
static void
|
||||
datalink_NewState(struct datalink *dl, int state)
|
||||
datalink_NewState(struct datalink *dl, unsigned state)
|
||||
{
|
||||
if (state != dl->state) {
|
||||
if (state >= 0 && state < sizeof states / sizeof states[0]) {
|
||||
if (state < sizeof states / sizeof states[0]) {
|
||||
log_Printf(LogPHASE, "%s: %s -> %s\n", dl->name, datalink_State(dl),
|
||||
states[state]);
|
||||
dl->state = state;
|
||||
|
@ -53,7 +53,7 @@ struct bundle;
|
||||
|
||||
struct datalink {
|
||||
struct fdescriptor desc; /* We play either a physical or a chat */
|
||||
int state; /* Our DATALINK_* state */
|
||||
unsigned state; /* Our DATALINK_* state */
|
||||
struct physical *physical; /* Our link */
|
||||
|
||||
struct chat chat; /* For bringing the link up & down */
|
||||
|
@ -66,8 +66,8 @@ DeflateResetOutput(void *v)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
DeflateOutput(void *v, struct ccp *ccp, struct link *l, int pri, u_short *proto,
|
||||
struct mbuf *mp)
|
||||
DeflateOutput(void *v, struct ccp *ccp, struct link *l __unused,
|
||||
int pri __unused, u_short *proto, struct mbuf *mp)
|
||||
{
|
||||
struct deflate_state *state = (struct deflate_state *)v;
|
||||
u_char *wp, *rp;
|
||||
@ -440,7 +440,7 @@ DeflateDispOpts(struct fsm_opt *o)
|
||||
}
|
||||
|
||||
static void
|
||||
DeflateInitOptsOutput(struct bundle *bundle, struct fsm_opt *o,
|
||||
DeflateInitOptsOutput(struct bundle *bundle __unused, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg)
|
||||
{
|
||||
o->hdr.len = 4;
|
||||
@ -449,8 +449,8 @@ DeflateInitOptsOutput(struct bundle *bundle, struct fsm_opt *o,
|
||||
}
|
||||
|
||||
static int
|
||||
DeflateSetOptsOutput(struct bundle *bundle, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg)
|
||||
DeflateSetOptsOutput(struct bundle *bundle __unused, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg __unused)
|
||||
{
|
||||
if (o->hdr.len != 4 || (o->data[0] & 15) != 8 || o->data[1] != '\0')
|
||||
return MODE_REJ;
|
||||
@ -464,7 +464,7 @@ DeflateSetOptsOutput(struct bundle *bundle, struct fsm_opt *o,
|
||||
}
|
||||
|
||||
static int
|
||||
DeflateSetOptsInput(struct bundle *bundle, struct fsm_opt *o,
|
||||
DeflateSetOptsInput(struct bundle *bundle __unused, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg)
|
||||
{
|
||||
int want;
|
||||
@ -486,7 +486,7 @@ DeflateSetOptsInput(struct bundle *bundle, struct fsm_opt *o,
|
||||
}
|
||||
|
||||
static void *
|
||||
DeflateInitInput(struct bundle *bundle, struct fsm_opt *o)
|
||||
DeflateInitInput(struct bundle *bundle __unused, struct fsm_opt *o)
|
||||
{
|
||||
struct deflate_state *state;
|
||||
|
||||
@ -509,7 +509,7 @@ DeflateInitInput(struct bundle *bundle, struct fsm_opt *o)
|
||||
}
|
||||
|
||||
static void *
|
||||
DeflateInitOutput(struct bundle *bundle, struct fsm_opt *o)
|
||||
DeflateInitOutput(struct bundle *bundle __unused, struct fsm_opt *o)
|
||||
{
|
||||
struct deflate_state *state;
|
||||
|
||||
|
@ -168,7 +168,7 @@ GetIpAddr(const char *cp)
|
||||
}
|
||||
|
||||
static const struct speeds {
|
||||
int nspeed;
|
||||
unsigned nspeed;
|
||||
speed_t speed;
|
||||
} speeds[] = {
|
||||
#ifdef B50
|
||||
@ -254,8 +254,8 @@ static const struct speeds {
|
||||
{ 0, 0 }
|
||||
};
|
||||
|
||||
int
|
||||
SpeedToInt(speed_t speed)
|
||||
unsigned
|
||||
SpeedToUnsigned(speed_t speed)
|
||||
{
|
||||
const struct speeds *sp;
|
||||
|
||||
@ -268,7 +268,7 @@ SpeedToInt(speed_t speed)
|
||||
}
|
||||
|
||||
speed_t
|
||||
IntToSpeed(int nspeed)
|
||||
UnsignedToSpeed(unsigned nspeed)
|
||||
{
|
||||
const struct speeds *sp;
|
||||
|
||||
@ -373,7 +373,7 @@ ex_desc(int ex)
|
||||
"redial", "reconnect"
|
||||
};
|
||||
|
||||
if (ex >= 0 && ex < sizeof desc / sizeof *desc)
|
||||
if (ex >= 0 && ex < (int)(sizeof desc / sizeof *desc))
|
||||
return desc[ex];
|
||||
snprintf(num, sizeof num, "%d", ex);
|
||||
return num;
|
||||
@ -405,7 +405,8 @@ zerofdset(fd_set *s)
|
||||
void
|
||||
Concatinate(char *buf, size_t sz, int argc, const char *const *argv)
|
||||
{
|
||||
int i, n, pos;
|
||||
int i, n;
|
||||
unsigned pos;
|
||||
|
||||
*buf = '\0';
|
||||
for (pos = i = 0; i < argc; i++) {
|
||||
@ -419,11 +420,11 @@ Concatinate(char *buf, size_t sz, int argc, const char *const *argv)
|
||||
}
|
||||
}
|
||||
|
||||
#if defined(__FreeBSD__) && !defined(NOKLDLOAD)
|
||||
int
|
||||
loadmodules(int how, const char *module, ...)
|
||||
{
|
||||
int loaded = 0;
|
||||
#if defined(__FreeBSD__) && !defined(NOKLDLOAD)
|
||||
va_list ap;
|
||||
|
||||
va_start(ap, module);
|
||||
@ -438,6 +439,12 @@ loadmodules(int how, const char *module, ...)
|
||||
module = va_arg(ap, const char *);
|
||||
}
|
||||
va_end(ap);
|
||||
#endif
|
||||
return loaded;
|
||||
}
|
||||
#else
|
||||
int
|
||||
loadmodules(int how __unused, const char *module __unused, ...)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
@ -128,8 +128,8 @@ extern ssize_t fullread(int, void *, size_t);
|
||||
extern const char *mode2Nam(int);
|
||||
extern int Nam2mode(const char *);
|
||||
extern struct in_addr GetIpAddr(const char *);
|
||||
extern int SpeedToInt(speed_t);
|
||||
extern speed_t IntToSpeed(int);
|
||||
extern unsigned SpeedToUnsigned(speed_t);
|
||||
extern speed_t UnsignedToSpeed(unsigned);
|
||||
extern char *findblank(char *, int);
|
||||
extern int MakeArgs(char *, char **, int, int);
|
||||
extern const char *NumStr(long, char *, size_t);
|
||||
|
@ -110,7 +110,7 @@ struct etherdevice {
|
||||
#define device2ether(d) \
|
||||
((d)->type == ETHER_DEVICE ? (struct etherdevice *)d : NULL)
|
||||
|
||||
int
|
||||
unsigned
|
||||
ether_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct etherdevice);
|
||||
@ -121,7 +121,7 @@ ether_Write(struct physical *p, const void *v, size_t n)
|
||||
{
|
||||
struct etherdevice *dev = device2ether(p->handler);
|
||||
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : n;
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : (ssize_t)n;
|
||||
}
|
||||
|
||||
static ssize_t
|
||||
@ -191,7 +191,7 @@ ether_Slot(struct physical *p)
|
||||
|
||||
static void
|
||||
ether_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
struct etherdevice *dev = device2ether(d);
|
||||
int sz = physical_MaxDeviceSize();
|
||||
@ -343,7 +343,7 @@ static const struct device baseetherdevice = {
|
||||
|
||||
struct device *
|
||||
ether_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
if (type == ETHER_DEVICE) {
|
||||
struct etherdevice *dev = (struct etherdevice *)iov[(*niov)++].iov_base;
|
||||
@ -443,8 +443,10 @@ ether_Create(struct physical *p)
|
||||
struct ng_mesg *resp;
|
||||
const struct hooklist *hlist;
|
||||
const struct nodeinfo *ninfo;
|
||||
char *path, *sessionid, *mode;
|
||||
int ifacelen, f;
|
||||
char *path, *sessionid;
|
||||
const char *mode;
|
||||
size_t ifacelen;
|
||||
unsigned f;
|
||||
|
||||
dev = NULL;
|
||||
path = NULL;
|
||||
|
@ -34,4 +34,4 @@ struct device;
|
||||
extern struct device *ether_Create(struct physical *);
|
||||
extern struct device *ether_iov2device(int, struct physical *, struct iovec *,
|
||||
int *, int, int *, int *);
|
||||
extern int ether_DeviceSize(void);
|
||||
extern unsigned ether_DeviceSize(void);
|
||||
|
@ -88,7 +88,8 @@ static struct device execdevice = {
|
||||
|
||||
struct device *
|
||||
exec_iov2device(int type, struct physical *p, struct iovec *iov,
|
||||
int *niov, int maxiov, int *auxfd, int *nauxfd)
|
||||
int *niov, int maxiov __unused, int *auxfd __unused,
|
||||
int *nauxfd __unused)
|
||||
{
|
||||
if (type == EXEC_DEVICE) {
|
||||
free(iov[(*niov)++].iov_base);
|
||||
|
@ -70,7 +70,7 @@
|
||||
#include "ncp.h"
|
||||
#include "bundle.h"
|
||||
|
||||
static int filter_Nam2Op(const char *);
|
||||
static unsigned filter_Nam2Op(const char *);
|
||||
|
||||
static int
|
||||
ParsePort(const char *service, const char *proto)
|
||||
@ -96,8 +96,7 @@ ParsePort(const char *service, const char *proto)
|
||||
* ICMP Syntax: src eq icmp_message_type
|
||||
*/
|
||||
static int
|
||||
ParseIcmp(int argc, char const *const *argv, const struct protoent *pe,
|
||||
struct filterent *tgt)
|
||||
ParseIcmp(int argc, char const *const *argv, struct filterent *tgt)
|
||||
{
|
||||
int type;
|
||||
char *cp;
|
||||
@ -189,8 +188,7 @@ ParseUdpOrTcp(int argc, char const *const *argv, const struct protoent *pe,
|
||||
}
|
||||
|
||||
static int
|
||||
ParseGeneric(int argc, char const * const *argv, const struct protoent *pe,
|
||||
struct filterent *tgt)
|
||||
ParseGeneric(int argc, struct filterent *tgt)
|
||||
{
|
||||
/*
|
||||
* Filter currently is a catch-all. Requests are either permitted or
|
||||
@ -382,10 +380,10 @@ filter_Parse(struct ncp *ncp, int argc, char const *const *argv,
|
||||
#ifndef NOINET6
|
||||
case IPPROTO_ICMPV6:
|
||||
#endif
|
||||
val = ParseIcmp(argc, argv, pe, &fe);
|
||||
val = ParseIcmp(argc, argv, &fe);
|
||||
break;
|
||||
default:
|
||||
val = ParseGeneric(argc, argv, pe, &fe);
|
||||
val = ParseGeneric(argc, &fe);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -435,12 +433,12 @@ filter_Set(struct cmdargs const *arg)
|
||||
}
|
||||
|
||||
const char *
|
||||
filter_Action2Nam(int act)
|
||||
filter_Action2Nam(unsigned act)
|
||||
{
|
||||
static const char * const actname[] = { " none ", "permit ", " deny " };
|
||||
static char buf[8];
|
||||
static char buf[8];
|
||||
|
||||
if (act >= 0 && act < MAXFILTERS) {
|
||||
if (act < MAXFILTERS) {
|
||||
snprintf(buf, sizeof buf, "%6d ", act);
|
||||
return buf;
|
||||
} else if (act >= A_NONE && act < A_NONE + sizeof(actname)/sizeof(char *))
|
||||
@ -539,7 +537,7 @@ filter_Show(struct cmdargs const *arg)
|
||||
static const char * const opname[] = {"none", "eq", "gt", "lt"};
|
||||
|
||||
const char *
|
||||
filter_Op2Nam(int op)
|
||||
filter_Op2Nam(unsigned op)
|
||||
{
|
||||
if (op >= sizeof opname / sizeof opname[0])
|
||||
return "unknown";
|
||||
@ -547,10 +545,10 @@ filter_Op2Nam(int op)
|
||||
|
||||
}
|
||||
|
||||
static int
|
||||
static unsigned
|
||||
filter_Nam2Op(const char *cp)
|
||||
{
|
||||
int op;
|
||||
unsigned op;
|
||||
|
||||
for (op = sizeof opname / sizeof opname[0] - 1; op; op--)
|
||||
if (!strcasecmp(cp, opname[op]))
|
||||
|
@ -95,7 +95,7 @@ struct cmdargs;
|
||||
|
||||
extern int filter_Show(struct cmdargs const *);
|
||||
extern int filter_Set(struct cmdargs const *);
|
||||
extern const char * filter_Action2Nam(int);
|
||||
extern const char *filter_Op2Nam(int);
|
||||
extern const char * filter_Action2Nam(unsigned);
|
||||
extern const char *filter_Op2Nam(unsigned);
|
||||
extern void filter_AdjustAddr(struct filter *, struct ncpaddr *,
|
||||
struct ncpaddr *, struct in_addr *);
|
||||
|
@ -185,7 +185,7 @@ NewState(struct fsm *fp, int new)
|
||||
}
|
||||
|
||||
void
|
||||
fsm_Output(struct fsm *fp, u_int code, u_int id, u_char *ptr, int count,
|
||||
fsm_Output(struct fsm *fp, u_int code, u_int id, u_char *ptr, unsigned count,
|
||||
int mtype)
|
||||
{
|
||||
int plen;
|
||||
@ -492,7 +492,7 @@ FsmRecvConfigReq(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
dec.rejend = dec.rej;
|
||||
cp = MBUF_CTOP(bp);
|
||||
(*fp->fn->DecodeConfig)(fp, cp, cp + flen, MODE_REQ, &dec);
|
||||
if (flen < sizeof(struct fsm_opt_hdr))
|
||||
if (flen < (int)sizeof(struct fsm_opt_hdr))
|
||||
log_Printf(fp->LogLevel, " [EMPTY]\n");
|
||||
|
||||
if (dec.nakend == dec.nak && dec.rejend == dec.rej)
|
||||
@ -626,7 +626,7 @@ FsmRecvConfigAck(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
dec.rejend = dec.rej;
|
||||
cp = MBUF_CTOP(bp);
|
||||
(*fp->fn->DecodeConfig)(fp, cp, cp + flen, MODE_ACK, &dec);
|
||||
if (flen < sizeof(struct fsm_opt_hdr))
|
||||
if (flen < (int)sizeof(struct fsm_opt_hdr))
|
||||
log_Printf(fp->LogLevel, " [EMPTY]\n");
|
||||
|
||||
switch (fp->state) {
|
||||
@ -710,7 +710,7 @@ FsmRecvConfigNak(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
dec.rejend = dec.rej;
|
||||
cp = MBUF_CTOP(bp);
|
||||
(*fp->fn->DecodeConfig)(fp, cp, cp + flen, MODE_NAK, &dec);
|
||||
if (flen < sizeof(struct fsm_opt_hdr))
|
||||
if (flen < (int)sizeof(struct fsm_opt_hdr))
|
||||
log_Printf(fp->LogLevel, " [EMPTY]\n");
|
||||
|
||||
switch (fp->state) {
|
||||
@ -771,7 +771,7 @@ FsmRecvTermReq(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvTermAck(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvTermAck(struct fsm *fp, struct fsmheader *lhp __unused, struct mbuf *bp)
|
||||
/* RTA */
|
||||
{
|
||||
switch (fp->state) {
|
||||
@ -803,12 +803,13 @@ FsmRecvConfigRej(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
/* RCJ */
|
||||
{
|
||||
struct fsm_decode dec;
|
||||
int plen, flen;
|
||||
size_t plen;
|
||||
int flen;
|
||||
u_char *cp;
|
||||
|
||||
plen = m_length(bp);
|
||||
flen = ntohs(lhp->length) - sizeof *lhp;
|
||||
if (plen < flen) {
|
||||
if ((int)plen < flen) {
|
||||
m_freem(bp);
|
||||
return;
|
||||
}
|
||||
@ -842,7 +843,7 @@ FsmRecvConfigRej(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
dec.rejend = dec.rej;
|
||||
cp = MBUF_CTOP(bp);
|
||||
(*fp->fn->DecodeConfig)(fp, cp, cp + flen, MODE_REJ, &dec);
|
||||
if (flen < sizeof(struct fsm_opt_hdr))
|
||||
if (flen < (int)sizeof(struct fsm_opt_hdr))
|
||||
log_Printf(fp->LogLevel, " [EMPTY]\n");
|
||||
|
||||
switch (fp->state) {
|
||||
@ -866,13 +867,14 @@ FsmRecvConfigRej(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvCodeRej(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvCodeRej(struct fsm *fp __unused, struct fsmheader *lhp __unused,
|
||||
struct mbuf *bp)
|
||||
{
|
||||
m_freem(bp);
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvProtoRej(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvProtoRej(struct fsm *fp, struct fsmheader *lhp __unused, struct mbuf *bp)
|
||||
{
|
||||
struct physical *p = link2physical(fp->link);
|
||||
u_short proto;
|
||||
@ -972,7 +974,7 @@ FsmRecvEchoReq(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvEchoRep(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvEchoRep(struct fsm *fp, struct fsmheader *lhp __unused, struct mbuf *bp)
|
||||
{
|
||||
if (fsm2lcp(fp))
|
||||
bp = lqr_RecvEcho(fp, bp);
|
||||
@ -981,7 +983,8 @@ FsmRecvEchoRep(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvDiscReq(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvDiscReq(struct fsm *fp __unused, struct fsmheader *lhp __unused,
|
||||
struct mbuf *bp)
|
||||
{
|
||||
m_freem(bp);
|
||||
}
|
||||
@ -1009,7 +1012,8 @@ FsmRecvIdent(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
FsmRecvTimeRemain(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
FsmRecvTimeRemain(struct fsm *fp __unused, struct fsmheader *lhp __unused,
|
||||
struct mbuf *bp)
|
||||
{
|
||||
m_freem(bp);
|
||||
}
|
||||
@ -1039,7 +1043,7 @@ FsmRecvResetAck(struct fsm *fp, struct fsmheader *lhp, struct mbuf *bp)
|
||||
void
|
||||
fsm_Input(struct fsm *fp, struct mbuf *bp)
|
||||
{
|
||||
int len;
|
||||
size_t len;
|
||||
struct fsmheader lh;
|
||||
const struct fsmcodedesc *codep;
|
||||
|
||||
@ -1051,7 +1055,7 @@ fsm_Input(struct fsm *fp, struct mbuf *bp)
|
||||
bp = mbuf_Read(bp, &lh, sizeof lh);
|
||||
|
||||
if (ntohs(lh.length) > len) {
|
||||
log_Printf(LogWARN, "%s: Oops: Got %d bytes but %d byte payload "
|
||||
log_Printf(LogWARN, "%s: Oops: Got %u bytes but %d byte payload "
|
||||
"- dropped\n", fp->link->name, len, (int)ntohs(lh.length));
|
||||
m_freem(bp);
|
||||
return;
|
||||
@ -1099,7 +1103,7 @@ fsm_NullRecvResetReq(struct fsm *fp)
|
||||
}
|
||||
|
||||
void
|
||||
fsm_NullRecvResetAck(struct fsm *fp, u_char id)
|
||||
fsm_NullRecvResetAck(struct fsm *fp, u_char id __unused)
|
||||
{
|
||||
log_Printf(fp->LogLevel, "%s: Oops - received unexpected reset ack\n",
|
||||
fp->link->name);
|
||||
@ -1155,12 +1159,12 @@ fsm_readopt(u_char **cp)
|
||||
static int
|
||||
fsm_opt(u_char *opt, int optlen, const struct fsm_opt *o)
|
||||
{
|
||||
int cplen = o->hdr.len;
|
||||
unsigned cplen = o->hdr.len;
|
||||
|
||||
if (optlen < sizeof(struct fsm_opt_hdr))
|
||||
if (optlen < (int)sizeof(struct fsm_opt_hdr))
|
||||
optlen = 0;
|
||||
|
||||
if (cplen > optlen) {
|
||||
if ((int)cplen > optlen) {
|
||||
log_Printf(LogERROR, "Can't REJ length %d - trunating to %d\n",
|
||||
cplen, optlen);
|
||||
cplen = optlen;
|
||||
|
@ -104,7 +104,7 @@ struct fsm {
|
||||
u_short min_code;
|
||||
u_short max_code;
|
||||
int open_mode; /* Delay before config REQ (-1 forever) */
|
||||
int state; /* State of the machine */
|
||||
unsigned state; /* State of the machine */
|
||||
u_char reqid; /* Next request id */
|
||||
int restart; /* Restart counter value */
|
||||
|
||||
@ -183,7 +183,7 @@ struct fsm_opt {
|
||||
extern void fsm_Init(struct fsm *, const char *, u_short, int, int, int,
|
||||
struct bundle *, struct link *, const struct fsm_parent *,
|
||||
struct fsm_callbacks *, const char * const [3]);
|
||||
extern void fsm_Output(struct fsm *, u_int, u_int, u_char *, int, int);
|
||||
extern void fsm_Output(struct fsm *, u_int, u_int, u_char *, unsigned, int);
|
||||
extern void fsm_Open(struct fsm *);
|
||||
extern void fsm_Up(struct fsm *);
|
||||
extern void fsm_Down(struct fsm *);
|
||||
|
@ -137,15 +137,9 @@ HdlcFcsBuf(u_short fcs, struct mbuf *m)
|
||||
return (fcs);
|
||||
}
|
||||
|
||||
int
|
||||
hdlc_WrapperOctets(struct lcp *lcp, u_short proto)
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
hdlc_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
hdlc_LayerPush(struct bundle *bundle __unused, struct link *l __unused,
|
||||
struct mbuf *bp, int pri __unused, u_short *proto __unused)
|
||||
{
|
||||
struct mbuf *last;
|
||||
u_char *cp;
|
||||
@ -293,7 +287,7 @@ static struct {
|
||||
const char *
|
||||
hdlc_Protocol2Nam(u_short proto)
|
||||
{
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < NPROTOCOLS; f++)
|
||||
if (proto >= protocols[f].from && proto <= protocols[f].to)
|
||||
@ -304,8 +298,8 @@ hdlc_Protocol2Nam(u_short proto)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
hdlc_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
hdlc_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto __unused)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
u_short fcs;
|
||||
@ -364,7 +358,7 @@ static const struct frameheader {
|
||||
};
|
||||
|
||||
int
|
||||
hdlc_Detect(u_char const **cp, int n, int issync)
|
||||
hdlc_Detect(u_char const **cp, unsigned n, int issync)
|
||||
{
|
||||
const struct frameheader *fh;
|
||||
const u_char *h;
|
||||
|
@ -110,7 +110,7 @@ extern void hdlc_DecodePacket(struct bundle *, u_short, struct mbuf *,
|
||||
struct link *);
|
||||
|
||||
extern u_short hdlc_Fcs(u_char *, size_t);
|
||||
extern int hdlc_Detect(u_char const **, int, int);
|
||||
extern int hdlc_WrapperOctets(struct lcp *, u_short);
|
||||
extern int hdlc_Detect(u_char const **, unsigned, int);
|
||||
#define hdlc_WrapperOctets() (2)
|
||||
|
||||
extern struct layer hdlclayer;
|
||||
|
@ -91,7 +91,7 @@ struct i4bdevice {
|
||||
|
||||
#define device2i4b(d) ((d)->type == I4B_DEVICE ? (struct i4bdevice *)d : NULL)
|
||||
|
||||
int
|
||||
unsigned
|
||||
i4b_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct i4bdevice);
|
||||
@ -248,14 +248,14 @@ i4b_Free(struct physical *p)
|
||||
free(dev);
|
||||
}
|
||||
|
||||
static int
|
||||
static unsigned
|
||||
i4b_Speed(struct physical *p)
|
||||
{
|
||||
struct termios ios;
|
||||
int ret;
|
||||
unsigned ret;
|
||||
|
||||
if (tcgetattr(p->fd, &ios) == -1 ||
|
||||
(ret = SpeedToInt(cfgetispeed(&ios))) == 0)
|
||||
(ret = SpeedToUnsigned(cfgetispeed(&ios))) == 0)
|
||||
ret = 64000;
|
||||
|
||||
return ret;
|
||||
@ -288,7 +288,7 @@ i4b_Slot(struct physical *p)
|
||||
|
||||
static void
|
||||
i4b_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
struct i4bdevice *dev = device2i4b(d);
|
||||
int sz = physical_MaxDeviceSize();
|
||||
@ -330,7 +330,7 @@ static struct device basei4bdevice = {
|
||||
|
||||
struct device *
|
||||
i4b_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
if (type == I4B_DEVICE) {
|
||||
struct i4bdevice *dev = (struct i4bdevice *)iov[(*niov)++].iov_base;
|
||||
|
@ -34,4 +34,4 @@ struct device;
|
||||
extern struct device *i4b_Create(struct physical *);
|
||||
extern struct device *i4b_iov2device(int, struct physical *,
|
||||
struct iovec *, int *, int, int *, int *);
|
||||
extern int i4b_DeviceSize(void);
|
||||
extern unsigned i4b_DeviceSize(void);
|
||||
|
@ -373,7 +373,8 @@ iface_addr_Add(const char *name, struct iface_addr *addr, int s)
|
||||
void
|
||||
iface_Clear(struct iface *iface, struct ncp *ncp, int family, int how)
|
||||
{
|
||||
int addrs, af, inskip, in6skip, n, s4 = -1, s6 = -1, *s;
|
||||
int addrs, af, inskip, in6skip, s4 = -1, s6 = -1, *s;
|
||||
unsigned n;
|
||||
|
||||
if (iface->addrs) {
|
||||
inskip = in6skip = how == IFACE_CLEAR_ALL ? 0 : 1;
|
||||
@ -431,7 +432,8 @@ int
|
||||
iface_Add(struct iface *iface, struct ncp *ncp, const struct ncprange *ifa,
|
||||
const struct ncpaddr *peer, int how)
|
||||
{
|
||||
int af, n, removed, s;
|
||||
int af, removed, s;
|
||||
unsigned n;
|
||||
struct ncpaddr ncplocal;
|
||||
struct iface_addr *addr, newaddr;
|
||||
|
||||
@ -515,7 +517,8 @@ int
|
||||
iface_Delete(struct iface *iface, struct ncp *ncp, const struct ncpaddr *del)
|
||||
{
|
||||
struct ncpaddr found;
|
||||
int n, res, s;
|
||||
unsigned n;
|
||||
int res, s;
|
||||
|
||||
if ((s = ID0socket(ncpaddr_family(del), SOCK_DGRAM, 0)) == -1) {
|
||||
log_Printf(LogERROR, "iface_Delete: socket(): %s\n", strerror(errno));
|
||||
@ -642,7 +645,8 @@ iface_Show(struct cmdargs const *arg)
|
||||
{
|
||||
struct ncpaddr ncpaddr;
|
||||
struct iface *iface = arg->bundle->iface, *current;
|
||||
int f, flags;
|
||||
unsigned f;
|
||||
int flags;
|
||||
#ifndef NOINET6
|
||||
int scopeid, width;
|
||||
#endif
|
||||
@ -666,7 +670,7 @@ iface_Show(struct cmdargs const *arg)
|
||||
flags);
|
||||
#endif
|
||||
|
||||
prompt_Printf(arg->prompt, "> mtu %d has %d address%s:\n", iface->mtu,
|
||||
prompt_Printf(arg->prompt, "> mtu %lu has %d address%s:\n", iface->mtu,
|
||||
iface->addrs, iface->addrs == 1 ? "" : "es");
|
||||
|
||||
for (f = 0; f < iface->addrs; f++) {
|
||||
|
@ -38,9 +38,9 @@ struct iface {
|
||||
char *name; /* Interface name (malloc'd) */
|
||||
int index; /* Interface index */
|
||||
int flags; /* Interface flags (IFF_*) */
|
||||
int mtu; /* struct tuninfo MTU */
|
||||
unsigned long mtu; /* struct tuninfo MTU */
|
||||
|
||||
int addrs; /* How many in_addr's */
|
||||
unsigned addrs; /* How many in_addr's */
|
||||
struct iface_addr *addr; /* Array of addresses (malloc'd) */
|
||||
};
|
||||
|
||||
|
@ -110,7 +110,7 @@ dns_Qclass2Txt(u_short qclass)
|
||||
/* rfc1035 */
|
||||
{ 1, "IN" }, { 2, "CS" }, { 3, "CH" }, { 4, "HS" }, { 255, "*" }
|
||||
};
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < sizeof qtxt / sizeof *qtxt; f++)
|
||||
if (qtxt[f].id == qclass)
|
||||
@ -137,7 +137,7 @@ dns_Qtype2Txt(u_short qtype)
|
||||
{ 27, "GPOS" }, { 28, "AAAA" }, { 252, "AXFR" }, { 253, "MAILB" },
|
||||
{ 254, "MAILA" }, { 255, "*" }
|
||||
};
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < sizeof qtxt / sizeof *qtxt; f++)
|
||||
if (qtxt[f].id == qtype)
|
||||
@ -494,7 +494,7 @@ ip_LogDNS(const struct udphdr *uh, const char *direction)
|
||||
const u_short *pktptr;
|
||||
const u_char *ptr;
|
||||
u_short *hptr, tmp;
|
||||
int len;
|
||||
unsigned len;
|
||||
|
||||
ptr = (const char *)uh + sizeof *uh;
|
||||
len = ntohs(uh->uh_ulen) - sizeof *uh;
|
||||
@ -519,11 +519,11 @@ ip_LogDNS(const struct udphdr *uh, const char *direction)
|
||||
|
||||
n = namewithdot;
|
||||
end = ptr + len - 4;
|
||||
if (end - ptr >= sizeof namewithdot)
|
||||
if (end - ptr >= (int)sizeof namewithdot)
|
||||
end = ptr + sizeof namewithdot - 1;
|
||||
while (ptr < end) {
|
||||
len = *ptr++;
|
||||
if (len > end - ptr)
|
||||
if ((int)len > end - ptr)
|
||||
len = end - ptr;
|
||||
if (n != namewithdot)
|
||||
*n++ = '.';
|
||||
@ -554,6 +554,7 @@ PacketCheck(struct bundle *bundle, u_int32_t family,
|
||||
const unsigned char *packet, int nb, struct filter *filter,
|
||||
const char *prefix, unsigned *psecs)
|
||||
{
|
||||
char logbuf[200];
|
||||
static const char *const TcpFlags[] = {
|
||||
"FIN", "SYN", "RST", "PSH", "ACK", "URG"
|
||||
};
|
||||
@ -565,9 +566,8 @@ PacketCheck(struct bundle *bundle, u_int32_t family,
|
||||
#endif
|
||||
const unsigned char *payload;
|
||||
struct ncpaddr srcaddr, dstaddr;
|
||||
int cproto, mask, len, n, pri, logit, loglen, result;
|
||||
char logbuf[200];
|
||||
int datalen, frag;
|
||||
int cproto, mask, len, n, pri, logit, result, datalen, frag;
|
||||
unsigned loglen;
|
||||
u_char tos;
|
||||
|
||||
logit = (log_IsKept(LogTCPIP) || log_IsKept(LogDNS)) &&
|
||||
@ -764,6 +764,7 @@ PacketCheck(struct bundle *bundle, u_int32_t family,
|
||||
snprintf(logbuf + loglen, sizeof logbuf - loglen, " contains ");
|
||||
result = PacketCheck(bundle, AF_INET, payload, nb - (payload - packet),
|
||||
filter, logbuf, psecs);
|
||||
loglen += strlen(logbuf + loglen);
|
||||
if (result != -2)
|
||||
return result;
|
||||
}
|
||||
@ -896,10 +897,11 @@ PacketCheck(struct bundle *bundle, u_int32_t family,
|
||||
return result;
|
||||
}
|
||||
|
||||
static int
|
||||
static size_t
|
||||
ip_Input(struct bundle *bundle, struct link *l, struct mbuf *bp, u_int32_t af)
|
||||
{
|
||||
int nb, nw;
|
||||
ssize_t nw;
|
||||
size_t nb;
|
||||
struct tun_data tun;
|
||||
char *data;
|
||||
unsigned secs, alivesecs;
|
||||
@ -933,7 +935,7 @@ ip_Input(struct bundle *bundle, struct link *l, struct mbuf *bp, u_int32_t af)
|
||||
data = tun.data;
|
||||
|
||||
nw = write(bundle->dev.fd, data, nb);
|
||||
if (nw != nb) {
|
||||
if (nw != (ssize_t)nb) {
|
||||
if (nw == -1)
|
||||
log_Printf(LogERROR, "ip_Input: %s: wrote %d, got %s\n",
|
||||
l->name, nb, strerror(errno));
|
||||
|
@ -148,7 +148,7 @@ protoname(int proto)
|
||||
{ 131, "SECDNS" }, /* 131: Secondary DNS Server Address */
|
||||
{ 132, "SECNBNS" } /* 132: Secondary NBNS Server Address */
|
||||
};
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < sizeof cftypes / sizeof *cftypes; f++)
|
||||
if (cftypes[f].id == proto)
|
||||
@ -319,8 +319,7 @@ void
|
||||
ipcp_RestoreDNS(struct ipcp *ipcp)
|
||||
{
|
||||
if (ipcp->ns.resolver) {
|
||||
ssize_t got;
|
||||
size_t len;
|
||||
ssize_t got, len;
|
||||
int fd;
|
||||
|
||||
if ((fd = ID0open(_PATH_RESCONF, O_WRONLY|O_TRUNC, 0644)) != -1) {
|
||||
@ -330,8 +329,8 @@ ipcp_RestoreDNS(struct ipcp *ipcp)
|
||||
log_Printf(LogERROR, "Failed rewriting %s: write: %s\n",
|
||||
_PATH_RESCONF, strerror(errno));
|
||||
else
|
||||
log_Printf(LogERROR, "Failed rewriting %s: wrote %lu of %lu\n",
|
||||
_PATH_RESCONF, (unsigned long)got, (unsigned long)len);
|
||||
log_Printf(LogERROR, "Failed rewriting %s: wrote %ld of %ld\n",
|
||||
_PATH_RESCONF, (long)got, (long)len);
|
||||
}
|
||||
close(fd);
|
||||
} else
|
||||
@ -511,7 +510,8 @@ ipcp_Setup(struct ipcp *ipcp, u_int32_t mask)
|
||||
struct iface *iface = ipcp->fsm.bundle->iface;
|
||||
struct ncpaddr ipaddr;
|
||||
struct in_addr peer;
|
||||
int pos, n;
|
||||
int pos;
|
||||
unsigned n;
|
||||
|
||||
ipcp->fsm.open_mode = 0;
|
||||
ipcp->ifmask.s_addr = mask == INADDR_NONE ? ipcp->cfg.netmask.s_addr : mask;
|
||||
@ -605,24 +605,18 @@ numaddresses(struct in_addr mask)
|
||||
|
||||
static int
|
||||
ipcp_proxyarp(struct ipcp *ipcp,
|
||||
int (*proxyfun)(struct bundle *, struct in_addr, int),
|
||||
int (*proxyfun)(struct bundle *, struct in_addr),
|
||||
const struct iface_addr *addr)
|
||||
{
|
||||
struct bundle *bundle = ipcp->fsm.bundle;
|
||||
struct in_addr peer, mask, ip;
|
||||
int n, ret, s;
|
||||
int n, ret;
|
||||
|
||||
if (!ncpaddr_getip4(&addr->peer, &peer)) {
|
||||
log_Printf(LogERROR, "Oops, ipcp_proxyarp() called with unexpected addr\n");
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ((s = ID0socket(PF_INET, SOCK_DGRAM, 0)) == -1) {
|
||||
log_Printf(LogERROR, "ipcp_proxyarp: socket: %s\n",
|
||||
strerror(errno));
|
||||
return 0;
|
||||
}
|
||||
|
||||
ret = 0;
|
||||
|
||||
if (Enabled(bundle, OPT_PROXYALL)) {
|
||||
@ -639,7 +633,7 @@ ipcp_proxyarp(struct ipcp *ipcp,
|
||||
}
|
||||
while (n) {
|
||||
if (!((ip.s_addr ^ peer.s_addr) & mask.s_addr)) {
|
||||
if (!(ret = (*proxyfun)(bundle, ip, s)))
|
||||
if (!(ret = (*proxyfun)(bundle, ip)))
|
||||
break;
|
||||
n--;
|
||||
}
|
||||
@ -647,9 +641,7 @@ ipcp_proxyarp(struct ipcp *ipcp,
|
||||
}
|
||||
ret = !n;
|
||||
} else if (Enabled(bundle, OPT_PROXY))
|
||||
ret = (*proxyfun)(bundle, peer, s);
|
||||
|
||||
close(s);
|
||||
ret = (*proxyfun)(bundle, peer);
|
||||
|
||||
return ret;
|
||||
}
|
||||
@ -798,7 +790,7 @@ IpcpSendConfigReq(struct fsm *fp)
|
||||
}
|
||||
|
||||
static void
|
||||
IpcpSentTerminateReq(struct fsm *fp)
|
||||
IpcpSentTerminateReq(struct fsm *fp __unused)
|
||||
{
|
||||
/* Term REQ just sent by FSM */
|
||||
}
|
||||
@ -974,7 +966,7 @@ ipcp_ValidateReq(struct ipcp *ipcp, struct in_addr ip, struct fsm_decode *dec)
|
||||
struct bundle *bundle = ipcp->fsm.bundle;
|
||||
struct iface *iface = bundle->iface;
|
||||
struct in_addr myaddr, peer;
|
||||
int n;
|
||||
unsigned n;
|
||||
|
||||
if (iplist_isvalid(&ipcp->cfg.peer_list)) {
|
||||
ncprange_getip4addr(&ipcp->cfg.my_range, &myaddr);
|
||||
@ -1060,7 +1052,7 @@ IpcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
|
||||
gotdnsnak = 0;
|
||||
|
||||
while (end - cp >= sizeof(opt->hdr)) {
|
||||
while (end - cp >= (int)sizeof(opt->hdr)) {
|
||||
if ((opt = fsm_readopt(&cp)) == NULL)
|
||||
break;
|
||||
|
||||
@ -1102,7 +1094,7 @@ IpcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
|
||||
case TY_COMPPROTO:
|
||||
pcomp = (struct compreq *)opt->data;
|
||||
compproto = (ntohs(pcomp->proto) << 16) + (pcomp->slots << 8) +
|
||||
compproto = (ntohs(pcomp->proto) << 16) + ((int)pcomp->slots << 8) +
|
||||
pcomp->compcid;
|
||||
log_Printf(LogIPCP, "%s %s\n", tbuff, vj2asc(compproto));
|
||||
|
||||
@ -1129,8 +1121,8 @@ IpcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
break;
|
||||
case 6: /* RFC1332 */
|
||||
if (ntohs(pcomp->proto) == PROTO_VJCOMP) {
|
||||
if (pcomp->slots <= MAX_VJ_STATES
|
||||
&& pcomp->slots >= MIN_VJ_STATES) {
|
||||
/* We know pcomp->slots' max value == MAX_VJ_STATES */
|
||||
if (pcomp->slots >= MIN_VJ_STATES) {
|
||||
/* Ok, we can do that */
|
||||
ipcp->peer_compproto = compproto;
|
||||
ipcp->heis1172 = 0;
|
||||
@ -1138,8 +1130,7 @@ IpcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
} else {
|
||||
/* Get as close as we can to what he wants */
|
||||
ipcp->heis1172 = 0;
|
||||
pcomp->slots = pcomp->slots < MIN_VJ_STATES ?
|
||||
MIN_VJ_STATES : MAX_VJ_STATES;
|
||||
pcomp->slots = MIN_VJ_STATES;
|
||||
nak.hdr.id = TY_COMPPROTO;
|
||||
nak.hdr.len = 4;
|
||||
memcpy(nak.data, &pcomp, 2);
|
||||
@ -1165,9 +1156,8 @@ IpcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
|
||||
case MODE_NAK:
|
||||
if (ntohs(pcomp->proto) == PROTO_VJCOMP) {
|
||||
if (pcomp->slots > MAX_VJ_STATES)
|
||||
pcomp->slots = MAX_VJ_STATES;
|
||||
else if (pcomp->slots < MIN_VJ_STATES)
|
||||
/* We know pcomp->slots' max value == MAX_VJ_STATES */
|
||||
if (pcomp->slots < MIN_VJ_STATES)
|
||||
pcomp->slots = MIN_VJ_STATES;
|
||||
compproto = (ntohs(pcomp->proto) << 16) + (pcomp->slots << 8) +
|
||||
pcomp->compcid;
|
||||
|
@ -172,7 +172,7 @@ iplist_reset(struct iplist *list)
|
||||
struct in_addr
|
||||
iplist_setcurpos(struct iplist *list, long pos)
|
||||
{
|
||||
if (pos < 0 || pos >= list->nItems) {
|
||||
if (pos < 0 || (unsigned)pos >= list->nItems) {
|
||||
list->cur.pos = -1;
|
||||
list->cur.ip.s_addr = INADDR_ANY;
|
||||
return list->cur.ip;
|
||||
@ -182,7 +182,7 @@ iplist_setcurpos(struct iplist *list, long pos)
|
||||
list->cur.pos = 0;
|
||||
while (1) {
|
||||
iplist_nextrange(list);
|
||||
if (pos < list->cur.nItems) {
|
||||
if (pos < (int)list->cur.nItems) {
|
||||
if (pos) {
|
||||
list->cur.srcitem = pos;
|
||||
list->cur.pos += pos;
|
||||
|
@ -375,12 +375,14 @@ ipv6cp_AddOutOctets(struct ipv6cp *ipv6cp, int n)
|
||||
}
|
||||
|
||||
void
|
||||
ipv6cp_IfaceAddrAdded(struct ipv6cp *ipv6cp, const struct iface_addr *addr)
|
||||
ipv6cp_IfaceAddrAdded(struct ipv6cp *ipv6cp __unused,
|
||||
const struct iface_addr *addr __unused)
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
ipv6cp_IfaceAddrDeleted(struct ipv6cp *ipv6cp, const struct iface_addr *addr)
|
||||
ipv6cp_IfaceAddrDeleted(struct ipv6cp *ipv6cp __unused,
|
||||
const struct iface_addr *addr __unused)
|
||||
{
|
||||
}
|
||||
|
||||
@ -629,7 +631,7 @@ ipv6cp_SendConfigReq(struct fsm *fp)
|
||||
}
|
||||
|
||||
static void
|
||||
ipv6cp_SentTerminateReq(struct fsm *fp)
|
||||
ipv6cp_SentTerminateReq(struct fsm *fp __unused)
|
||||
{
|
||||
/* Term REQ just sent by FSM */
|
||||
}
|
||||
@ -642,7 +644,7 @@ ipv6cp_SendTerminateAck(struct fsm *fp, u_char id)
|
||||
}
|
||||
|
||||
static const char *
|
||||
protoname(int proto)
|
||||
protoname(unsigned proto)
|
||||
{
|
||||
static const char *cftypes[] = { "IFACEID", "COMPPROTO" };
|
||||
|
||||
@ -687,7 +689,7 @@ ipv6cp_DecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
|
||||
memset(zero, 0, IPV6CP_IFIDLEN);
|
||||
|
||||
while (end - cp >= sizeof(opt->hdr)) {
|
||||
while (end - cp >= (int)sizeof(opt->hdr)) {
|
||||
if ((opt = fsm_readopt(&cp)) == NULL)
|
||||
break;
|
||||
|
||||
|
@ -116,7 +116,7 @@ static const char * const lcp_TimerNames[] =
|
||||
{"LCP restart", "LCP openmode", "LCP stopped"};
|
||||
|
||||
static const char *
|
||||
protoname(int proto)
|
||||
protoname(unsigned proto)
|
||||
{
|
||||
static const char * const cftypes[] = {
|
||||
/* Check out the latest ``Assigned numbers'' rfc (1700) */
|
||||
@ -146,8 +146,7 @@ protoname(int proto)
|
||||
"LDBACP", /* 23: Link Discriminator for BACP */
|
||||
};
|
||||
|
||||
if (proto < 0 || proto > sizeof cftypes / sizeof *cftypes ||
|
||||
cftypes[proto] == NULL)
|
||||
if (proto > sizeof cftypes / sizeof *cftypes || cftypes[proto] == NULL)
|
||||
return HexStr(proto, NULL, 0);
|
||||
|
||||
return cftypes[proto];
|
||||
@ -453,11 +452,11 @@ LcpSendConfigReq(struct fsm *fp)
|
||||
*o->data = CALLBACK_CBCP;
|
||||
INC_FSM_OPT(TY_CALLBACK, 3, o);
|
||||
} else if (lcp->want_callback.opmask & CALLBACK_BIT(CALLBACK_E164)) {
|
||||
int sz = strlen(lcp->want_callback.msg);
|
||||
size_t sz = strlen(lcp->want_callback.msg);
|
||||
|
||||
if (sz > sizeof o->data - 1) {
|
||||
sz = sizeof o->data - 1;
|
||||
log_Printf(LogWARN, "Truncating E164 data to %d octets (oops!)\n", sz);
|
||||
log_Printf(LogWARN, "Truncating E164 data to %u octets (oops!)\n", sz);
|
||||
}
|
||||
*o->data = CALLBACK_E164;
|
||||
memcpy(o->data + 1, lcp->want_callback.msg, sz);
|
||||
@ -529,7 +528,7 @@ lcp_RecvIdentification(struct lcp *lcp, char *data)
|
||||
}
|
||||
|
||||
static void
|
||||
LcpSentTerminateReq(struct fsm *fp)
|
||||
LcpSentTerminateReq(struct fsm *fp __unused)
|
||||
{
|
||||
/* Term REQ just sent by FSM */
|
||||
}
|
||||
@ -658,7 +657,8 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
{
|
||||
/* Deal with incoming PROTO_LCP */
|
||||
struct lcp *lcp = fsm2lcp(fp);
|
||||
int sz, pos, op, callback_req, chap_type;
|
||||
int pos, op, callback_req, chap_type;
|
||||
size_t sz;
|
||||
u_int32_t magic, accmap;
|
||||
u_short mru, phmtu, maxmtu, maxmru, wantmtu, wantmru, proto;
|
||||
struct lqrreq *req;
|
||||
@ -667,9 +667,10 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
struct physical *p = link2physical(fp->link);
|
||||
struct fsm_opt *opt, nak;
|
||||
|
||||
sz = op = callback_req = 0;
|
||||
sz = 0;
|
||||
op = callback_req = 0;
|
||||
|
||||
while (end - cp >= sizeof(opt->hdr)) {
|
||||
while (end - cp >= (int)sizeof(opt->hdr)) {
|
||||
if ((opt = fsm_readopt(&cp)) == NULL)
|
||||
break;
|
||||
|
||||
@ -1055,11 +1056,13 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
break;
|
||||
|
||||
case TY_CALLBACK:
|
||||
if (opt->hdr.len == 2)
|
||||
if (opt->hdr.len == 2) {
|
||||
op = CALLBACK_NONE;
|
||||
else
|
||||
sz = 0;
|
||||
} else {
|
||||
op = (int)opt->data[0];
|
||||
sz = opt->hdr.len - 3;
|
||||
sz = opt->hdr.len - 3;
|
||||
}
|
||||
switch (op) {
|
||||
case CALLBACK_AUTH:
|
||||
log_Printf(LogLCP, "%s Auth\n", request);
|
||||
@ -1101,7 +1104,7 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
lcp->his_callback.opmask = CALLBACK_BIT(op);
|
||||
if (sz > sizeof lcp->his_callback.msg - 1) {
|
||||
sz = sizeof lcp->his_callback.msg - 1;
|
||||
log_Printf(LogWARN, "Truncating option arg to %d octets\n", sz);
|
||||
log_Printf(LogWARN, "Truncating option arg to %u octets\n", sz);
|
||||
}
|
||||
memcpy(lcp->his_callback.msg, opt->data + 1, sz);
|
||||
lcp->his_callback.msg[sz] = '\0';
|
||||
@ -1194,7 +1197,7 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
} else if (!IsAccepted(mp->cfg.negenddisc)) {
|
||||
lcp->my_reject |= (1 << opt->hdr.id);
|
||||
fsm_rej(dec, opt);
|
||||
} else if (opt->hdr.len - 3 < sizeof p->dl->peer.enddisc.address &&
|
||||
} else if (opt->hdr.len < sizeof p->dl->peer.enddisc.address + 3 &&
|
||||
opt->data[0] <= MAX_ENDDISC_CLASS) {
|
||||
p->dl->peer.enddisc.class = opt->data[0];
|
||||
p->dl->peer.enddisc.len = opt->hdr.len - 3;
|
||||
@ -1223,7 +1226,7 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
|
||||
default:
|
||||
sz = (sizeof desc - 2) / 2;
|
||||
if (sz > opt->hdr.len - 2)
|
||||
if (sz + 2 > opt->hdr.len)
|
||||
sz = opt->hdr.len - 2;
|
||||
pos = 0;
|
||||
desc[0] = sz ? ' ' : '\0';
|
||||
@ -1283,7 +1286,7 @@ LcpDecodeConfig(struct fsm *fp, u_char *cp, u_char *end, int mode_type,
|
||||
}
|
||||
|
||||
extern struct mbuf *
|
||||
lcp_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
lcp_Input(struct bundle *bundle __unused, struct link *l, struct mbuf *bp)
|
||||
{
|
||||
/* Got PROTO_LCP from link */
|
||||
m_settype(bp, MB_LCPIN);
|
||||
|
@ -118,7 +118,7 @@ link_DeleteQueue(struct link *l)
|
||||
size_t
|
||||
link_QueueLen(struct link *l)
|
||||
{
|
||||
int i;
|
||||
unsigned i;
|
||||
size_t len;
|
||||
|
||||
for (i = 0, len = 0; i < LINK_QUEUES(l); i++)
|
||||
@ -130,7 +130,7 @@ link_QueueLen(struct link *l)
|
||||
size_t
|
||||
link_QueueBytes(struct link *l)
|
||||
{
|
||||
int i;
|
||||
unsigned i;
|
||||
size_t len, bytes;
|
||||
struct mbuf *m;
|
||||
|
||||
@ -257,7 +257,7 @@ link_PushPacket(struct link *l, struct mbuf *bp, struct bundle *b, int pri,
|
||||
* packet (as we do with ``pull''s).
|
||||
*/
|
||||
|
||||
if(pri < 0 || pri >= LINK_QUEUES(l))
|
||||
if(pri < 0 || (unsigned)pri >= LINK_QUEUES(l))
|
||||
pri = 0;
|
||||
|
||||
bp->priv = 0; /* Adjusted by the async layer ! */
|
||||
@ -372,7 +372,7 @@ static const struct {
|
||||
static void
|
||||
Despatch(struct bundle *bundle, struct link *l, struct mbuf *bp, u_short proto)
|
||||
{
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < DSIZE; f++)
|
||||
if (despatcher[f].proto == proto) {
|
||||
|
@ -127,7 +127,7 @@ void
|
||||
lqr_ChangeOrder(struct lqrdata *src, struct lqrdata *dst)
|
||||
{
|
||||
u_int32_t *sp, *dp;
|
||||
int n;
|
||||
unsigned n;
|
||||
|
||||
sp = (u_int32_t *) src;
|
||||
dp = (u_int32_t *) dst;
|
||||
@ -198,7 +198,7 @@ SendLqrReport(void *v)
|
||||
}
|
||||
|
||||
struct mbuf *
|
||||
lqr_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
lqr_Input(struct bundle *bundle __unused, struct link *l, struct mbuf *bp)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
struct lcp *lcp = p->hdlc.lqm.owner;
|
||||
@ -411,8 +411,8 @@ lqr_Analyse(const struct hdlc *hdlc, const struct lqrdata *oldlqr,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
lqr_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
lqr_LayerPush(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
int len, layer, extra_async_bytes;
|
||||
@ -455,7 +455,7 @@ lqr_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
/* Not included - see rfc1989 */
|
||||
break;
|
||||
case LAYER_HDLC:
|
||||
p->hdlc.lqm.ifOutOctets += hdlc_WrapperOctets(&l->lcp, *proto);
|
||||
p->hdlc.lqm.ifOutOctets += hdlc_WrapperOctets();
|
||||
break;
|
||||
case LAYER_LQR:
|
||||
layer = l->nlayers;
|
||||
@ -508,7 +508,8 @@ lqr_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
lqr_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp, u_short *proto)
|
||||
lqr_LayerPull(struct bundle *b __unused, struct link *l __unused,
|
||||
struct mbuf *bp, u_short *proto)
|
||||
{
|
||||
/*
|
||||
* This is the ``Rx'' process from rfc1989, although a part of it is
|
||||
|
@ -109,7 +109,7 @@ static struct bundle *SignalBundle;
|
||||
static struct prompt *SignalPrompt;
|
||||
|
||||
void
|
||||
Cleanup(int excode)
|
||||
Cleanup()
|
||||
{
|
||||
SignalBundle->CleaningUp = 1;
|
||||
bundle_Close(SignalBundle, NULL, CLOSE_STAYDOWN);
|
||||
@ -143,7 +143,7 @@ static void
|
||||
CloseSession(int signo)
|
||||
{
|
||||
log_Printf(LogPHASE, "Signal %d, terminate.\n", signo);
|
||||
Cleanup(EX_TERM);
|
||||
Cleanup();
|
||||
}
|
||||
|
||||
static pid_t BGPid = 0;
|
||||
@ -157,14 +157,14 @@ KillChild(int signo)
|
||||
}
|
||||
|
||||
static void
|
||||
TerminalCont(int signo)
|
||||
TerminalCont(int signo __unused)
|
||||
{
|
||||
signal(SIGCONT, SIG_DFL);
|
||||
prompt_Continue(SignalPrompt);
|
||||
}
|
||||
|
||||
static void
|
||||
TerminalStop(int signo)
|
||||
TerminalStop(int signo __unused)
|
||||
{
|
||||
prompt_Suspend(SignalPrompt);
|
||||
signal(SIGCONT, TerminalCont);
|
||||
@ -172,7 +172,7 @@ TerminalStop(int signo)
|
||||
}
|
||||
|
||||
static void
|
||||
BringDownServer(int signo)
|
||||
BringDownServer(int signo __unused)
|
||||
{
|
||||
/* Drops all child prompts too ! */
|
||||
if (server_Close(SignalBundle))
|
||||
@ -180,7 +180,7 @@ BringDownServer(int signo)
|
||||
}
|
||||
|
||||
static void
|
||||
RestartServer(int signo)
|
||||
RestartServer(int signo __unused)
|
||||
{
|
||||
/* Drops all child prompts and re-opens the socket */
|
||||
server_Reopen(SignalBundle);
|
||||
@ -302,7 +302,8 @@ main(int argc, char **argv)
|
||||
{
|
||||
char *name;
|
||||
const char *lastlabel;
|
||||
int arg, f, holdfd[3], label;
|
||||
int arg, holdfd[3], label;
|
||||
unsigned f;
|
||||
struct bundle *bundle;
|
||||
struct prompt *prompt;
|
||||
struct switches sw;
|
||||
|
@ -28,5 +28,5 @@
|
||||
* $FreeBSD$
|
||||
*/
|
||||
|
||||
extern void Cleanup(int);
|
||||
extern void Cleanup(void);
|
||||
extern void AbortProgram(int);
|
||||
|
@ -74,10 +74,10 @@ static struct memmap {
|
||||
|
||||
static unsigned long long mbuf_Mallocs, mbuf_Frees;
|
||||
|
||||
int
|
||||
size_t
|
||||
m_length(struct mbuf *bp)
|
||||
{
|
||||
int len;
|
||||
size_t len;
|
||||
|
||||
for (len = 0; bp; bp = bp->m_next)
|
||||
len += bp->m_len;
|
||||
@ -240,7 +240,7 @@ mbuf_View(struct mbuf *bp, void *v, size_t len)
|
||||
}
|
||||
|
||||
struct mbuf *
|
||||
m_prepend(struct mbuf *bp, const void *ptr, size_t len, size_t extra)
|
||||
m_prepend(struct mbuf *bp, const void *ptr, size_t len, u_short extra)
|
||||
{
|
||||
struct mbuf *head;
|
||||
|
||||
@ -274,7 +274,7 @@ m_adj(struct mbuf *bp, ssize_t n)
|
||||
{
|
||||
if (n > 0) {
|
||||
while (bp) {
|
||||
if (n < bp->m_len) {
|
||||
if ((size_t)n < bp->m_len) {
|
||||
bp->m_len = n;
|
||||
bp->m_offset += n;
|
||||
return bp;
|
||||
@ -288,7 +288,7 @@ m_adj(struct mbuf *bp, ssize_t n)
|
||||
return NULL;
|
||||
}
|
||||
for (; bp; bp = bp->m_next, n -= bp->m_len)
|
||||
if (n < bp->m_len) {
|
||||
if ((size_t)n < bp->m_len) {
|
||||
bp->m_len = n;
|
||||
m_freem(bp->m_next);
|
||||
bp->m_next = NULL;
|
||||
@ -302,7 +302,7 @@ m_adj(struct mbuf *bp, ssize_t n)
|
||||
void
|
||||
mbuf_Write(struct mbuf *bp, const void *ptr, size_t m_len)
|
||||
{
|
||||
int plen;
|
||||
size_t plen;
|
||||
int nb;
|
||||
|
||||
plen = m_length(bp);
|
||||
|
@ -30,7 +30,7 @@
|
||||
|
||||
struct mbuf {
|
||||
size_t m_size; /* size allocated (excluding header) */
|
||||
short m_offset; /* offset from header end to start position */
|
||||
u_short m_offset; /* offset from header end to start position */
|
||||
size_t m_len; /* available byte count in buffer */
|
||||
short m_type; /* MB_* below */
|
||||
struct mbuf *m_next; /* link to next mbuf */
|
||||
@ -46,10 +46,10 @@ struct mqueue {
|
||||
};
|
||||
|
||||
#define MBUF_CTOP(bp) \
|
||||
((bp) ? (u_char *)((bp)+1) + (bp)->m_offset : NULL)
|
||||
((bp) ? (u_char *)((bp)+1) + (bp)->m_offset : (u_char *)bp)
|
||||
|
||||
#define CONST_MBUF_CTOP(bp) \
|
||||
((bp) ? (const u_char *)((bp)+1) + (bp)->m_offset : NULL)
|
||||
((bp) ? (const u_char *)((bp)+1) + (bp)->m_offset : (const u_char *)bp)
|
||||
|
||||
#define MB_IPIN 0
|
||||
#define MB_IPOUT 1
|
||||
@ -100,14 +100,14 @@ struct mqueue {
|
||||
|
||||
struct cmdargs;
|
||||
|
||||
extern int m_length(struct mbuf *);
|
||||
extern size_t m_length(struct mbuf *);
|
||||
extern struct mbuf *m_get(size_t, int);
|
||||
extern struct mbuf *m_free(struct mbuf *);
|
||||
extern void m_freem(struct mbuf *);
|
||||
extern void mbuf_Write(struct mbuf *, const void *, size_t);
|
||||
extern struct mbuf *mbuf_Read(struct mbuf *, void *, size_t);
|
||||
extern size_t mbuf_View(struct mbuf *, void *, size_t);
|
||||
extern struct mbuf *m_prepend(struct mbuf *, const void *, size_t, size_t);
|
||||
extern struct mbuf *m_prepend(struct mbuf *, const void *, size_t, u_short);
|
||||
extern struct mbuf *m_adj(struct mbuf *, ssize_t);
|
||||
extern struct mbuf *m_pullup(struct mbuf *);
|
||||
extern void m_settype(struct mbuf *, int);
|
||||
|
@ -161,13 +161,13 @@ mp_ReadHeader(struct mp *mp, struct mbuf *m, struct mp_header *header)
|
||||
}
|
||||
|
||||
static void
|
||||
mp_LayerStart(void *v, struct fsm *fp)
|
||||
mp_LayerStart(void *v __unused, struct fsm *fp __unused)
|
||||
{
|
||||
/* The given FSM (ccp) is about to start up ! */
|
||||
}
|
||||
|
||||
static void
|
||||
mp_LayerUp(void *v, struct fsm *fp)
|
||||
mp_LayerUp(void *v __unused, struct fsm *fp)
|
||||
{
|
||||
/* The given fsm (ccp) is now up */
|
||||
|
||||
@ -175,13 +175,13 @@ mp_LayerUp(void *v, struct fsm *fp)
|
||||
}
|
||||
|
||||
static void
|
||||
mp_LayerDown(void *v, struct fsm *fp)
|
||||
mp_LayerDown(void *v __unused, struct fsm *fp __unused)
|
||||
{
|
||||
/* The given FSM (ccp) has been told to come down */
|
||||
}
|
||||
|
||||
static void
|
||||
mp_LayerFinish(void *v, struct fsm *fp)
|
||||
mp_LayerFinish(void *v __unused, struct fsm *fp)
|
||||
{
|
||||
/* The given fsm (ccp) is now down */
|
||||
if (fp->state == ST_CLOSED && fp->open_mode == OPEN_PASSIVE)
|
||||
@ -416,7 +416,7 @@ mp_Assemble(struct mp *mp, struct mbuf *m, struct physical *p)
|
||||
{
|
||||
struct mp_header mh, h;
|
||||
struct mbuf *q, *last;
|
||||
int32_t seq;
|
||||
u_int32_t seq;
|
||||
|
||||
/*
|
||||
* When `m' and `p' are NULL, it means our oldest link has gone down.
|
||||
@ -445,7 +445,7 @@ mp_Assemble(struct mp *mp, struct mbuf *m, struct physical *p)
|
||||
mp->seq.min_in = (u_int32_t)-1;
|
||||
for (dl = mp->bundle->links; dl; dl = dl->next)
|
||||
if (dl->state == DATALINK_OPEN &&
|
||||
(mp->seq.min_in == -1 ||
|
||||
(mp->seq.min_in == (u_int32_t)-1 ||
|
||||
isbefore(mp->local_is12bit, dl->mp.seq, mp->seq.min_in)))
|
||||
mp->seq.min_in = dl->mp.seq;
|
||||
}
|
||||
@ -535,7 +535,7 @@ mp_Assemble(struct mp *mp, struct mbuf *m, struct physical *p)
|
||||
/* We've got something, reassemble */
|
||||
struct mbuf **frag = &q;
|
||||
int len;
|
||||
u_long first = -1;
|
||||
long long first = -1;
|
||||
|
||||
do {
|
||||
*frag = mp->inbufs;
|
||||
@ -574,8 +574,8 @@ mp_Assemble(struct mp *mp, struct mbuf *m, struct physical *p)
|
||||
|
||||
if (q) {
|
||||
q = m_pullup(q);
|
||||
log_Printf(LogDEBUG, "MP: Reassembled frags %ld-%lu, length %d\n",
|
||||
first, (u_long)h.seq, m_length(q));
|
||||
log_Printf(LogDEBUG, "MP: Reassembled frags %lu-%lu, length %d\n",
|
||||
(u_long)first, (u_long)h.seq, m_length(q));
|
||||
link_PullPacket(&mp->link, MBUF_CTOP(q), q->m_len, mp->bundle);
|
||||
m_freem(q);
|
||||
}
|
||||
@ -896,10 +896,10 @@ mp_ShowStatus(struct cmdargs const *arg)
|
||||
}
|
||||
|
||||
const char *
|
||||
mp_Enddisc(u_char c, const char *address, int len)
|
||||
mp_Enddisc(u_char c, const char *address, size_t len)
|
||||
{
|
||||
static char result[100]; /* Used immediately after it's returned */
|
||||
int f, header;
|
||||
unsigned f, header;
|
||||
|
||||
switch (c) {
|
||||
case ENDDISC_NULL:
|
||||
@ -930,7 +930,7 @@ mp_Enddisc(u_char c, const char *address, int len)
|
||||
case ENDDISC_MAGIC:
|
||||
sprintf(result, "Magic: 0x");
|
||||
header = strlen(result);
|
||||
if (len > sizeof result - header - 1)
|
||||
if (len + header + 1 > sizeof result)
|
||||
len = sizeof result - header - 1;
|
||||
for (f = 0; f < len; f++)
|
||||
sprintf(result + header + 2 * f, "%02x", address[f]);
|
||||
@ -940,10 +940,10 @@ mp_Enddisc(u_char c, const char *address, int len)
|
||||
snprintf(result, sizeof result, "PSN: %.*s", len, address);
|
||||
break;
|
||||
|
||||
default:
|
||||
default:
|
||||
sprintf(result, "%d: ", (int)c);
|
||||
header = strlen(result);
|
||||
if (len > sizeof result - header - 1)
|
||||
if (len + header + 1 > sizeof result)
|
||||
len = sizeof result - header - 1;
|
||||
for (f = 0; f < len; f++)
|
||||
sprintf(result + header + 2 * f, "%02x", address[f]);
|
||||
@ -993,19 +993,13 @@ mp_SetEnddisc(struct cmdargs const *arg)
|
||||
mp->cfg.enddisc.len = sizeof arg->bundle->ncp.ipcp.my_ip.s_addr;
|
||||
} else if (!strcasecmp(arg->argv[arg->argn], "mac")) {
|
||||
struct sockaddr_dl hwaddr;
|
||||
int s;
|
||||
|
||||
if (arg->bundle->ncp.ipcp.my_ip.s_addr == INADDR_ANY)
|
||||
ncprange_getip4addr(&arg->bundle->ncp.ipcp.cfg.my_range, &addr);
|
||||
else
|
||||
addr = arg->bundle->ncp.ipcp.my_ip;
|
||||
|
||||
s = ID0socket(PF_INET, SOCK_DGRAM, 0);
|
||||
if (s < 0) {
|
||||
log_Printf(LogERROR, "set enddisc: socket(): %s\n", strerror(errno));
|
||||
return 2;
|
||||
}
|
||||
if (arp_EtherAddr(s, addr, &hwaddr, 1)) {
|
||||
if (arp_EtherAddr(addr, &hwaddr, 1)) {
|
||||
mp->cfg.enddisc.class = ENDDISC_MAC;
|
||||
memcpy(mp->cfg.enddisc.address, hwaddr.sdl_data + hwaddr.sdl_nlen,
|
||||
hwaddr.sdl_alen);
|
||||
@ -1013,10 +1007,8 @@ mp_SetEnddisc(struct cmdargs const *arg)
|
||||
} else {
|
||||
log_Printf(LogWARN, "set enddisc: Can't locate MAC address for %s\n",
|
||||
inet_ntoa(addr));
|
||||
close(s);
|
||||
return 4;
|
||||
}
|
||||
close(s);
|
||||
} else if (!strcasecmp(arg->argv[arg->argn], "magic")) {
|
||||
int f;
|
||||
|
||||
@ -1082,7 +1074,8 @@ mpserver_IsSet(struct fdescriptor *d, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static void
|
||||
mpserver_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
mpserver_Read(struct fdescriptor *d, struct bundle *bundle,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct mpserver *s = descriptor2mpserver(d);
|
||||
|
||||
@ -1090,8 +1083,8 @@ mpserver_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static int
|
||||
mpserver_Write(struct fdescriptor *d, struct bundle *bundle,
|
||||
const fd_set *fdset)
|
||||
mpserver_Write(struct fdescriptor *d __unused, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
/* We never want to write here ! */
|
||||
log_Printf(LogALERT, "mpserver_Write: Internal error: Bad call !\n");
|
||||
@ -1129,7 +1122,9 @@ mpserver_Open(struct mpserver *s, struct peerid *peer)
|
||||
return MPSERVER_FAILED;
|
||||
}
|
||||
|
||||
for (f = 0; f < peer->enddisc.len && l < sizeof s->socket.sun_path - 2; f++) {
|
||||
for (f = 0;
|
||||
f < peer->enddisc.len && (size_t)l < sizeof s->socket.sun_path - 2;
|
||||
f++) {
|
||||
snprintf(s->socket.sun_path + l, sizeof s->socket.sun_path - l,
|
||||
"%02x", *(u_char *)(peer->enddisc.address+f));
|
||||
l += 2;
|
||||
|
@ -137,7 +137,7 @@ extern struct mbuf *mp_Input(struct bundle *, struct link *, struct mbuf *);
|
||||
extern int mp_FillPhysicalQueues(struct bundle *);
|
||||
extern int mp_SetDatalinkBandwidth(struct cmdargs const *);
|
||||
extern int mp_ShowStatus(struct cmdargs const *);
|
||||
extern const char *mp_Enddisc(u_char, const char *, int);
|
||||
extern const char *mp_Enddisc(u_char, const char *, size_t);
|
||||
extern int mp_SetEnddisc(struct cmdargs const *);
|
||||
extern void mp_LinkLost(struct mp *, struct datalink *);
|
||||
extern void mp_RestartAutoloadTimer(struct mp *);
|
||||
|
@ -98,7 +98,7 @@ struct mppe_state {
|
||||
unsigned flushnext : 1;
|
||||
unsigned flushrequired : 1;
|
||||
int cohnum;
|
||||
int keylen; /* 8 or 16 bytes */
|
||||
unsigned keylen; /* 8 or 16 bytes */
|
||||
int keybits; /* 40, 56 or 128 bits */
|
||||
char sesskey[MPPE_KEY_LEN];
|
||||
char mastkey[MPPE_KEY_LEN];
|
||||
@ -155,8 +155,8 @@ MPPEKeyChange(struct mppe_state *mp)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
MPPEOutput(void *v, struct ccp *ccp, struct link *l, int pri, u_short *proto,
|
||||
struct mbuf *mp)
|
||||
MPPEOutput(void *v, struct ccp *ccp, struct link *l __unused, int pri __unused,
|
||||
u_short *proto, struct mbuf *mp)
|
||||
{
|
||||
struct mppe_state *mop = (struct mppe_state *)v;
|
||||
struct mbuf *mo;
|
||||
@ -232,7 +232,7 @@ MPPEOutput(void *v, struct ccp *ccp, struct link *l, int pri, u_short *proto,
|
||||
}
|
||||
|
||||
static void
|
||||
MPPEResetInput(void *v)
|
||||
MPPEResetInput(void *v __unused)
|
||||
{
|
||||
log_Printf(LogCCP, "MPPE: Unexpected input channel ack\n");
|
||||
}
|
||||
@ -372,8 +372,10 @@ MPPEInput(void *v, struct ccp *ccp, u_short *proto, struct mbuf *mp)
|
||||
}
|
||||
|
||||
static void
|
||||
MPPEDictSetup(void *v, struct ccp *ccp, u_short proto, struct mbuf *mi)
|
||||
MPPEDictSetup(void *v __unused, struct ccp *ccp __unused,
|
||||
u_short proto __unused, struct mbuf *mp __unused)
|
||||
{
|
||||
/* Nothing to see here */
|
||||
}
|
||||
|
||||
static const char *
|
||||
|
@ -244,7 +244,8 @@ nat_RedirectProto(struct cmdargs const *arg)
|
||||
struct in_addr localIP, publicIP, remoteIP;
|
||||
struct alias_link *link;
|
||||
struct protoent *pe;
|
||||
int error, len;
|
||||
int error;
|
||||
unsigned len;
|
||||
|
||||
len = strlen(arg->argv[arg->argn]);
|
||||
if (len == 0) {
|
||||
@ -494,8 +495,8 @@ nat_SkinnyPort(struct cmdargs const *arg)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
nat_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
nat_LayerPush(struct bundle *bundle, struct link *l __unused, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
if (!bundle->NatEnabled || *proto != PROTO_IP)
|
||||
return bp;
|
||||
@ -511,7 +512,7 @@ nat_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
nat_LayerPull(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
nat_LayerPull(struct bundle *bundle, struct link *l __unused, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
{
|
||||
static int gfrags;
|
||||
|
@ -89,12 +89,8 @@ static u_short default_urgent_tcp_ports[] = {
|
||||
544 /* kshell */
|
||||
};
|
||||
|
||||
static u_short default_urgent_udp_ports[] = { };
|
||||
|
||||
#define NDEFTCPPORTS \
|
||||
(sizeof default_urgent_tcp_ports / sizeof default_urgent_tcp_ports[0])
|
||||
#define NDEFUDPPORTS \
|
||||
(sizeof default_urgent_udp_ports / sizeof default_urgent_udp_ports[0])
|
||||
|
||||
void
|
||||
ncp_Init(struct ncp *ncp, struct bundle *bundle)
|
||||
@ -108,11 +104,8 @@ ncp_Init(struct ncp *ncp, struct bundle *bundle)
|
||||
NDEFTCPPORTS * sizeof(u_short));
|
||||
ncp->cfg.urgent.tos = 1;
|
||||
|
||||
ncp->cfg.urgent.udp.nports = ncp->cfg.urgent.udp.maxports = NDEFUDPPORTS;
|
||||
ncp->cfg.urgent.udp.port = (u_short *)malloc(NDEFUDPPORTS * sizeof(u_short));
|
||||
memcpy(ncp->cfg.urgent.udp.port, default_urgent_udp_ports,
|
||||
NDEFUDPPORTS * sizeof(u_short));
|
||||
|
||||
ncp->cfg.urgent.udp.nports = ncp->cfg.urgent.udp.maxports = 0;
|
||||
ncp->cfg.urgent.udp.port = NULL;
|
||||
|
||||
mp_Init(&ncp->mp, bundle);
|
||||
|
||||
@ -205,7 +198,7 @@ ncp_SetLink(struct ncp *ncp, struct link *l)
|
||||
* down to the physical link level 'till ncp_FillPhysicalQueues() is used.
|
||||
*/
|
||||
void
|
||||
ncp_Enqueue(struct ncp *ncp, int af, int pri, char *ptr, int count)
|
||||
ncp_Enqueue(struct ncp *ncp, int af, unsigned pri, char *ptr, int count)
|
||||
{
|
||||
#ifndef NOINET6
|
||||
struct ipv6cp *ipv6cp = &ncp->ipv6cp;
|
||||
@ -222,8 +215,8 @@ ncp_Enqueue(struct ncp *ncp, int af, int pri, char *ptr, int count)
|
||||
|
||||
switch (af) {
|
||||
case AF_INET:
|
||||
if (pri < 0 || pri >= IPCP_QUEUES(ipcp)) {
|
||||
log_Printf(LogERROR, "Can't store in ip queue %d\n", pri);
|
||||
if (pri >= IPCP_QUEUES(ipcp)) {
|
||||
log_Printf(LogERROR, "Can't store in ip queue %u\n", pri);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -236,8 +229,8 @@ ncp_Enqueue(struct ncp *ncp, int af, int pri, char *ptr, int count)
|
||||
|
||||
#ifndef NOINET6
|
||||
case AF_INET6:
|
||||
if (pri < 0 || pri >= IPV6CP_QUEUES(ipcp)) {
|
||||
log_Printf(LogERROR, "Can't store in ipv6 queue %d\n", pri);
|
||||
if (pri >= IPV6CP_QUEUES(ipcp)) {
|
||||
log_Printf(LogERROR, "Can't store in ipv6 queue %u\n", pri);
|
||||
break;
|
||||
}
|
||||
|
||||
@ -333,7 +326,7 @@ ncp_FillPhysicalQueues(struct ncp *ncp, struct bundle *bundle)
|
||||
* of what is to be pushed next, coming either from mp->out or ncp->afq.
|
||||
*/
|
||||
int
|
||||
ncp_PushPacket(struct ncp *ncp, int *af, struct link *l)
|
||||
ncp_PushPacket(struct ncp *ncp __unused, int *af, struct link *l)
|
||||
{
|
||||
struct bundle *bundle = l->lcp.fsm.bundle;
|
||||
int res;
|
||||
@ -360,7 +353,7 @@ ncp_PushPacket(struct ncp *ncp, int *af, struct link *l)
|
||||
int
|
||||
ncp_IsUrgentPort(struct port_range *range, u_short src, u_short dst)
|
||||
{
|
||||
int f;
|
||||
unsigned f;
|
||||
|
||||
for (f = 0; f < range->nports; f++)
|
||||
if (range->port[f] == src || range->port[f] == dst)
|
||||
@ -373,7 +366,7 @@ void
|
||||
ncp_AddUrgentPort(struct port_range *range, u_short port)
|
||||
{
|
||||
u_short *newport;
|
||||
int p;
|
||||
unsigned p;
|
||||
|
||||
if (range->nports == range->maxports) {
|
||||
range->maxports += 10;
|
||||
@ -407,11 +400,11 @@ ncp_AddUrgentPort(struct port_range *range, u_short port)
|
||||
void
|
||||
ncp_RemoveUrgentPort(struct port_range *range, u_short port)
|
||||
{
|
||||
int p;
|
||||
unsigned p;
|
||||
|
||||
for (p = 0; p < range->nports; p++)
|
||||
if (range->port[p] == port) {
|
||||
if (p != range->nports - 1)
|
||||
if (p + 1 != range->nports)
|
||||
memmove(range->port + p, range->port + p + 1,
|
||||
(range->nports - p - 1) * sizeof(u_short));
|
||||
range->nports--;
|
||||
@ -432,7 +425,7 @@ int
|
||||
ncp_Show(struct cmdargs const *arg)
|
||||
{
|
||||
struct ncp *ncp = &arg->bundle->ncp;
|
||||
int p;
|
||||
unsigned p;
|
||||
|
||||
#ifndef NOINET6
|
||||
prompt_Printf(arg->prompt, "Next queued AF: %s\n",
|
||||
|
@ -60,7 +60,7 @@ extern int ncp_fsmStart(struct ncp *, struct bundle *);
|
||||
extern void ncp_IfaceAddrAdded(struct ncp *, const struct iface_addr *);
|
||||
extern void ncp_IfaceAddrDeleted(struct ncp *, const struct iface_addr *);
|
||||
extern void ncp_SetLink(struct ncp *, struct link *);
|
||||
extern void ncp_Enqueue(struct ncp *, int, int, char *, int);
|
||||
extern void ncp_Enqueue(struct ncp *, int, unsigned, char *, int);
|
||||
extern void ncp_DeleteQueues(struct ncp *);
|
||||
extern size_t ncp_QueueLen(struct ncp *);
|
||||
extern size_t ncp_FillPhysicalQueues(struct ncp *, struct bundle *);
|
||||
|
@ -159,11 +159,11 @@ mask62bits(const struct in6_addr *mask)
|
||||
return masklen;
|
||||
}
|
||||
|
||||
#if 0
|
||||
static void
|
||||
adjust_linklocal(struct sockaddr_in6 *sin6)
|
||||
{
|
||||
/* XXX: ?????!?!?!!!!! This is horrible ! */
|
||||
#if 0
|
||||
/*
|
||||
* The kernel does not understand sin6_scope_id for routing at this moment.
|
||||
* We should rather keep the embedded ID.
|
||||
@ -175,9 +175,9 @@ adjust_linklocal(struct sockaddr_in6 *sin6)
|
||||
ntohs(*(u_short *)&sin6->sin6_addr.s6_addr[2]);
|
||||
*(u_short *)&sin6->sin6_addr.s6_addr[2] = 0;
|
||||
}
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
void
|
||||
ncpaddr_init(struct ncpaddr *addr)
|
||||
@ -385,7 +385,9 @@ ncpaddr_ntowa(const struct ncpaddr *addr)
|
||||
sin6.sin6_len = sizeof(sin6);
|
||||
sin6.sin6_family = AF_INET6;
|
||||
sin6.sin6_addr = addr->ncpaddr_ip6addr;
|
||||
#if 0
|
||||
adjust_linklocal(&sin6);
|
||||
#endif
|
||||
#ifdef NI_WITHSCOPEID
|
||||
if (getnameinfo((struct sockaddr *)&sin6, sizeof sin6, res, sizeof(res),
|
||||
NULL, 0, NI_WITHSCOPEID | NI_NUMERICHOST) != 0)
|
||||
|
@ -98,18 +98,19 @@ struct ngdevice {
|
||||
#define NG_MSGBUFSZ 4096
|
||||
#define NETGRAPH_PREFIX "netgraph:"
|
||||
|
||||
int
|
||||
unsigned
|
||||
ng_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct ngdevice);
|
||||
}
|
||||
|
||||
static int
|
||||
ng_MessageOut(struct ngdevice *dev, struct physical *p, const char *data)
|
||||
ng_MessageOut(struct ngdevice *dev, const char *data)
|
||||
{
|
||||
char path[NG_PATHSIZ];
|
||||
int len, pos, dpos;
|
||||
char *fmt;
|
||||
size_t len;
|
||||
int pos, dpos;
|
||||
|
||||
/*
|
||||
* We expect a node path, one or more spaces, a command, one or more
|
||||
@ -141,7 +142,7 @@ ng_MessageOut(struct ngdevice *dev, struct physical *p, const char *data)
|
||||
* This is probably a waste of time, but we really don't want to end
|
||||
* up stuffing unexpected % escapes into the kernel....
|
||||
*/
|
||||
for (pos = dpos = 0; pos < len;) {
|
||||
for (pos = dpos = 0; pos < (int)len;) {
|
||||
if (data[dpos] == '%')
|
||||
fmt[pos++] = '%';
|
||||
fmt[pos++] = data[dpos++];
|
||||
@ -169,7 +170,7 @@ ng_MessageIn(struct physical *p, char *buf, size_t sz)
|
||||
struct ngdevice *dev = device2ng(p->handler);
|
||||
struct ng_mesg *rep = (struct ng_mesg *)msgbuf;
|
||||
char path[NG_PATHSIZ];
|
||||
int len;
|
||||
size_t len;
|
||||
|
||||
#ifdef BROKEN_SELECT
|
||||
struct timeval t;
|
||||
@ -224,9 +225,9 @@ ng_Write(struct physical *p, const void *v, size_t n)
|
||||
switch (p->dl->state) {
|
||||
case DATALINK_DIAL:
|
||||
case DATALINK_LOGIN:
|
||||
return ng_MessageOut(dev, p, v) ? n : -1;
|
||||
return ng_MessageOut(dev, v) ? (ssize_t)n : -1;
|
||||
}
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : n;
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : (ssize_t)n;
|
||||
}
|
||||
|
||||
static ssize_t
|
||||
@ -279,7 +280,7 @@ ng_Free(struct physical *p)
|
||||
|
||||
static void
|
||||
ng_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
struct ngdevice *dev = device2ng(d);
|
||||
int sz = physical_MaxDeviceSize();
|
||||
@ -319,7 +320,7 @@ static const struct device basengdevice = {
|
||||
|
||||
struct device *
|
||||
ng_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
if (type == NG_DEVICE) {
|
||||
struct ngdevice *dev = (struct ngdevice *)iov[(*niov)++].iov_base;
|
||||
@ -427,7 +428,7 @@ static int
|
||||
getsegment(const char *what, char *word, size_t sz, const char *from,
|
||||
const char *sep, const char **endp)
|
||||
{
|
||||
int len;
|
||||
size_t len;
|
||||
|
||||
if ((len = strcspn(from, sep)) == 0) {
|
||||
log_Printf(LogWARN, "%s name should not be empty !\n", what);
|
||||
@ -468,7 +469,8 @@ ng_Create(struct physical *p)
|
||||
char modname[NG_TYPESIZ + 3];
|
||||
char path[NG_PATHSIZ];
|
||||
char *nodename;
|
||||
int len, sz, done, f;
|
||||
int len, sz, done;
|
||||
unsigned f;
|
||||
|
||||
dev = NULL;
|
||||
if (p->fd < 0 && !strncasecmp(p->name.full, NETGRAPH_PREFIX,
|
||||
|
@ -34,4 +34,4 @@ struct device;
|
||||
extern struct device *ng_Create(struct physical *);
|
||||
extern struct device *ng_iov2device(int, struct physical *, struct iovec *,
|
||||
int *, int, int *, int *);
|
||||
extern int ng_DeviceSize(void);
|
||||
extern unsigned ng_DeviceSize(void);
|
||||
|
@ -270,7 +270,7 @@ pap_Input(struct bundle *bundle, struct link *l, struct mbuf *bp)
|
||||
pap_Failure(authp);
|
||||
} else
|
||||
#endif
|
||||
if (auth_Validate(bundle, authp->in.name, key, p))
|
||||
if (auth_Validate(bundle, authp->in.name, key))
|
||||
pap_Success(authp);
|
||||
else
|
||||
pap_Failure(authp);
|
||||
|
@ -30,6 +30,9 @@
|
||||
#include <errno.h>
|
||||
#include <fcntl.h>
|
||||
#include <paths.h>
|
||||
#ifdef NOSUID
|
||||
#include <signal.h>
|
||||
#endif
|
||||
#include <stdarg.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
@ -109,7 +112,7 @@
|
||||
static int physical_DescriptorWrite(struct fdescriptor *, struct bundle *,
|
||||
const fd_set *);
|
||||
|
||||
static int
|
||||
static unsigned
|
||||
physical_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct device);
|
||||
@ -119,7 +122,7 @@ struct {
|
||||
struct device *(*create)(struct physical *);
|
||||
struct device *(*iov2device)(int, struct physical *, struct iovec *,
|
||||
int *, int, int *, int *);
|
||||
int (*DeviceSize)(void);
|
||||
unsigned (*DeviceSize)(void);
|
||||
} devices[] = {
|
||||
#ifndef NOI4B
|
||||
/*
|
||||
@ -231,7 +234,7 @@ static const struct parity {
|
||||
{ "even", "P_EVEN", CS7 | PARENB },
|
||||
{ "odd", "P_ODD", CS7 | PARENB | PARODD },
|
||||
{ "none", "P_ZERO", CS8 },
|
||||
{ NULL, 0 },
|
||||
{ NULL, NULL, 0 },
|
||||
};
|
||||
|
||||
static int
|
||||
@ -269,7 +272,7 @@ physical_SetParity(struct physical *p, const char *str)
|
||||
return -1;
|
||||
}
|
||||
|
||||
int
|
||||
unsigned
|
||||
physical_GetSpeed(struct physical *p)
|
||||
{
|
||||
if (p->handler && p->handler->speed)
|
||||
@ -279,9 +282,9 @@ physical_GetSpeed(struct physical *p)
|
||||
}
|
||||
|
||||
int
|
||||
physical_SetSpeed(struct physical *p, int speed)
|
||||
physical_SetSpeed(struct physical *p, unsigned speed)
|
||||
{
|
||||
if (IntToSpeed(speed) != B0) {
|
||||
if (UnsignedToSpeed(speed) != B0) {
|
||||
p->cfg.speed = speed;
|
||||
return 1;
|
||||
}
|
||||
@ -402,8 +405,8 @@ physical_Destroy(struct physical *p)
|
||||
}
|
||||
|
||||
static int
|
||||
physical_DescriptorWrite(struct fdescriptor *d, struct bundle *bundle,
|
||||
const fd_set *fdset)
|
||||
physical_DescriptorWrite(struct fdescriptor *d, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct physical *p = descriptor2physical(d);
|
||||
int nw, result = 0;
|
||||
@ -535,7 +538,7 @@ physical_ShowStatus(struct cmdargs const *arg)
|
||||
|
||||
void
|
||||
physical_DescriptorRead(struct fdescriptor *d, struct bundle *bundle,
|
||||
const fd_set *fdset)
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct physical *p = descriptor2physical(d);
|
||||
u_char *rbuff;
|
||||
@ -591,7 +594,8 @@ iov2physical(struct datalink *dl, struct iovec *iov, int *niov, int maxiov,
|
||||
int fd, int *auxfd, int *nauxfd)
|
||||
{
|
||||
struct physical *p;
|
||||
int len, h, type;
|
||||
int len, type;
|
||||
unsigned h;
|
||||
|
||||
p = (struct physical *)iov[(*niov)++].iov_base;
|
||||
p->link.name = dl->name;
|
||||
@ -662,13 +666,13 @@ iov2physical(struct datalink *dl, struct iovec *iov, int *niov, int maxiov,
|
||||
return p;
|
||||
}
|
||||
|
||||
int
|
||||
unsigned
|
||||
physical_MaxDeviceSize()
|
||||
{
|
||||
int biggest, sz, n;
|
||||
unsigned biggest, sz, n;
|
||||
|
||||
biggest = sizeof(struct device);
|
||||
for (sz = n = 0; n < NDEVICES; n++)
|
||||
for (n = 0; n < NDEVICES; n++)
|
||||
if (devices[n].DeviceSize) {
|
||||
sz = (*devices[n].DeviceSize)();
|
||||
if (biggest < sz)
|
||||
@ -787,7 +791,8 @@ const char *physical_GetDevice(struct physical *p)
|
||||
void
|
||||
physical_SetDeviceList(struct physical *p, int argc, const char *const *argv)
|
||||
{
|
||||
int f, pos;
|
||||
unsigned pos;
|
||||
int f;
|
||||
|
||||
p->cfg.devlist[sizeof p->cfg.devlist - 1] = '\0';
|
||||
for (f = 0, pos = 0; f < argc && pos < sizeof p->cfg.devlist - 1; f++) {
|
||||
@ -1003,10 +1008,11 @@ physical_Found(struct physical *p)
|
||||
}
|
||||
|
||||
int
|
||||
physical_Open(struct physical *p, struct bundle *bundle)
|
||||
physical_Open(struct physical *p)
|
||||
{
|
||||
int devno, h, wasfd, err;
|
||||
char *dev;
|
||||
int devno, wasfd, err;
|
||||
unsigned h;
|
||||
|
||||
if (p->fd >= 0)
|
||||
log_Printf(LogDEBUG, "%s: Open: Modem is already open!\n", p->link.name);
|
||||
|
@ -71,7 +71,7 @@ struct device {
|
||||
ssize_t (*read)(struct physical *, void *, size_t);
|
||||
ssize_t (*write)(struct physical *, const void *, size_t);
|
||||
void (*device2iov)(struct device *, struct iovec *, int *, int, int *, int *);
|
||||
int (*speed)(struct physical *);
|
||||
unsigned (*speed)(struct physical *);
|
||||
const char *(*openinfo)(struct physical *);
|
||||
int (*slot)(struct physical *);
|
||||
};
|
||||
@ -130,10 +130,10 @@ struct physical {
|
||||
#define PHYSICAL_FORCE_SYNCNOACF 4
|
||||
|
||||
extern struct physical *physical_Create(struct datalink *, int);
|
||||
extern int physical_Open(struct physical *, struct bundle *);
|
||||
extern int physical_Open(struct physical *);
|
||||
extern int physical_Raw(struct physical *);
|
||||
extern int physical_GetSpeed(struct physical *);
|
||||
extern int physical_SetSpeed(struct physical *, int);
|
||||
extern unsigned physical_GetSpeed(struct physical *);
|
||||
extern int physical_SetSpeed(struct physical *, unsigned);
|
||||
extern int physical_SetParity(struct physical *, const char *);
|
||||
extern int physical_SetRtsCts(struct physical *, int);
|
||||
extern void physical_SetSync(struct physical *);
|
||||
@ -168,9 +168,9 @@ extern int physical_SetMode(struct physical *, int);
|
||||
extern void physical_DeleteQueue(struct physical *);
|
||||
extern void physical_SetupStack(struct physical *, const char *, int);
|
||||
extern void physical_StopDeviceTimer(struct physical *);
|
||||
extern int physical_MaxDeviceSize(void);
|
||||
extern unsigned physical_MaxDeviceSize(void);
|
||||
extern int physical_AwaitCarrier(struct physical *);
|
||||
extern void physical_SetDescriptor(struct physical *);
|
||||
extern void physical_SetAsyncParams(struct physical *, u_int32_t, u_int32_t);
|
||||
extern int physical_Slot(struct physical *);
|
||||
extern int physical_SetPPPoEnonstandatd(struct physical *, int);
|
||||
extern int physical_SetPPPoEnonstandard(struct physical *, int);
|
||||
|
@ -151,7 +151,7 @@ Pred1ResetOutput(void *v)
|
||||
}
|
||||
|
||||
static void *
|
||||
Pred1InitInput(struct bundle *bundle, struct fsm_opt *o)
|
||||
Pred1InitInput(struct bundle *bundle __unused, struct fsm_opt *o __unused)
|
||||
{
|
||||
struct pred1_state *state;
|
||||
state = (struct pred1_state *)malloc(sizeof(struct pred1_state));
|
||||
@ -161,7 +161,7 @@ Pred1InitInput(struct bundle *bundle, struct fsm_opt *o)
|
||||
}
|
||||
|
||||
static void *
|
||||
Pred1InitOutput(struct bundle *bundle, struct fsm_opt *o)
|
||||
Pred1InitOutput(struct bundle *bundle __unused, struct fsm_opt *o __unused)
|
||||
{
|
||||
struct pred1_state *state;
|
||||
state = (struct pred1_state *)malloc(sizeof(struct pred1_state));
|
||||
@ -171,8 +171,8 @@ Pred1InitOutput(struct bundle *bundle, struct fsm_opt *o)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
Pred1Output(void *v, struct ccp *ccp, struct link *l, int pri, u_short *proto,
|
||||
struct mbuf *bp)
|
||||
Pred1Output(void *v, struct ccp *ccp, struct link *l __unused,
|
||||
int pri __unused, u_short *proto, struct mbuf *bp)
|
||||
{
|
||||
struct pred1_state *state = (struct pred1_state *)v;
|
||||
struct mbuf *mwp;
|
||||
@ -289,26 +289,28 @@ Pred1Input(void *v, struct ccp *ccp, u_short *proto, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static void
|
||||
Pred1DictSetup(void *v, struct ccp *ccp, u_short proto, struct mbuf *bp)
|
||||
Pred1DictSetup(void *v __unused, struct ccp *ccp __unused,
|
||||
u_short proto __unused, struct mbuf *bp __unused)
|
||||
{
|
||||
/* Nothing to see here */
|
||||
}
|
||||
|
||||
static const char *
|
||||
Pred1DispOpts(struct fsm_opt *o)
|
||||
Pred1DispOpts(struct fsm_opt *o __unused)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static void
|
||||
Pred1InitOptsOutput(struct bundle *bundle, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg)
|
||||
Pred1InitOptsOutput(struct bundle *bundle __unused, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg __unused)
|
||||
{
|
||||
o->hdr.len = 2;
|
||||
}
|
||||
|
||||
static int
|
||||
Pred1SetOpts(struct bundle *bundle, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg)
|
||||
Pred1SetOpts(struct bundle *bundle __unused, struct fsm_opt *o,
|
||||
const struct ccp_config *cfg __unused)
|
||||
{
|
||||
if (o->hdr.len != 2) {
|
||||
o->hdr.len = 2;
|
||||
|
@ -129,7 +129,8 @@ prompt_Display(struct prompt *p)
|
||||
}
|
||||
|
||||
static int
|
||||
prompt_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w, fd_set *e, int *n)
|
||||
prompt_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w __unused,
|
||||
fd_set *e, int *n)
|
||||
{
|
||||
struct prompt *p = descriptor2prompt(d);
|
||||
int sets;
|
||||
@ -179,7 +180,8 @@ prompt_ShowHelp(struct prompt *p)
|
||||
}
|
||||
|
||||
static void
|
||||
prompt_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
prompt_Read(struct fdescriptor *d, struct bundle *bundle,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
struct prompt *p = descriptor2prompt(d);
|
||||
struct prompt *op;
|
||||
@ -206,7 +208,7 @@ prompt_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
} else if (n <= 0) {
|
||||
log_Printf(LogPHASE, "%s: Client connection closed.\n", p->src.from);
|
||||
if (!p->owner)
|
||||
Cleanup(EX_NORMAL);
|
||||
Cleanup();
|
||||
prompt_Destroy(p, 0);
|
||||
}
|
||||
return;
|
||||
@ -300,7 +302,8 @@ prompt_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static int
|
||||
prompt_Write(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
prompt_Write(struct fdescriptor *d __unused, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
/* We never want to write here ! */
|
||||
log_Printf(LogALERT, "prompt_Write: Internal error: Bad call !\n");
|
||||
@ -394,7 +397,7 @@ prompt_vPrintf(struct prompt *p, const char *fmt, va_list ap)
|
||||
|
||||
if (p->TermMode) {
|
||||
/* Stuff '\r' in front of '\n' 'cos we're in raw mode */
|
||||
int len = strlen(fmt);
|
||||
size_t len = strlen(fmt);
|
||||
|
||||
if (len && len < sizeof nfmt - 1 && fmt[len-1] == '\n' &&
|
||||
(len == 1 || fmt[len-2] != '\r')) {
|
||||
|
@ -69,8 +69,8 @@ proto_Prepend(struct mbuf *bp, u_short proto, unsigned comp, int extra)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
proto_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
proto_LayerPush(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
log_Printf(LogDEBUG, "proto_LayerPush: Using 0x%04x\n", *proto);
|
||||
bp = proto_Prepend(bp, *proto, l->lcp.his_protocomp,
|
||||
@ -82,7 +82,7 @@ proto_LayerPush(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
proto_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
proto_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
{
|
||||
u_char cp[2];
|
||||
|
@ -671,7 +671,8 @@ radius_Timeout(void *v)
|
||||
* Time to call rad_continue_send_request() - something to read.
|
||||
*/
|
||||
static void
|
||||
radius_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
radius_Read(struct fdescriptor *d, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
radius_Continue(descriptor2radius(d), 1);
|
||||
}
|
||||
@ -680,7 +681,8 @@ radius_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
* Behave as a struct fdescriptor (descriptor.h)
|
||||
*/
|
||||
static int
|
||||
radius_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w, fd_set *e, int *n)
|
||||
radius_UpdateSet(struct fdescriptor *d, fd_set *r, fd_set *w __unused,
|
||||
fd_set *e __unused, int *n)
|
||||
{
|
||||
struct radius *rad = descriptor2radius(d);
|
||||
|
||||
@ -710,7 +712,8 @@ radius_IsSet(struct fdescriptor *d, const fd_set *fdset)
|
||||
* Behave as a struct fdescriptor (descriptor.h)
|
||||
*/
|
||||
static int
|
||||
radius_Write(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
radius_Write(struct fdescriptor *d __unused, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
/* We never want to write here ! */
|
||||
log_Printf(LogALERT, "radius_Write: Internal error: Bad call !\n");
|
||||
@ -845,10 +848,11 @@ radius_Authenticate(struct radius *r, struct authinfo *authp, const char *name,
|
||||
const char *key, int klen, const char *nchallenge,
|
||||
int nclen)
|
||||
{
|
||||
struct timeval tv;
|
||||
int got;
|
||||
char hostname[MAXHOSTNAMELEN];
|
||||
char *mac_addr, *what;
|
||||
struct timeval tv;
|
||||
const char *what = "questionable"; /* silence warnings! */
|
||||
char *mac_addr;
|
||||
int got;
|
||||
#if 0
|
||||
struct hostent *hp;
|
||||
struct in_addr hostaddr;
|
||||
@ -997,7 +1001,7 @@ radius_Authenticate(struct radius *r, struct authinfo *authp, const char *name,
|
||||
rad_put_string(r->cx.rad, RAD_CALLING_STATION_ID, mac_addr) != 0) {
|
||||
log_Printf(LogERROR, "rad_put: %s\n", rad_strerror(r->cx.rad));
|
||||
rad_close(r->cx.rad);
|
||||
return;
|
||||
return 0;
|
||||
}
|
||||
|
||||
radius_put_physical_details(r->cx.rad, authp->physical);
|
||||
@ -1210,7 +1214,7 @@ radius_Account(struct radius *r, struct radacct *ac, struct datalink *dl,
|
||||
}
|
||||
|
||||
if (log_IsKept(LogPHASE) || log_IsKept(LogRADIUS)) {
|
||||
char *what;
|
||||
const char *what;
|
||||
int level;
|
||||
|
||||
switch (acct_type) {
|
||||
|
@ -184,7 +184,7 @@ static struct bits {
|
||||
#endif
|
||||
|
||||
static void
|
||||
p_flags(struct prompt *prompt, u_int32_t f, int max)
|
||||
p_flags(struct prompt *prompt, u_int32_t f, unsigned max)
|
||||
{
|
||||
char name[33], *flags;
|
||||
register struct bits *p = bits;
|
||||
@ -192,7 +192,7 @@ p_flags(struct prompt *prompt, u_int32_t f, int max)
|
||||
if (max > sizeof name - 1)
|
||||
max = sizeof name - 1;
|
||||
|
||||
for (flags = name; p->b_mask && flags - name < max; p++)
|
||||
for (flags = name; p->b_mask && flags - name < (int)max; p++)
|
||||
if (p->b_mask & f)
|
||||
*flags++ = p->b_val;
|
||||
*flags = '\0';
|
||||
@ -516,7 +516,7 @@ route_UpdateMTU(struct bundle *bundle)
|
||||
if (log_IsKept(LogTCPIP)) {
|
||||
ncprange_setsa(&dst, sa[RTAX_DST], sa[RTAX_NETMASK]);
|
||||
log_Printf(LogTCPIP, "route_UpdateMTU: Netif: %d (%s), dst %s,"
|
||||
" mtu %d\n", rtm->rtm_index, Index2Nam(rtm->rtm_index),
|
||||
" mtu %lu\n", rtm->rtm_index, Index2Nam(rtm->rtm_index),
|
||||
ncprange_ntoa(&dst), bundle->iface->mtu);
|
||||
}
|
||||
rt_Update(bundle, sa[RTAX_DST], sa[RTAX_GATEWAY], sa[RTAX_NETMASK]);
|
||||
|
@ -192,7 +192,8 @@ server_Read(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
}
|
||||
|
||||
static int
|
||||
server_Write(struct fdescriptor *d, struct bundle *bundle, const fd_set *fdset)
|
||||
server_Write(struct fdescriptor *d __unused, struct bundle *bundle __unused,
|
||||
const fd_set *fdset __unused)
|
||||
{
|
||||
/* We never want to write here ! */
|
||||
log_Printf(LogALERT, "server_Write: Internal error: Bad call !\n");
|
||||
@ -207,7 +208,8 @@ struct server server = {
|
||||
server_Read,
|
||||
server_Write
|
||||
},
|
||||
-1
|
||||
-1,
|
||||
{ "", "", 0, 0 }
|
||||
};
|
||||
|
||||
enum server_stat
|
||||
@ -375,7 +377,7 @@ failed:
|
||||
}
|
||||
|
||||
int
|
||||
server_Close(struct bundle *bundle)
|
||||
server_Close(struct bundle *bundle __unused)
|
||||
{
|
||||
if (server.fd >= 0) {
|
||||
if (*server.cfg.sockname != '\0') {
|
||||
|
@ -436,7 +436,7 @@ sl_uncompress_tcp(u_char ** bufp, int len, u_int type, struct slcompress *comp,
|
||||
* overflow the space we have available for it.
|
||||
*/
|
||||
hlen = ip->ip_hl << 2;
|
||||
if (hlen + sizeof(struct tcphdr) > len)
|
||||
if ((int)(hlen + sizeof(struct tcphdr)) > len)
|
||||
goto bad;
|
||||
th = (struct tcphdr *) & ((char *) ip)[hlen];
|
||||
hlen += THOFFSET(th) << 2;
|
||||
|
@ -49,8 +49,8 @@
|
||||
#include "physical.h"
|
||||
|
||||
static struct mbuf *
|
||||
sync_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
sync_LayerPush(struct bundle *bundle __unused, struct link *l __unused,
|
||||
struct mbuf *bp, int pri __unused, u_short *proto __unused)
|
||||
{
|
||||
log_DumpBp(LogSYNC, "Write", bp);
|
||||
m_settype(bp, MB_SYNCOUT);
|
||||
@ -59,8 +59,8 @@ sync_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
sync_LayerPull(struct bundle *b, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
sync_LayerPull(struct bundle *b __unused, struct link *l, struct mbuf *bp,
|
||||
u_short *proto __unused)
|
||||
{
|
||||
struct physical *p = link2physical(l);
|
||||
int len;
|
||||
|
@ -70,7 +70,8 @@ InterpretArg(const char *from, char *to)
|
||||
{
|
||||
char *ptr, *startto, *endto;
|
||||
struct passwd *pwd;
|
||||
int len, instring;
|
||||
int instring;
|
||||
size_t len;
|
||||
const char *env;
|
||||
|
||||
instring = 0;
|
||||
@ -106,7 +107,7 @@ InterpretArg(const char *from, char *to)
|
||||
ptr = strchr(from+2, '}');
|
||||
if (ptr) {
|
||||
len = ptr - from - 2;
|
||||
if (endto - to < len )
|
||||
if (endto - to < (int)len )
|
||||
len = endto - to;
|
||||
if (len) {
|
||||
strncpy(to, from+2, len);
|
||||
@ -137,7 +138,7 @@ InterpretArg(const char *from, char *to)
|
||||
|
||||
case '~':
|
||||
ptr = strchr(++from, '/');
|
||||
len = ptr ? ptr - from : strlen(from);
|
||||
len = ptr ? (size_t)(ptr - from) : strlen(from);
|
||||
if (len == 0)
|
||||
pwd = getpwuid(ID0realuid());
|
||||
else {
|
||||
|
@ -119,7 +119,8 @@ static struct device tcpdevice = {
|
||||
|
||||
struct device *
|
||||
tcp_iov2device(int type, struct physical *p, struct iovec *iov,
|
||||
int *niov, int maxiov, int *auxfd, int *nauxfd)
|
||||
int *niov, int maxiov __unused, int *auxfd __unused,
|
||||
int *nauxfd __unused)
|
||||
{
|
||||
if (type == TCP_DEVICE) {
|
||||
free(iov[(*niov)++].iov_base);
|
||||
|
@ -96,9 +96,9 @@
|
||||
}
|
||||
|
||||
static void
|
||||
MSSFixup(struct tcphdr *tc, ssize_t pktlen, u_int16_t maxmss)
|
||||
MSSFixup(struct tcphdr *tc, size_t pktlen, u_int16_t maxmss)
|
||||
{
|
||||
int hlen, olen, optlen;
|
||||
size_t hlen, olen, optlen;
|
||||
u_char *opt;
|
||||
u_int16_t *mss;
|
||||
int accumulate;
|
||||
@ -144,7 +144,7 @@ static struct mbuf *
|
||||
tcpmss_Check(struct bundle *bundle, struct mbuf *bp)
|
||||
{
|
||||
struct ip *pip;
|
||||
int hlen, plen;
|
||||
size_t hlen, plen;
|
||||
|
||||
if (!Enabled(bundle, OPT_TCPMSSFIXUP))
|
||||
return bp;
|
||||
@ -160,7 +160,7 @@ tcpmss_Check(struct bundle *bundle, struct mbuf *bp)
|
||||
*/
|
||||
if (pip->ip_p == IPPROTO_TCP && (ntohs(pip->ip_off) & IP_OFFMASK) == 0 &&
|
||||
ntohs(pip->ip_len) == plen && hlen <= plen &&
|
||||
plen - hlen >= sizeof(struct tcphdr))
|
||||
plen >= sizeof(struct tcphdr) + hlen)
|
||||
MSSFixup((struct tcphdr *)(MBUF_CTOP(bp) + hlen), plen - hlen,
|
||||
MAXMSS(bundle->iface->mtu));
|
||||
|
||||
@ -168,15 +168,15 @@ tcpmss_Check(struct bundle *bundle, struct mbuf *bp)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
tcpmss_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
int pri, u_short *proto)
|
||||
tcpmss_LayerPush(struct bundle *bundle, struct link *l __unused,
|
||||
struct mbuf *bp, int pri __unused, u_short *proto __unused)
|
||||
{
|
||||
return tcpmss_Check(bundle, bp);
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
tcpmss_LayerPull(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
tcpmss_LayerPull(struct bundle *bundle, struct link *l __unused,
|
||||
struct mbuf *bp, u_short *proto __unused)
|
||||
{
|
||||
return tcpmss_Check(bundle, bp);
|
||||
}
|
||||
|
@ -91,7 +91,7 @@ struct ttydevice {
|
||||
int carrier_seconds; /* seconds before CD is *required* */
|
||||
#ifndef NONETGRAPH
|
||||
struct {
|
||||
int speed; /* Pre-line-discipline speed */
|
||||
unsigned speed; /* Pre-line-discipline speed */
|
||||
int fd; /* Pre-line-discipline fd */
|
||||
int disc; /* Old line-discipline */
|
||||
} real;
|
||||
@ -103,7 +103,7 @@ struct ttydevice {
|
||||
|
||||
#define device2tty(d) ((d)->type == TTY_DEVICE ? (struct ttydevice *)d : NULL)
|
||||
|
||||
int
|
||||
unsigned
|
||||
tty_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct ttydevice);
|
||||
@ -259,7 +259,8 @@ LoadLineDiscipline(struct physical *p)
|
||||
char ttypath[NG_NODESIZ];
|
||||
struct ngm_mkpeer ngm;
|
||||
struct ngm_connect ngc;
|
||||
int ldisc, cs, ds, hot, speed;
|
||||
int ldisc, cs, ds, hot;
|
||||
unsigned speed;
|
||||
|
||||
/*
|
||||
* Don't use the netgraph line discipline for now. Using it works, but
|
||||
@ -409,7 +410,7 @@ tty_Write(struct physical *p, const void *v, size_t n)
|
||||
struct ttydevice *dev = device2tty(p->handler);
|
||||
|
||||
if (isngtty(dev))
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : n;
|
||||
return NgSendData(p->fd, dev->hook, v, n) == -1 ? -1 : (ssize_t)n;
|
||||
else
|
||||
return write(p->fd, v, n);
|
||||
}
|
||||
@ -528,7 +529,7 @@ tty_Free(struct physical *p)
|
||||
free(dev);
|
||||
}
|
||||
|
||||
static int
|
||||
static unsigned
|
||||
tty_Speed(struct physical *p)
|
||||
{
|
||||
struct termios ios;
|
||||
@ -536,7 +537,7 @@ tty_Speed(struct physical *p)
|
||||
if (tcgetattr(p->fd, &ios) == -1)
|
||||
return 0;
|
||||
|
||||
return SpeedToInt(cfgetispeed(&ios));
|
||||
return SpeedToUnsigned(cfgetispeed(&ios));
|
||||
}
|
||||
|
||||
static const char *
|
||||
@ -573,7 +574,7 @@ tty_Slot(struct physical *p)
|
||||
|
||||
static void
|
||||
tty_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
struct ttydevice *dev = device2tty(d);
|
||||
int sz = physical_MaxDeviceSize();
|
||||
@ -622,7 +623,7 @@ static struct device basettydevice = {
|
||||
|
||||
struct device *
|
||||
tty_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd, int *nauxfd)
|
||||
{
|
||||
if (type == TTY_DEVICE) {
|
||||
struct ttydevice *dev = (struct ttydevice *)iov[(*niov)++].iov_base;
|
||||
@ -719,7 +720,7 @@ tty_Create(struct physical *p)
|
||||
/* Change tty speed when we're not in -direct mode */
|
||||
ios.c_cflag &= ~(CSIZE | PARODD | PARENB);
|
||||
ios.c_cflag |= p->cfg.parity;
|
||||
if (cfsetspeed(&ios, IntToSpeed(p->cfg.speed)) == -1)
|
||||
if (cfsetspeed(&ios, UnsignedToSpeed(p->cfg.speed)) == -1)
|
||||
log_Printf(LogWARN, "%s: %s: Unable to set speed to %d\n",
|
||||
p->link.name, p->name.full, p->cfg.speed);
|
||||
}
|
||||
|
@ -34,4 +34,4 @@ struct device;
|
||||
extern struct device *tty_Create(struct physical *);
|
||||
extern struct device *tty_iov2device(int, struct physical *,
|
||||
struct iovec *, int *, int, int *, int *);
|
||||
extern int tty_DeviceSize(void);
|
||||
extern unsigned tty_DeviceSize(void);
|
||||
|
@ -73,7 +73,7 @@ struct udpdevice {
|
||||
|
||||
#define device2udp(d) ((d)->type == UDP_DEVICE ? (struct udpdevice *)d : NULL)
|
||||
|
||||
int
|
||||
unsigned
|
||||
udp_DeviceSize(void)
|
||||
{
|
||||
return sizeof(struct udpdevice);
|
||||
@ -138,7 +138,7 @@ udp_Free(struct physical *p)
|
||||
|
||||
static void
|
||||
udp_device2iov(struct device *d, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
int sz = physical_MaxDeviceSize();
|
||||
|
||||
@ -174,7 +174,7 @@ static const struct device baseudpdevice = {
|
||||
|
||||
struct device *
|
||||
udp_iov2device(int type, struct physical *p, struct iovec *iov, int *niov,
|
||||
int maxiov, int *auxfd, int *nauxfd)
|
||||
int maxiov __unused, int *auxfd __unused, int *nauxfd __unused)
|
||||
{
|
||||
if (type == UDP_DEVICE) {
|
||||
struct udpdevice *dev = (struct udpdevice *)iov[(*niov)++].iov_base;
|
||||
|
@ -32,4 +32,4 @@ struct device;
|
||||
extern struct device *udp_Create(struct physical *);
|
||||
extern struct device *udp_iov2device(int, struct physical *,
|
||||
struct iovec *, int *, int, int *, int *);
|
||||
extern int udp_DeviceSize(void);
|
||||
extern unsigned udp_DeviceSize(void);
|
||||
|
@ -70,8 +70,8 @@
|
||||
#define MAX_VJHEADER 16 /* Maximum size of compressed header */
|
||||
|
||||
static struct mbuf *
|
||||
vj_LayerPush(struct bundle *bundle, struct link *l, struct mbuf *bp, int pri,
|
||||
u_short *proto)
|
||||
vj_LayerPush(struct bundle *bundle, struct link *l __unused, struct mbuf *bp,
|
||||
int pri __unused, u_short *proto)
|
||||
{
|
||||
int type;
|
||||
struct ip *pip;
|
||||
@ -162,7 +162,7 @@ VjUncompressTcp(struct ipcp *ipcp, struct mbuf *bp, u_char type)
|
||||
}
|
||||
|
||||
static struct mbuf *
|
||||
vj_LayerPull(struct bundle *bundle, struct link *l, struct mbuf *bp,
|
||||
vj_LayerPull(struct bundle *bundle, struct link *l __unused, struct mbuf *bp,
|
||||
u_short *proto)
|
||||
{
|
||||
u_char type;
|
||||
|
Loading…
x
Reference in New Issue
Block a user