Network Working Group George Swallow Internet Draft Cisco Systems, Inc. Category: Standards Track Expiration Date: October 2007 Adrian Farrel Old Dog Consulting April 2007 User Defined Errors for RSVP draft-ietf-tsvwg-rsvp-user-error-spec-00.txt Status of this Memo By submitting this Internet-Draft, each author represents that any applicable patent or other IPR claims of which he or she is aware have been or will be disclosed, and any of which he or she becomes aware will be disclosed, in accordance with Section 6 of BCP 79. 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/1id-abstracts.html The list of Internet-Draft Shadow Directories can be accessed at http://www.ietf.org/shadow.html Abstract The Resource ReserVation Protocol (RSVP) defines an ERROR_SPEC object for communicating errors. That object has a defined format that permits the definition of 256 error codes. As RSVP has been developed and extended, the convention has been to be conservative in defining new error codes. Further, no provision for user defined errors exists in RSVP. Swallow & Farrel Standards Track [Page 1] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 This document defines a new RSVP object to permit user defined error values to be communicated. Swallow & Farrel Standards Track [Page 2] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 Contents 1 Introduction .............................................. 4 1.1 Conventions ............................................... 4 2 User Defined Error ........................................ 4 3 USER_ERROR_SPEC Class ..................................... 5 3.1 Subobjects ................................................ 6 4 Procedures for using the User Error Spec .................. 7 4.1 Procedures for sending the User Error Spec ................ 7 4.2 Procedures for receiving the User Error Spec .............. 7 5 IANA Considerations ....................................... 7 6 Security Considerations ................................... 8 7 Acknowledgments ........................................... 8 8 Normative References ...................................... 8 9 Authors' Addresses ........................................ 9 Swallow & Farrel Standards Track [Page 3] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 1. Introduction The Resource ReserVation Protocol (RSVP) [RFC2205] defines an ERROR_SPEC object for communicating errors. That object has a defined format that permits the definition of 256 error codes. As RSVP has been developed and extended, the convention has been to be conservative in communicating errors. Further no provision for user defined errors exists in RSVP. When developing extensions to RSVP, it is often useful for those implementing to define error messages to aid both in the initial debugging and in testing against older versions or other implementa- tions. This document defines a new RSVP object to permit user defined errors to be communicated. This will enable organizations to define errors which they can use for internal development. These error values could also be shared with the community at large to aid in promoting interoperability between diverse implementations. RSVP PathErr and ResvErr messages require the presence of an ERROR_SPEC object. [RFC3473] defines the Notify message that also requires the presence of an ERROR_SPEC object. In order to not change the mandatory contents of these messages, this document defines a new error code value that indicates that the new object is present and carries a user defined error code. 1.1. Conventions The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to be interpreted as described in RFC 2119 [KEYWORDS]. 2. User Defined Error Error Code = : User Error Spec This error code is used to signal the presence of a USER_ERROR_SPEC. No subcodes are defined. When sending this error code, a USER_ERROR_SPEC object MUST be included in the PathErr, ResvErr or Notify message. [Editor's note: = to be assigned by IANA] Swallow & Farrel Standards Track [Page 4] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 3. USER_ERROR_SPEC Class A new RSVP object class is defined called the the USER_ERROR_SPEC Class. The class number is taken from the range 192 - 247. This is done for backward compatibility. Existing implementations will ignore the object and pass it along. USER_ERROR_SPEC object: Class = , C-Type = 1 0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +---------------+---------------+---------------+---------------+ | Enterprise Number | +---------------+---------------+---------------+---------------+ | Sub Org | Err Desc Len | User Error Value | +---------------+---------------+---------------+---------------+ | | . Error Description . . . | | +---------------+---------------+---------------+---------------+ | | . User Defined Subobjects . . . | | +---------------+---------------+---------------+---------------+ Enterprise Number A unique identifier of an organization encoded as a 32-bit integer. Enterprise Numbers are assigned by IANA. Sub-organization A unique identifier of an organization encoded as a 8-bit integer. An organization MAY use this field to create independent Error Value spaces. This is intended to facilitate teams which are doing parallel development. If independent spaces are not required, this field SHOULD be set to zero. Err Desc Len The length of the error description in the Error Description field in buyes excluding any padding. Swallow & Farrel Standards Track [Page 5] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 User Error Value A 16-bit integer The format and contents are specified by the (sub-)organization indicated by the Enterprise Number and Sub Org fields. Error Description A string of characters in US-ASCII padded with nulls (0x00) to a multiple of 4 bytes. While no format is required, it is RECOMMENDED that organizations use a published schema for this string to promote consistent decoding. User Defined Subobjects Optionally, user defined subobjects may be included. The semantics of the Type and the format and contents of the value are specified by the (sub-) organization indicated by the Enterprise Number and Sub Org fields. 3.1. Subobjects Each subobject is encoded as a TLV in the following format: 0 1 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-------------//----------------+ | Type | Length | (Subobject contents) | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-------------//----------------+ Type An 8-bit number assigned by the the (sub-) organization indicated by the Enterprise Number and Sub Org fields. Length The Length contains the total length of the Subobject contents in bytes, including the L, Type and Length fields. The Length MUST be at least 4, and MUST be a multiple of 4. Swallow & Farrel Standards Track [Page 6] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 4. Procedures for using the User Error Spec 4.1. Procedures for sending the User Error Spec A USER_ERROR_SPEC object MAY be included in any PathErr, ResvErr or Notify message. The Enterprise Number MUST be a valid value assigned by IANA. As specified in [RFC2205] and [RFC3473], an ERROR_SPEC object with a valid error code MUST be included in those messages. If no other error code applies, the error code MUST be set to , Unspecified Error. 4.2. Procedures for receiving the User Error Spec It is RECOMMENDED that implementations at a minimum log the Enter- prise Number Sub-organization, User Error Value, and Error Descrip- tion. Implementation capable of interpreting the contents of the USER_ERROR_SPEC object SHOULD take appropriate action. If a message is received containing an ERROR_SPEC object using the "User Error Spec" error code, but not containing a USER_ERROR_SPEC object, the message SHOULD be treated as malformed and handled according to [RFC2205]. Implementations SHOULD ignore repeated occurences of USER_ERROR_SPEC objects. 5. IANA Considerations This document makes the following assignments from the RSVP Error Codes and Globally-Defined Error Value Sub-Codes registry (pending IANA action): Value Name User Error Spec This document makes the following assignments from the RSVP Class Names, Class Numbers, and Class Types registry (pending IANA action): Swallow & Farrel Standards Track [Page 7] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 Number Space Value Name Class Numbers * User Error Spec Class Type 1 User Defined Error * Assignment is requested from the range 192 through 247 6. Security Considerations This document makes no changes to the basic message exchanges of [RFC2205] and [RFC3473]. It will result in a small increase in the number of error messages sent in cases where messages were silently dropped due to the lack of an appropriate error code. 7. Acknowledgments The authors would like to thank Elisheva Halevy for motivating this document and Tom Nadeau for his review and comments. 8. Normative References [RFC2205] Braden, R., Zhang, L., Berson, S., Herzog, S., and S. Jamin, "Resource ReSerVation Protocol (RSVP) -- Version 1 Functional Specification", RFC 2205, September 1997. [RFC3473] Berger, L., "Generalized Multi-Protocol Label Switching (GMPLS) Signaling Resource ReserVation Protocol-Traffic Engineering (RSVP-TE) Extensions", RFC 3473, January 2003. [KEYWORDS] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997. Swallow & Farrel Standards Track [Page 8] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 9. Authors' Addresses George Swallow Cisco Systems, Inc. Email: swallow@cisco.com Adrian Farrel Old Dog Consulting EMail: adrian@olddog.co.uk Intellectual Property The IETF takes no position regarding the validity or scope of any Intellectual Property Rights or other rights that might be claimed to pertain to the implementation or use of the technology described in this document or the extent to which any license under such rights might or might not be available; nor does it represent that it has made any independent effort to identify any such rights. Information on the procedures with respect to rights in RFC documents can be found in BCP 78 and BCP 79. Copies of IPR disclosures made to the IETF Secretariat and any assur- ances of licenses to be made available, or the result of an attempt made to obtain a general license or permission for the use of such proprietary rights by implementers or users of this specification can be obtained from the IETF on-line IPR repository at http://www.ietf.org/ipr. The IETF invites any interested party to bring to its attention any copyrights, patents or patent applications, or other proprietary rights that may cover technology that may be required to implement this standard. Please address the information to the IETF at ietf- ipr@ietf.org. Full Copyright Notice Copyright (C) The IETF Trust (2007). This document is subject to the rights, licenses and restrictions contained in BCP 78, and except as set forth therein, the authors retain all their rights. This document and the information contained herein are provided on an "AS IS" basis and THE CONTRIBUTOR, THE ORGANIZATION HE/SHE REPRESENTS Swallow & Farrel Standards Track [Page 9] Internet Draftdraft-ietf-tsvwg-rsvp-user-error-spec-00.txt April 2007 OR IS SPONSORED BY (IF ANY), THE INTERNET SOCIETY, THE IETF TRUST AND THE INTERNET ENGINEERING TASK FORCE DISCLAIM 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. Swallow & Farrel Standards Track [Page 10]