Skip to main content

Quick Subnetting (Good for exams)

More
19 years 3 months ago #10395 by Ozzy_98
Simple Subnetting
By: Robert H. Williams III
compTIA A+\Net+, Microsoft MCP\MCSA\MCSE (2000), Cisco CCNA


What this document is about:

This document will cover two quick ways for figuring out the numbers behind subnetting. The first way involves making a simple chart, the second way uses simple math that most people can do in their head, at least for smaller numbers. The first way is recommended for any exams, or times when you need to do a lot of subnetting quickly. The second way works best if you just need to know one or two examples, or to check your work from the chart.

Pre-requirements:

This document does not tell you what subnetting is, nor does it tell you why you subnet. It also does not cover any types of binary math or the like. So to use this document, you must understand the following:

1) How to convert decimal to binary
2) How subnets and subnet masks work
3) The basic subnetting rules, such as broadcast addresses and network addresses

Subnetting process:

Part 1) Introduction to the processes covered in this document.

I will be covering two different subnetting processes. The first one takes a bit of time, as it’s a fairly large chart you have to write out. The second way needs no setup, it’s simple subtraction and division. However, for large subnets (510+ hosts) or large numbers of subnets (again, 510+) you may need scrap paper.

Part 2) Chart-Based Subnetting

If you ask any game programmer what’s the fastest way to compute something, he’ll say to pre-compute it. The idea of lookup tables, or figuring out the hard math one time, before you need too, can be applied to many things in life. Timed Cisco and CompTIA exams are one of them.

When you take exams you are not allowed to bring in any of your own paper or the like, but they hand you paper to use while in the exams (Or, dry-erase markers like at my exam place). many people do a “brain dump” where they write down all the things they can think off of the top of their head. This process gave me the idea, if I could memorize a subnetting chart, I could really reduce the time needed for subnetting questions. So, I started writing down all the math I could think of that would help me, the powers of 2, the different valid subnet masks (there’s nine different values per octets that you can have) and the binary values of these masks. Then I sorted it, and came up with a chart like this:
[code:1]
+
+
+
+
| Network Section | Host Section | Net Mask |
+---+
+
+
+
+
+
|128|1 | 0/510 | 000 0000| 126/32,766|1/9/17/25 |
|192|11 | 2/1,022 | 00 0000| 62/16,382|2/10/18/26|
|224|111 | 6/2,046 | 0 0000| 30/8,190 |3/11/19/27|
|240|1111 | 14/4,094 | 0000| 14/4,094 |4/12/20/28|
|248|1111 1 | 30/8,190 | 000| 6/2,046 |5/13/21/29|
|252|1111 11 | 62/16,382| 00| 2/1,022 |6/14/22/30|
|254|1111 111 | 126/32,766| 0| 0/510 |7/15/23/31|
|255|1111 1111| 254/65,534| | X/254 |8/16/24/32|
+---+
+
+
+
+
+
[/code:1]
While this chart may seem complex, and it may seem like you can’t make it while in the exam, it’s actually just built from some simple math. There’s seven steps to making the chart, so let’s start now...

Part 2a) Available masks.

There are nine valid numbers that can be in a subnet mask, 0, 128, 192, 224, 240, 248, 252, 254, 255.How do we get these numbers? Well, remember the numbers used in binary math:

[code:1] 128 64 32 16 8 4 2 1[/code:1]
Well, if you have 0 bits set aside for the subnet inside that octet, then the mask would be 0. If you have 1 bit, then you would have 128 for the mask. (Remember the basics of subnetting, networks start on the LEFT and move right. By adding a bit to the network side, it moves down the line) So if you have two bits for the subnet mask, it would look like this:
[code:1]
128 64 32 16 8 4 2 1
1 1 0 0 0 0 0 0
[/code:1]
Or, in other words, 128+64. 128 + 64 = 192. Three bits? 128+64+32, or 192+32, or 224. This is how we get the first column on the chart, by figuring out all the valid subnet masks. After a while you’ll just remember them, but when you start out, you may need to do a little figuring off to the side.

Before you begin, you should also note that, while there are nine values for the subnet masks, only eight are in the chart. I skipped the 0 mask, since it’s overlapped by the 255. If you have a subnet mask of 255.255.0.0 then you have both 0 and 255, I just decided to use the 255 in the B class, rather then the 0 of the C class.

