IEN 88
                         User Datagram Protocol
                           Jonathan B. Postel
                               2 May 1979
                     Information Sciences Institute
                   University of Southern California
                           4676 Admiralty Way
                   Marina del Rey, California  90291
                             (213) 822-1511
IEN-88                                                         J. Postel
                                                                     ISI
                                                              2 May 1979
                         User Datagram Protocol
                         ----------------------
Introduction
------------
This User Datagram Protocol is defined to make available a datagram mode
of packet-switched  computer  communication  in the  environment  of  an
interconnected set of computer networks.  This protocol assumes that the
Internet Protocol (IN) [1] is used as the underlying protocol.
This protocol  provides  a procedure  for application  programs  to send
messages  to other programs  with a minimum  of protocol mechanism.  The
messages  delivery  is unordered and unreliable.  Applications requiring
ordered reliable delivery of streams of data should use the Transmission
Control Protocol (TCP) [2].
Format
------
                    0            15 16           31
                   +---------------+---------------+
                   !   Source      !  Destination  !
                   !    Port       !     Port      !
                   +---------------+---------------+
                   !               !               !
                   !   Length      !    Checksum   !
                   +---------------+---------------+
                   !
                   !    data octets .....
                   +------------ ...
                      User Datagram Header Format
Fields
------
Source Port is an optional field, when meaningful, it indicates the port
of the sending  process,  and may be assumed  to be the port  to which a
reply should  be addressed  in the absence of any other information.  If
not used, a value of zero is inserted.
Destination  Port has a meaning  within  the  context  of  a  particular
internet destination address.
Postel                                                          [page 1]
                                                              2 May 1979
User Datagram Protocol                                            IEN-88
Fields
Length  is the length  in octets  of this user datagram  including  this
header  and the data.   (This  means  the minimum value of the length is
four.)
Checksum  is the 16-bit  one's complement of the one's complement sum of
the source  address  and destination  address  fields  from the internet
header, the fields above, and the data, padded with zero octets at the
end to make a multiple of two octets.
If the computed  checksum  is zero,  it is transmitted  as all ones (the
equivalent  in one's complement  arithmetic).   An all zero  transmitted
checksum  value means that the transmitter  generated  no checksum  (for
debugging or for higher level protocols that don't care).
User Interface
--------------
A user interface should allow
  the creation of new receive ports,
  receive  operations  on the receive  ports that return the data octets
  and an indication of source port, if any,
  and an operation  that allows  a datagram  to be sent,  specifying the
  data and source port to be sent.
Protocol Application
--------------------
The major use of this protocol is the Internet Name Server [3].
Protocol Number
---------------
This is protocol  17 (21 octal)  when used  in  the  Internet  Protocol.
Other protocol numbers are listed in [4].
[page 2]                                                          Postel
2 May 1979
IEN-88                                            User Datagram Protocol
                                                              References
References
----------
[1]     Postel,  J.,  "Internet Datagram Protocol -- Version 4," IEN-80,
        USC-Information Sciences Institute, February 1979.
[2]     Postel,   J.,  "Transmission  Control  Protocol  --  Version 4,"
        IEN-81, USC-Information Sciences Institute, February 1979.
[3]     Postel,  J.,  "Internet  Name Server,"  USC-Information Sciences
        Institute, IEN-89, May 1979.
[4]     Postel,   J.,   "Assigned   Numbers,"  USC-Information  Sciences
        Institute, RFC-755, IEN-93, May 1979.
Postel                                                          [page 3]