summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
6ec3472)
The constant names are the same, but they're processed differently.
/*----- Data structures ---------------------------------------------------*/
/*----- Data structures ---------------------------------------------------*/
-enum { UNUSED, STALE, USED }; /* Unix socket status values */
+/* Unix socket status values. */
+#define UNUSED 0u /* No sign of anyone using it */
+#define STALE 1u /* Socket exists, but is abandoned */
+#define USED 16u /* Socket is in active use */
+
enum { DENY, ALLOW }; /* ACL verdicts */
static int address_families[] = { AF_INET, AF_INET6, -1 };
enum { DENY, ALLOW }; /* ACL verdicts */
static int address_families[] = { AF_INET, AF_INET6, -1 };
* desperate. If the socket is in use, we fail here. (This could get
* racy. Let's not worry about that for now.)
*/
* desperate. If the socket is in use, we fail here. (This could get
* racy. Let's not worry about that for now.)
*/
- if (encode_single_inet_addr(sa, sun, !desperatep) == USED)
+ if (encode_single_inet_addr(sa, sun, !desperatep)&USED)
return (-1);
/* Next, check the corresponding wildcard address, so as to avoid
return (-1);
/* Next, check the corresponding wildcard address, so as to avoid
*/
wildcard_address(sa->sa_family, &waddr.sa);
port_to_sockaddr(&waddr.sa, port);
*/
wildcard_address(sa->sa_family, &waddr.sa);
port_to_sockaddr(&waddr.sa, port);
- if (encode_single_inet_addr(&waddr.sa, &wsun, !desperatep) == USED)
+ if (encode_single_inet_addr(&waddr.sa, &wsun, !desperatep)&USED)
return (-1);
/* We're not done yet. If this is an IPv4 address, then /also/ check (a)
return (-1);
/* We're not done yet. If this is an IPv4 address, then /also/ check (a)
*/
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&maddr.sin6, SIN(&sa));
*/
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&maddr.sin6, SIN(&sa));
- if (encode_single_inet_addr(&maddr.sa, &wsun, !desperatep) == USED)
+ if (encode_single_inet_addr(&maddr.sa, &wsun, !desperatep)&USED)
return (-1);
map_ipv4_sockaddr(&maddr.sin6, &waddr.sin);
return (-1);
map_ipv4_sockaddr(&maddr.sin6, &waddr.sin);
- if (encode_single_inet_addr(&maddr.sa, &wsun, !desperatep) == USED)
+ if (encode_single_inet_addr(&maddr.sa, &wsun, !desperatep)&USED)
return (-1);
wildcard_address(AF_INET6, &waddr.sa);
port_to_sockaddr(&waddr.sa, port);
return (-1);
wildcard_address(AF_INET6, &waddr.sa);
port_to_sockaddr(&waddr.sa, port);
- if (encode_single_inet_addr(&waddr.sa, &wsun, !desperatep) == USED)
+ if (encode_single_inet_addr(&waddr.sa, &wsun, !desperatep)&USED)
address addr;
struct sockaddr_in6 sin6;
int port = port_from_sockaddr(sa);
address addr;
struct sockaddr_in6 sin6;
int port = port_from_sockaddr(sa);
char buf[ADDRBUFSZ];
D( fprintf(stderr, "noip(%d): encode %s (%s)", getpid(),
char buf[ADDRBUFSZ];
D( fprintf(stderr, "noip(%d): encode %s (%s)", getpid(),
/* Try the address as given. If it's in use, or we don't necessarily
* want an existing socket, then we're done.
*/
/* Try the address as given. If it's in use, or we don't necessarily
* want an existing socket, then we're done.
*/
- if (encode_single_inet_addr(sa, sun, 0) == USED || (f&ENCF_FRESH))
- goto found;
+ rc = encode_single_inet_addr(sa, sun, 0);
+ if ((rc&USED) || (f&ENCF_FRESH)) goto found;
/* We're looking for a socket which already exists. This is
* unfortunately difficult, because we must deal both with wildcards and
/* We're looking for a socket which already exists. This is
* unfortunately difficult, because we must deal both with wildcards and
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&addr.sin6, SIN(sa));
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&addr.sin6, SIN(sa));
- if (encode_single_inet_addr(&addr.sa, sun, 0) == USED) goto found;
+ if (encode_single_inet_addr(&addr.sa, sun, 0)&USED) goto found;
}
wildcard_address(sa->sa_family, &addr.sa);
port_to_sockaddr(&addr.sa, port);
}
wildcard_address(sa->sa_family, &addr.sa);
port_to_sockaddr(&addr.sa, port);
- if (encode_single_inet_addr(&addr.sa, sun, 0) == USED) goto found;
+ if (encode_single_inet_addr(&addr.sa, sun, 0)&USED) goto found;
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&sin6, &addr.sin);
if (sa->sa_family == AF_INET) {
map_ipv4_sockaddr(&sin6, &addr.sin);
- if (encode_single_inet_addr(SA(&sin6), sun, 0) == USED) goto found;
+ if (encode_single_inet_addr(SA(&sin6), sun, 0)&USED) goto found;
wildcard_address(AF_INET6, &addr.sa);
port_to_sockaddr(&addr.sa, port);
wildcard_address(AF_INET6, &addr.sa);
port_to_sockaddr(&addr.sa, port);
- if (encode_single_inet_addr(&addr.sa, sun, 0) == USED) goto found;
+ if (encode_single_inet_addr(&addr.sa, sun, 0)&USED) goto found;
}
/* Well, this isn't going to work (unless a miraculous race is lost), but
}
/* Well, this isn't going to work (unless a miraculous race is lost), but