So, the chart will have 8 rows of data. First column is a list of all subnet masks. Keep the binary number chart in mind when you do this. First number is 128. Then, below the, add the next number, 64, for 192. Then add 32, for 224. Then 16, for 240. Then 8 for 248, until you have all 8 subnet masks. Too much thinking? Well, let’s take a break from thinking and do an easy step, step 2.

Part 2b) Network bits

The second section on the chart shows you how many bits are user per mask.. For example, 128 uses 1 bit, so it’s written in binary as 10000000. 192 uses two, 11000000. To make it simpler to read, I just included the 1’s, or the bits used for the network. And since each number down the line uses one more bit, this is very easy to make. Just put down one 1 for 128, then two for 192, three for 224, on down to eight for 255 (255 mask uses all 8 bits for the network part of the mask). When I write it, I put a space every 4 bits, to make it quicker to read. So six bits active in the network mask would show up as 1111 11. So after this set, your chart looks like this:
[code:1]
+
+
| Network Section |
+---+
+
+
|128|1 |
|192|11 |
|224|111 |
|240|1111 |
|248|1111 1 |
|252|1111 11 |
|254|1111 111 |
|255|1111 1111|
+---+
+
[/code:1]
Part 2c) Powers of two

This part here forms a second sub-chart. I like to write out the powers of 2, generally up to 16. This helps with a lot of math, since finding the number of valid hosts is 2^(Number of host bits)-2. And powers of two are simple to do, it you do them in a row. If someone asked you, what’s 2 to the power of 17, how long would it take you? If someone asked you what’s 65536 * 2, think you could do it faster? I know I sure as hell could.

so that’s ALL you have to do, write down a 2, then each line, double it. so you get a chart like this:
[code:1]
2 | 1
4 | 2
8 | 3
16 | 4
32 | 5
64 | 6
128 | 7
256 | 8
512 | 9
1,024 | 10
2,048 | 11
4,096 | 12
8,192 | 13
16,384 | 14
32,768 | 15
65,536 | 16
[/code:1]
Simple? If you REALLY want, you can go up to the powers of 32, but not only is that kind of silly, and takes a long, long time, the higher numbers are NOT valid in subnets. How often do you see a network 10.0.0.0/7 ? So, 16 bit is a good place to stop. 24 bit would be the highest you should even think about going. So you got your nice chart, and can not do 2^1 up to 2^16 with a glance, now we need to move on to the next part of the chart, networks.

Part 2d) Networks

Before we go on, there’s something you need to keep in mind. If you have 4 bits set aside for the subnet, how many networks do you have, 2^4, or 2^4-2 ? Or even 2^4-1 ? Well, depending on the network, all three can be valid. Most people go by the -2, where it removes subnet zero and the all ones subnets. But on most new equipment, both subnets are valid. If you do a show run command on the Cisco router, you will see the current status of subnet zero, if enabled or disabled on that router.

So for this part of the chart, we’ll use networks = 2^(bits)-2. So the first mask, 128, has 1 bit set aside for networks. This would be 255.255.255.128 when used with a class C address, such as 192.168.0.0 (If it was a B class network, like 172.16.0.0, then 255.255.255.128 would have 9 bits for the subnet, not 1. 1 bit mask for a class B address is 255.255.128.0. 1 bit for a class A is 255.128.0.0)

Since the 128 mask has 1 bit, we look up on the chart 2^1, and that’s 2. 2-2 = 0, so we write that down. Keep that in mind, 128 is not a valid subnet when your not using subnet zero and all ones subnet, since that’s all that’s generated, a zero subnet and an all ones subnet. If you can use these subnets, then 128 is valid in network masks.

Below 128, the next mask is 192. This has 2 bits, so we look up the power of 2 on the chart, it’s 4. 4-2 is 2. And we move on to 224, with three bits. 2^3 is 8, 8-2 is 6, so 6 networks. We repeat this till we get to 255 mask, with 8 bits, that’s 256 -2, or 254 valid hosts per network. A standard class C network.

