summaryrefslogtreecommitdiff
path: root/doc/rfc/rfc940.txt
blob: 17edde16b0c4cb3e9c7760523ceabe0529ad8716 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
Network Working Group                                               GADS
Request for Comments: 940 
                                                              April 1985

           Toward an Internet Standard Scheme for Subnetting


STATUS OF THIS MEMO

   This RFC discusses standardizing the protocol used in subnetted
   environments in the ARPA-Internet.  Distribution of this memo is
   unlimited.

   The author of this RFC is the Gateway Algorithms and Data Structures
   (GADS) Task Force, chaired by David L. Mills.

INTRODUCTION

   Several sites now contain a complex of local links connected to the
   Internet via a gateway.  The details of the internal connectivity are
   of little interest to the rest of the Internet.

   One way of organizing these local complexes of links is to use the
   same strategy as the Internet uses to organize networks, that is, to
   declare each link to be an entity (like a network) and to
   interconnect the links with devices that perform routing functions
   (like gateways).  This general scheme is called subnetting, the
   individual links are called subnets, and the connecting devices are
   called subgateways (or bridges, or gateways).

   All hosts in the Internet must make a decision when sending a
   datagram, that is, they must answer the question "Is this datagram
   addressed to a host on a directly connected network, or must it be
   sent to a gateway?".  In a subnetted environment, this question is
   extended to "Is this datagram addressed to a host on a directly
   connected subnet, or must it be sent to a (sub)gateway?".  Let us
   call answering this question "making the routing decision".

   Because the hosts used in a subnetted environment must implement in
   their IP or network interface software procedures for making the
   routing decision, and because such hosts may be acquired from various
   sources, it is important that a standard subnetting scheme be
   identified so that different suppliers can provide compatible hosts
   (that is, hosts compatible with the complexes at different sites and
   each other).  Without a designated standard for a subnetting scheme
   suppliers can not create compatible hosts.

   The potential problem is that if different subnetting schemes are
   developed by different suppliers a customer that installs hosts from
   two or more suppliers may find that they do not work together.



GADS                                                            [Page 1]

^L


RFC 940                                                       April 1985
Toward an Internet Standard Scheme for Subnetting


   This topic has been discussed in a set of RFCs [1,2,3,4] and in a
   flurry of messages in the Gateway Algorithms and Data Structures Task
   Force.  It is strongly suggested that if subnetting is used at all,
   it be according this new standard scheme.

APPROACH

   An Internet address currently consists of a two-layer hierarchy, a
   'network' and a per-network 'rest' field.  This subnet scheme adds an
   optional 'subnet' layer and field.

   The subnet field is created by stealing some bits from the rest (or
   host) field of the address.  The details of the subnet field are site
   specific.  All three classes (A, B, and C) of networks may be
   subnetted.

   The use of subnets is an optional local decision.  The fact that a
   network has subnets is invisible outside that network, and the change
   is local and can be instituted at a site without any global Internet
   perturbations.  A complex of links is assigned a single IP network
   number, and outside that complex it appears as a single network with
   that number.  Only inside does local structure appear.

   However, while the decision to use subnets at a site is optional, any
   IP implementation which may possibly be used in a potentially
   subnetted environment, should provide for subnet field configuration
   as described above.  Such an implementation will function properly in
   environments with or without subnetting.  On the other hand,
   implementations lacking this provision will not function in a
   subnetted environment, and are thus potentially less useful.

   This specifications is not intended to require a particular
   implementation technique inside the host, but rather to define the
   external behavior of the host in a subnetted environment.  It does
   not specify how routing is done or the details of host construction.
   Note that gateways are hosts, too.

   However, it seems easiest to explain the approach by describing one
   possible host implementation.

      Example Implementation:

         Let us use "subnet" to mean the locally attached transmission
         medium.

         The key decision to be made is "Is the destination IP address



GADS                                                            [Page 2]

^L


RFC 940                                                       April 1985
Toward an Internet Standard Scheme for Subnetting


         on my subnet or not?".  Once this decision is made the host
         knows to whether to send the datagram directly to the
         destination on the subnet or to send the datagram to a gateway.

         The host uses a 32-bit mask, along with the host's own IP
         address, to determine whether or not destination IP addresses
         are on its subnet.

         The mask can be configured at boot time as a static quantity or
         distributed by a protocol that is beyond the scope of this
         memo.

         If the bitwise AND of the mask with the destination IP address
         matches the bitwise AND of the mask with the host's own IP
         address, the destination is assumed on its subnet; if not, the
         destination is assumed on a subnet or network reachable only
         via a gateway.

            Note: if the mask is all zeros, all destinations will appear
            to be on this subnet; while, if the mask is all ones, only
            the sending host itself will appear to be on this subnet.
            If the mask contains ones in the network field and zeros in
            the rest field, subnets are not in use.

         The above procedure must be treated as a per interface
         procedure for multihomed hosts.

   For further information on background and rationale, see RFC-917,
   "Internet Subnets" [1].

REFERENCES

   [1]  Mogul, J., "Internet Subnets", RFC-917, Stanford University,
   October 1984.

   [2]  Postel, J., "Multi-LAN Address Resolution", RFC-925,
   USC/Information Sciences Institute, October 1984.

   [3]  Clark, D., "A Subnetwork Addressing Scheme", RFC-932, MIT LCS,
   January 1985.

   [4]  Karels, M., "Another Internet Subnet Addressing Scheme",
   RFC-936, UC Berkeley, February 1985.






GADS                                                            [Page 3]

^L