Network Working Group                                          Ted Lemon
Internet Draft						   Nominum, Inc.

New draft						      July,
                                                         Stuart Cheshire
                                                    Apple Computer, Inc.

Obsoletes: draft-ietf-dhc-concat-01.txt			   October, 2001
                                                     Expires January, April, 2002

		      Encoding Long DHCP Options
		     <draft-ietf-dhc-concat-01.txt>
		     <draft-ietf-dhc-concat-02.txt>

Status of this Memo

   This document is an Internet-Draft and is in full conformance with
   all provisions of Section 10 of RFC2026.

   This document is an Internet-Draft.  Internet-Drafts are working
   documents of the Internet Engineering Task Force (IETF), its areas,
   and its working groups.  Note that other groups may also distribute
   working documents as Internet-Drafts.

   Internet-Drafts are draft documents valid for a maximum of six months
   and may be updated, replaced, or obsoleted by other documents at any
   time.  It is inappropriate to use Internet-Drafts as reference
   material or to cite them other than as "work in progress".

     The list of current Internet-Drafts can be accessed at
     http://www.ietf.org/ietf/1id-abstracts.txt

     The list of Internet-Draft Shadow Directories can be accessed at
     http://www.ietf.org/shadow.html.

Abstract

     This draft specifies how DHCP options in a DHCP packet can be
     aggregated so that DHCP protocol agents can send options that are
     more than 255 bytes in length.

Introduction

     The DHCP protocol [1] specifies objects called "options" that are
     encoded in the DHCP packet to pass information between DHCP
     protocol agents.  These options are encoded as a one-byte type
     code, a one-byte length, and a buffer consisting of the number of
     bytes specified in the length, from zero to 255.

     In some cases it may be useful to send DHCP options that are
     longer than 255 bytes, however.  RFC2131 [1] specifies that when
     more than one option with a given type code appears in the DHCP
     packet, all such options should be concatenated together.   It
     does not, however, specify the order in which this concatenation
     should occur.

     We specify here an the ordering that can MUST be used by DHCP protocol
     agents when sending and receiving options with more than 255 bytes.  DHCP protocol agents MAY use the ordering described here
     to encode existing options if such   This method
     also MUST be used for splitting options exceed that are shorter than 255 bytes in
     length.  The main purpose of this specification, however, is
     bytes, if for some reason the encoding agent needs to
     provide do so.   This
     method also MUST be used whenever a decoding agent receives a specification that new DHCP option drafts can
     reference.
     packet containing more than one of a certain type of option.

Terminology

     DHCP protocol agents
	This refers to any device on the network that sends or
	receives DHCP packets - any DHCP client, server or relay
	agent.   The nature of these devices is not important to this
	specification.
     Encoding agent
        The DHCP protocol agent that is composing a DHCP packet to
	send.
     Decoding agent
        The DHCP protocol agent that is processing a DHCP packet it
	has received.
     Options
	DHCP options are collections of data with type codes that
	indicate how the options should be used.   Options can specify
	information that is required for the DHCP protocol,
	IP stack configuration parameters for the client, information
	allowing the client to rendesvous rendezvous with DHCP servers, and so
	on.
     Option overload
	The DHCP packet format is based on the BOOTP packet format
	defined in RFC951 [4].   When used by DHCP protocol agents,
	BOOTP packets have three fields that can contain options.
	These are the actual option buffer, optional parameters field, the server name buffer, sname field,
	and the filename buffer. field.   The DHCP options specification [2]
	defines the DHCP Overload option, which specifies which of
	these three
	buffers fields is actually being used in any given DHCP
	message to store DHCP options.

Requirements language

     In this document, the key words "MAY", "MUST, "MUST NOT",
     "optional", "recommended",
     "OPTIONAL", "RECOMMENDED", "SHOULD", and "SHOULD NOT", are to be
     interpreted as described in RFC2119 [3].