While you could stop, I like to at least cover subnets up to 16 bits, meaning one more pass. After the 0 on the 128, put a slash ( / ) and the find the number for 9 bits (8+1). That’s 512-2. Keep in mind, when you write the chart, the first number is when you have 1~8 bits, the second number is 9~16. I’ll cover this more in the usage section of the cart.

So, you follow the chart you wrote for the powers, subtracting two from each one, until you once again hit 255, this time with 66,534. At this point your chart looks like this:
[code:1]
+
+
| Network Section |
+---+
+
+
|128|1 | 0/510 |
|192|11 | 2/1,022 |
|224|111 | 6/2,046 |
|240|1111 | 14/4,094 |
|248|1111 1 | 30/8,190 |
|252|1111 11 | 62/16,382|
|254|1111 111 | 126/32,766|
|255|1111 1111| 254/65,534|
+---+
+
+
[/code:1]
And now it’s on the working on the host side of the chart.

Part 2e) Host bits

Now that it’s time to move onto the host section, we have three easy steps. The first one, writing the host bits, is just putting the 0’s down where the bits used for the hosts are in the net mask. For example, in 128, the mask is 10000000, and since all 0’s are for the hosts, you put on the chart 000 0000. Then each line, you remove one, until on 255 you have nothing to write. Like this:
[code:1]
000 0000
00 0000
0 0000
0000
000
00
0
[/code:1]
If you look, this should match up with the 1’s bits in the network portion. For example, the 224 mask has 111, and 0 0000. That’s eight total bits, three for the network, and five for the hosts. The last one, 255, will have no bits, while all the network masks has at least one bit. This is because of the overlap of 0 and 255 masks. If we had done the 0 mask, it would have been above the 128 line, with no bits for the network, and eight 0’s for hosts, or 0000 0000. Meaning all bits for this part is dedicated to the host.

Part 2f) Number of Hosts

Finding the number of hosts is easy, cause you already did the math. The number of hosts is 2^(Host bits)-2. The same thing as the network side, just as the network moves up, hosts move down. So, starting with 255 and moving up, you write the number of hosts per network. The first line is the dual duty 255/0 line, so it’s a bit special. You have 0 bits set aside for hosts, meaning you can not have this as a network. so we just put an X there for now. Nest up, the 254 line. We have 1 bit for the hosts. If you look at the 128 line for networks, you see that it also has 1 bit. 2^1-2 = 0, so this mask has 0 hosts. On to the 252 mask, we have two bits for hosts, and if we look at the network side, three bits is 6 networks, and for us, 6 hosts.

So, to make this side quickly, you just place an X on the last one, 255, then moving up, you copy the network numbers down. As you move up the hosts column, you move down the network column, until you hit 126 hosts. The next line, 254, you wrap around and place it behind the X, like this:





[code:1]
+
+
+
| Network Section | Host Section |
+---+
+
+
+
+
|128|1 | 0/510 | 000 0000| 126/
|192|11 | 2/1,022 | 00 0000| 62/
|224|111 | 6/2,046 | 0 0000| 30/
|240|1111 | 14/4,094 | 0000| 14/
|248|1111 1 | 30/8,190 | 000| 6/
|252|1111 11 | 62/16,382| 00| 2/
|254|1111 111 | 126/32,766| 0| 0/
|255|1111 1111| 254/65,534| | X/254
+---+
+
+
+
+
[/code:1]
So, why do these numbers not line up right? Simple, it’s cause we’re not showing the 0 mask line, remember. Since the data would be the same as 255, we skip it, but if we did show it, the chart would look like this:
[code:1]
+
+
+
| Network Section | Host Section |
+---+
+
+
+
+
| 0| | X/254 |0000 0000| 254
|128|1 | 0/510 | 000 0000| 126/
|192|11 | 2/1,022 | 00 0000| 62/
|224|111 | 6/2,046 | 0 0000| 30/
|240|1111 | 14/4,094 | 0000| 14/
|248|1111 1 | 30/8,190 | 000| 6/
|252|1111 11 | 62/16,382| 00| 2/
|254|1111 111 | 126/32,766| 0| 0/
|255|1111 1111| 254/65,534| | X/254
+---+
+
+
+
+
[/code:1]
See the pattern now? The 0 line wouldn’t have served any point, so we skipped writing it, to make things go a bit quicker. So, to finish the host section of the chart, just finish copying the numbers till you get to 32,766. Your finished chart should look like this:
[code:1]
+
+
+
| Network Section | Host Section |
+---+
+
+
+
+
|128|1 | 0/510 | 000 0000| 126/32,766|
|192|11 | 2/1,022 | 00 0000| 62/16,382|
|224|111 | 6/2,046 | 0 0000| 30/8,190 |
|240|1111 | 14/4,094 | 0000| 14/4,094 |
|248|1111 1 | 30/8,190 | 000| 6/2,046 |
|252|1111 11 | 62/16,382| 00| 2/1,022 |
|254|1111 111 | 126/32,766| 0| 0/510 |
|255|1111 1111| 254/65,534| | X/254 |
+---+
+
+
+
+
[/code:1]
And now we move on to the last part...

