aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrodri <rgl@antares-labs.eu>2020-09-06 13:01:13 +0000
committerrodri <rgl@antares-labs.eu>2020-09-06 13:01:13 +0000
commit0df4c4b8c4e7f1012a6384a2d2845860bc153e94 (patch)
treeecbbcadd8cabd247a845bb9e01d32b3b96d0fbf1
parent6fb2c86045a74fa3c02ccd94f95d7f6344aefd9e (diff)
downloadipcalc-0df4c4b8c4e7f1012a6384a2d2845860bc153e94.tar.gz
ipcalc-0df4c4b8c4e7f1012a6384a2d2845860bc153e94.tar.bz2
ipcalc-0df4c4b8c4e7f1012a6384a2d2845860bc153e94.zip
check if the mask is correct.
-rw-r--r--main.c27
1 files changed, 25 insertions, 2 deletions
diff --git a/main.c b/main.c
index dc77019..86e2c0b 100644
--- a/main.c
+++ b/main.c
@@ -57,6 +57,18 @@ countones(u32int addr)
{
int cnt, shift;
+ for(cnt = 0, shift = 31; shift >= 0; shift--)
+ if((addr & 1<<shift) != 0)
+ cnt++;
+ return cnt;
+}
+
+/* returns the most-significant ones */
+int
+countmsones(u32int addr)
+{
+ int cnt, shift;
+
for(cnt = 0, shift = 31; cnt < 32 && (addr & 1<<shift) != 0; cnt++, shift--)
;
return cnt;
@@ -82,6 +94,14 @@ getip4(char *s)
return addr;
}
+int
+checkmask(u32int mask)
+{
+ if(countones(mask) != countmsones(mask))
+ return -1;
+ return 0;
+}
+
void
usage(void)
{
@@ -109,8 +129,11 @@ main(int argc, char *argv[])
cidr = strtol(argv[1], nil, 10);
assert(cidr > 0 && cidr <= 32);
mask = ~0 << (32-cidr);
- }else
+ }else{
mask = getip4(argv[1]);
+ if(checkmask(mask) < 0)
+ sysfatal("invalid mask");
+ }
net.addr = addr&mask;
net.mask = mask;
@@ -118,7 +141,7 @@ main(int argc, char *argv[])
net.minaddr = net.addr+1;
net.maxaddr = net.bcast-1;
net.nhosts = net.maxaddr-net.minaddr;
- net.cidr = countones(net.mask);
+ net.cidr = countmsones(net.mask);
print("%N", net);
exits(nil);