Applicability

     This specification applies in any case where when a DHCP protocol agent is encoding a packet
     containing options, and some of those options must be broken into
     parts.  This need can occur for two reasons.   First, it can occur either
     because
     such the value of an option that needs to be sent is longer than
     255 bytes, or bytes.   In this case, the encoding agent MUST follow the algo-
     rithm specified here.   It can also occur because there is not
     sufficient suff-
     icient space in the current output buffer to store the option, but
     there is space for part of the option, and there is space in another
     output buffer for the rest.  DHCP protocol
     agents encoding an option in   In this case MAY use case, the encoding agent
     MUST either use this algorithm
     specified here. or not send the option at all.

     This specification also applies in any case where a DHCP protocol
     agent has received a DHCP packet that contains more than one
     instance of an option of a given type.   DHCP protocol agents
     that are decoding such options MAY follow the algorithm specified
     here.

     The rationale for making this optional is that existing
     implementations have not been subject to a requirement to encode
     or decode options in   In this way, and it is not our intention to
     potentially cause existing implementations to be in violation case, the agent
     MUST concatenate these seperate instances of
     this specification. the same option in the
     way that we specify here.

The aggregate option buffer

     This behaviour only applies in cases where this specification is
     applicable, as previously defined in the Applicability section.

     DHCP options can be stored in the DHCP packet in three seperate
     portions of the packet.  These are the optional parameters field,
     the sname field, and the file field, as described in RFC2131 [1].
     This complicates the description of the option splitting
     mechanism because there are three seperate buffers fields into which
     split options may be stored. placed.

     To further complicate matters, an option that doesn't fit into
     one buffer field can't overlap the boundary into another buffer field - the
     encoding agent must instead break the option into two parts and
     store one part in each buffer.

     To simplify this discussion, we will talk about an aggregate
     option buffer, which will be the aggregate of the three buffers.
     This is a logical aggregation - the buffers MUST appear in the
     locations in the DHCP packet described in RFC2131 [1].

     The aggregate option buffer is made up of the optional parameters
     field, the file field, and the sname field, in that order.
     WARNING: This is not the physical ordering of these fields in the
     DHCP packet.

     Options MUST NOT be stored in the aggregate option buffer in such
     in such a way that they cross either boundary between the three
     fields in the aggregate buffer.

     The encoding agent is free to choose to use either or both of the
     sname field and file field.   If the encoding agent does not choose
     to use either or both of these two fields, then they MUST NOT be
     considered part of the aggregate option buffer in that case.

Encoding agent behaviour

     Encoding agents MAY split options as described in this
     specification.   Encoding agents supporting options that require
     this MUST decide to split options as based on the reasons we
     have described here, if it is necessary to
     do so in order to encode the entire contents of the option. preceding section entitled "applicability."

     Options MAY can be split on any octet boundary.  No split portion of
     an option that has been split can contain more than 255 octets.
     The split portions of the option MUST be stored in the aggregate
     option buffer in sequential order - the first split portion MUST
     be stored first in the aggregate option buffer, then the second
     portion, and so on.  The encoding agent MUST NOT attempt to
     specify any semantic information based on how the option is
     split.

     Note that because the aggregate option buffer does not represent
     the physical ordering of the DHCP packet, if an option were split
     into three parts and each part went into one of the possible
     option fields, the first part would go into the optional
     parameters field, the second part would go into the file field,
     and the third part would go into the sname field.   This
     maintains consistency with section 4.1 of RFC2131 [1].

     Each split portion of an option MUST be stored in the aggregate
     option buffer in the same way that as if it were a full normal variable-length option would be stored
     - each portion contains a single byte option type code, and then
     a single byte indicating the as
     described in RFC2132 [2].   The length fields of the each split portion
     of the option
     payload being stored in that portion, and then MUST add up to the payload
     itself.  The total length byte MUST NOT include itself or of the option
     code. data.
     For any given option being split, the option code field in each
     split portion MUST be the same.

Decoding agent behaviour

     When a decoding agent is scanning an incoming DHCP packet's
     option buffer and finds two or more options with the same option
     code, it MAY MUST consider them to be a split portions of an option as
     described
     here.  Decoding agents that support options that require the
     behaviour described in this draft MUST consider such options to
     be split. the preceding section.

     In the case that a decoding agent finds a split option, it must MUST
     treat the contents of that option as a single option, and the
     contents must MUST be ordered as reassembled in the order that was described above
     under encoding agent behaviour.

     The decoding agent MUST should ensure that when the option's
     value is used, any alignment issues that are particular to the
     machine architecture on which the decoding agent is running are
     accounted for - there is no requirement that the encoding agent
     align the options in any particular way.

     There is no semantic meaning to where an option is split - the
     encoding agent is free to split the option at any point, and the
     decoding agent MUST reassemble the split option parts into a
     single object, and MUST NOT treat each split portion of the option
     as a seperate object.