Part 2g) CIDR numbers

Ever seen an IP address written as 192.168.0.0/27 ? That network has 30 hosts on it per subnet, 6 subnets if you don’t count the two special ones. It’s subnet mask is 255.255.255.224. Took me about 3 seconds to find that out on the chart. The final part of this chart, the CIDR numbers. These are easy, all you have to do is write a 1 for the first net mask, 128, then a 2 for the next one, 192, down to 8 for 255. Then back to 1, place a /, then go from 9 down to 16. Start back up to the top again, and repeat until you have all 32 numbers done. Now, finally, you finished all the steps, and have finished your chart.


[code:1]
+
+
+
+
| Network Section | Host Section | Net Mask |
+---+
+
+
+
+
+
|128|1 | 0/510 | 000 0000| 126/32,766|1/9/17/25 |
|192|11 | 2/1,022 | 00 0000| 62/16,382|2/10/18/26|
|224|111 | 6/2,046 | 0 0000| 30/8,190 |3/11/19/27|
|240|1111 | 14/4,094 | 0000| 14/4,094 |4/12/20/28|
|248|1111 1 | 30/8,190 | 000| 6/2,046 |5/13/21/29|
|252|1111 11 | 62/16,382| 00| 2/1,022 |6/14/22/30|
|254|1111 111 | 126/32,766| 0| 0/510 |7/15/23/31|
|255|1111 1111| 254/65,534| | X/254 |8/16/24/32|
+---+
+
+
+
+
+
[/code:1]
Part 2h) Using the chart

Using the chart is pretty easy, but since subnetting questions can take so many forms, you need practice. Say your question is, what is the subnet for the 192.168.0.0/27 network?

Well, simple, you find /27 in the net mask section, and see it’s 224. Also, look how the net masks are setup, there’s 4 sections per numbers. The section with the number is where the split between hosts and networks takes place, so anything to the left is all 255’s, and anything to the right is 0. so it the mask it /22, then you have a 255.255 to the left, and a .0 to the right, and the number where the split it, you get that from the far left of the chart, 252 for the /22 network. Let’s try another one, /17. It’s in 1/9/17/25, the third space. So we know just at a glance it’s 255.255.?.0. Check the far left of the chart, 128. so /17 is 255.255.128.0.

Next question you get, same network, 192.168.0.0/27. How many hosts per subnet, and how many subnets are in each network? You check out where /27 is on the chart, and you see that the first section is 6 for networks, and 30 for hosts. And that’s the right answer.

But, how did you know to pick six, and not 2,046? The first number is used when you have eight or less bits for the host\network, the second is used for 9~16 bits. How you tell? Well, remember this chart is just for helping speed things up, you still have to know some for yourself. If it’s a class C address, 192.0.0.0~223.255.255.255, then it will always be 8 or less bits in the mask. So only class A and B addresses do you have to worry.

Class B addresses, 128.0.0.0~191.255.255.255, have a default subnet mask of 255.255.0.0. So if you get a class B address, and it’s a 255.255.255.x mask, then more then eight bits is used in the network section. This means for the network section, you need to use the second set of numbers. For the hosts, you still need to use the first set of numbers. Example: 172.16.8.0/26. It’s a class b network, but using a class c net mask, meaning that is has more then eight bits for networks. 1,022 networks, 62 hosts per network.

Class A addresses, 1.0.0.0~ 126.0.0.0, have a net mask of 255.0.0.0. So, how many hosts and subnets in 10.1.0.0/24 ? Well, the subnet mask is 255.255.255.0, it’s using more then 8 bits. It’s using 16 bits, the highest we bothered to make on our chart. A quick look at /24 shows us that is has 65,654 networks, and 254 hosts per network (If you get the X and it’s a valid subnet mask, skip the X to the next number, 256 in this case). It’s rare you’ll see a class A network on an exam question, just due to the huge numbers you get when working with the math. Anything higher then /24, or lower then /16, and this chart can’t do it, you would have to expand it beyond the powers of 16. It also means you’ll have 131,070 subnets, or 131,070 hosts on one network. Not often that you will encounter that on an exam...

Next example, 192.168.5.67/ 27 is on what network? This type of question is a bit harder to figure out, you would need to take the subnet mask, and AND it to the IP address. /27 is a subnet mask of 255.255.255.224, so we know 192.168.5 is part of the network address, but we need the last one. If you wanted to AND them out by hand, you would convert 67 to binary, convert 224 to binary, and convert the result back. The chart can even help, as it has the binary number of 224 right in it. However...

While we know that a /27 has 30 hosts per network, it uses 32 IP addresses per network, one used by the network address, one for broadcast address. This means that each network is a block of 32 IP addresses, or listed number of hosts, plus two. So subnet zero uses 32 addresses, 192.168.5.0~192.168.5.31. The first “valid” subnet is 192.168.5.32~192.168.5.63 (NOTE: Subnet zero is a valid subnet in most installs, but most books say it’s not valid, or won’t even cover it. Even finding for sure if it’s valid on Cisco exams can be a pain. For more info on this, check the notes at the end of this document.)

In this example, the block size is 32 for each network. To find the network of 192.168.5.67, you find out what block it’s between. The closest multiple of 32 that’s LESS then 67 is 64. So it’s on the 192.168.5.64 network. If you want math, divide 67 by block size (32), drop any remainders. For example, 67/32 = 2. Then take this, and times it by block size, 32*2 = 64. You really wouldn’t even need all these steps, since when you do the division, you already know 32*2, that’s how you find the remainder.

Another example of the same type: 172.16.96.34 255.255.240.0 is on what network? Well, looking at the subnet mask, we know 172.16.?.0 so far, just need the C section. So we need to find the block size of 240. 240 lists 14 hosts, 14+2 = block size of 16. 96/16 = 6 even. So 96 is on the 96 network address. Note: this may seem wrong, since there’s no bits left over for the host address, but remember, you have another section with host bits, the D section. So 172.16.96.0 is NOT a valid host address, it’s a network address, but our address, 172.16.96.34 is valid, and it’s on network 172.16.96.0.

Now for the longest type of question you may encounter. Given 192.168.5.0/26 network, what are ALL the valid subnets. Show Network addresses, host range, and broadcast addresses. Include subnet zero and the all ones subnet.

Sounds like fun? Well, we know the first address in subnet zero is 192.168.5.0. To find the broadcast address, we need to find the network address of the next network, and subtract one. And to find the next network broadcast address, we need to find block size once again./26 is a 255.255.255.192 subnet mask, with 62 hosts per subnet, or a block size of 64. The block size is also always the network address of the first subnet after subnet zero. So we know that the network address of the next subnet is 192.168.5.64, so the broadcast address of our network is 192.168.5.63. The host range is all numbers between network and broadcast, so in this case, 192.168.5.1~192.168.5.62. So here’s what we know so far:
[code:1]
Network #0 Network #1
Address: 192.168.5.0 Address: 192.168.5.64
First Host: 192.168.5.1
Last Host: 192.168.5.62
Broadcast: 192.168.5.63
[/code:1]
And we just have to repeat this till we get them all. Looking at the chart, you will see /26 has 2 valid subnets, plus the network 0 and all ones subnet make it four total networks to list. So this Process wouldn’t take too long. Each network address is just 64 more then the last, 0,64,128,192. Add 64 to 192, you get 256, an invalid address. So the four network addresses, 0,64,128,192. The broadcast of 0 network is the next network (64) minus 1, or 63. broadcast of 64 is 128-1, or 127. Broadcast for 192 is 255. (Last one is always 255, or 256-1). Host ranges for these networks are the numbers between host and broadcast.