Example

     Consider an option, option 224, Bootfile name (option code 67), with a value
     of "isc.org.". "/diskless/foo".  Normally, this would be encoded as a single
     option, as follows:

       +-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+

       +----+----+---+---+---+---+---+---+---+---+---+---+---+---+---+
       | 67 | 13 | / | 224 d |  8 i | 'i' s | 's' k | 'c' l | '.' e | 'o' s | 'r' s | 'g' / | '.' f |
       +-----+-----+-----+-----+-----+-----+-----+-----+-----+-----+ o | o |
       +----+----+---+---+---+---+---+---+---+---+---+---+---+---+---+

     If an encoding agent needed to split the option in order to fit
     it into the option buffer, it could encode it as two seperate
     options, as follows, and store it in the aggregate option buffer
     in the following sequence:

       +-----+-----+-----+-----+-----+-----+-----+

       +----+---+---+---+---+---+---+---+---+
       | 67 | 7 | / | d | i | 224 s |  5 k | 'i' l | 's' e | 'c'
       +----+---+---+---+---+---+---+---+---+

       +----+---+---+---+---+---+---+---+
       | '.' 67 | 'o' 6 |
       +-----+-----+-----+-----+-----+-----+-----+

       +-----+-----+-----+-----+-----+ s | 224 s |  3 / | 'r' f | 'g' o | '.' o |
       +-----+-----+-----+-----+-----+
       +----+---+---+---+---+---+---+---+

Security Considerations

     DHCP currently provides

     This document raises no authentication or new security mechanisms. issues.  Potential exposures
     to attack in the DHCP protocol are discussed in section 7 of the
     DHCP protocol specification RFC2131 [1]. The Classless Static Routes option can
     be used to misdirect network traffic by providing incorrect IP
     addresses for routers.

References

 [1] Droms, R., "Dynamic Host Configuration Protocol", RFC 2131,
     Bucknell University, March 1997.
 [2] Alexander, S. and Droms, R., "DHCP Options and BOOTP Vendor
     Extensions", RFC 2132, Silicon Graphics, Inc., Bucknell
     University, March 1997.
 [3] Bradner, S., "Key words for use in RFCs to indicate requirement
     levels", RFC 2119, Harvard University, March 1997.
 [4] Mogul, J., Postel, Croft, W., Gilmore, J., "Internet Standard Subnetting
     Procedure", RFC950, "BOOTSTRAP PROTOCOL (BOOTP)", RFC951,
     Stanford University, USC/Information
     Sciences Institute, August Sun Microsystems, September 1985.

Author Information

Ted Lemon
Nominum, Inc.
950 Charter Street
Redwood City, CA 94043
USA
email: mellon@nominum.com Ted.Lemon@nominum.com

Stuart Cheshire
Apple Computer, Inc.
1 Infinite Loop
Cupertino
California 95014
USA
Phone: +1 408 974 3207
EMail: rfc@stuartcheshire.org

Expiration

   This document will expire on January April 31, 2002.

Full Copyright Statement

   Copyright (C) The Internet Society (2001).  All Rights Reserved.

   This document and translations of it may be copied and furnished to
   others, and derivative works that comment on or otherwise explain it
   or assist in its implementation may be prepared, copied, published
   and distributed, in whole or in part, without restriction of any
   kind, provided that the above copyright notice and this paragraph are
   included on all such copies and derivative works.  However, this
   document itself may not be modified in any way, such as by removing
   the copyright notice or references to the Internet Society or other
   Internet organizations, except as needed for the purpose of
   developing Internet standards in which case the procedures for
   copyrights defined in the Internet Standards process must be
   followed, or as required to translate it into languages other than
   English.

   The limited permissions granted above are perpetual and will not be
   revoked by the Internet Society or its successors or assigns.

   This document and the information contained herein is provided on an
   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.