This should cover anything you need to know on usage of the chart. So now it’s on to the second way, based on the 256 rule.

Part 3) 256 Rule

The 256 rule is a nice subnetting rule. When I first made a subnetting chart, I never knew about it, and never noticed it until after I was using the chart for months. I guess this is a good thing, as the chart is still faster for exams, but I never would have made it if I had known this rule.

The 256 rule is simple, you subtract the subnet mask from 256 to get the block size. For example, 255.255.255.240 has a block size of 256-240, or 16. Meaning the first subnet after the zero subnet is 16, second subnet is 32, first subnets broadcast is 31, host ranges 17~30. That’s it, done.

While the 256 rule is simple to do, sometimes it can get tricky. How many hosts can you get on the network this host is on: 172.16.56.34/23. Well, first step, you need to convert /23 into a subnet mask. If you have the chart, this is simple, just find /23. Without the chart, you have to count. 8,16 and 24 are the “even” subnet masks, 255.0.0.0, 255.255.0.0, 255.255.255.0. Since we know 23 is more then 16, and less then 24, we know it’s 255.255.?.0 mask. What you have to do, is know the valid subnet mask numbers by heart, or be able to figure them out: 0,128,192,224,240,248,252,254,255. /8,/16 and /24 all give you a 0 subnet mask (and 255 on the one before). Add one, /9,/17,/25, you get 128 mask. and just keep going on your counting.

Since we know /24 is 255.255.255.0, you can take a short cut, and use one lower mask. /23 is 255.255.254.0. Now we take the 256 - 254, and we have a block size of 2. The first network is 172.16.0.0 and the second one is 192.16.2.0, up to 172.16.56.0, where our host is on.

You may be thinking, well, block size is 2, subtract the network address and the broadcast address, 2-2 = 0, so something is invalid. Well, it would be, if it wasn’t for the 8 host addresses to the left of it. So the address of the next network is 172.16.58.0, so take one step back, the broadcast address of our 56 network is 172.16.57.255, not 172.16.57.0 like you may have been thinking. Valid host ranges on out network is 172.16.56.1~172.16.57.254. Rather then counting them, you know that there’s 2 in the block size of the c part of the address, 56 and 57, and there’s 256 addresses in each of them, so 256*2 = 512, - the network and broadcast, 510 host addresses. Like I said, anything larger then 510 you may need scrap paper, but any masks of /24 or more, this 256 rule is great.


That sums up the two ways, any questions and comments, feel free to post.
More
19 years 3 months ago #10396 by snorks
Excellent and awesome. Got 1 week off school now, and we are to design a network with 3 "departments" in it, like sale, engineering etc.

The only thing I was afraid of was subnetting, and this post came like an angel sent above. Thanks, I love you.

- snorks
More
19 years 3 months ago #10409 by mew
Except for maybe a type-o or two I find no error to your math logic or definitions. Great post. I have seen this kind of thing before but not to this extent. I know those that like the "magic number" but there are places it does not work. I know a lot of people that like math that does not include having to use binary numbers. I'm sure this will be a great help to them.

On the other hand as you may have seen my posts on subnetting before I still say if you aren't using binary you are not doing it the easy way. :lol:

It's a lot easier to learn binary than not make a mistake memorizing rules or charts. :( But that's just my opinion based on my experiences. Wouldn't is be great if they would just let people use a subnet calculator on a certification test. 8)

By the way no mater how you feel comfortable subnetting you do know that if you want to check you answers when practicing for a test. Or if you are in need of a solution for you network I hope you know you can get a really good subnet calculator for free at:

www.solarwinds.net/Tools/Free_tools/Subnet_Calc/
More
19 years 3 months ago #10412 by DaLight
Great post Ozzy_98!! I 've printed it out for later enjoyment. I know it sounds sad but as the Bishop will testify, I love my maths.
More
19 years 3 months ago #10413 by nske
Awesome! Many thanks for the time you took to write and format it Ozzy_98. :)
It can help many people, so I'm making it sticky.
More
19 years 3 months ago #10430 by rickardo
I know quite a few college lecturers in ccna who couldn't have put it as well as that :)
Time to create page: 0.144 seconds