home *** CD-ROM | disk | FTP | other *** search
/ Chip 1998 February / CHIP_2_98.iso / misc / src / install / bootp.h < prev    next >
C/C++ Source or Header  |  1997-09-17  |  10KB  |  252 lines

  1. /************************************************************************
  2.           Copyright 1988, 1991 by Carnegie Mellon University
  3.  
  4.                           All Rights Reserved
  5.  
  6. Permission to use, copy, modify, and distribute this software and its
  7. documentation for any purpose and without fee is hereby granted, provided
  8. that the above copyright notice appear in all copies and that both that
  9. copyright notice and this permission notice appear in supporting
  10. documentation, and that the name of Carnegie Mellon University not be used
  11. in advertising or publicity pertaining to distribution of the software
  12. without specific, written prior permission.
  13.  
  14. CARNEGIE MELLON UNIVERSITY DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS
  15. SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
  16. IN NO EVENT SHALL CMU BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL
  17. DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  18. PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
  19. ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
  20. SOFTWARE.
  21. ************************************************************************/
  22.  
  23. /*
  24.  * Bootstrap Protocol (BOOTP).  RFC951 and RFC1395.
  25.  *
  26.  * $Id: bootp.h,v 1.1 1996/12/06 20:37:14 ewt Exp $
  27.  *
  28.  *
  29.  * This file specifies the "implementation-independent" BOOTP protocol
  30.  * information which is common to both client and server.
  31.  *
  32.  */
  33.  
  34. #include "bptypes.h"    /* for int32, u_int32 */
  35.  
  36. #define BP_CHADDR_LEN     16
  37. #define BP_SNAME_LEN     64
  38. #define BP_FILE_LEN    128
  39. #define BP_VEND_LEN     64
  40. #define BP_MINPKTSZ    300    /* to check sizeof(struct bootp) */
  41.  
  42. struct bootp {
  43.     unsigned char    bp_op;            /* packet opcode type */
  44.     unsigned char    bp_htype;            /* hardware addr type */
  45.     unsigned char    bp_hlen;            /* hardware addr length */
  46.     unsigned char    bp_hops;            /* gateway hops */
  47.     unsigned int32   bp_xid;            /* transaction ID */
  48.     unsigned short   bp_secs;            /* seconds since boot began */
  49.     unsigned short   bp_flags;            /* RFC1532 broadcast, etc. */
  50.     struct in_addr   bp_ciaddr;            /* client IP address */
  51.     struct in_addr   bp_yiaddr;            /* 'your' IP address */
  52.     struct in_addr   bp_siaddr;            /* server IP address */
  53.     struct in_addr   bp_giaddr;            /* gateway IP address */
  54.     unsigned char    bp_chaddr[BP_CHADDR_LEN];    /* client hardware address */
  55.     char         bp_sname[BP_SNAME_LEN];    /* server host name */
  56.     char         bp_file[BP_FILE_LEN];    /* boot file name */
  57.     unsigned char    bp_vend[BP_VEND_LEN];    /* vendor-specific area */
  58.     /* note that bp_vend can be longer, extending to end of packet. */
  59. };
  60.  
  61. /*
  62.  * UDP port numbers, server and client.
  63.  */
  64. #define    IPPORT_BOOTPS        67
  65. #define    IPPORT_BOOTPC        68
  66.  
  67. #define BOOTREPLY        2
  68. #define BOOTREQUEST        1
  69.  
  70. /*
  71.  * Hardware types from Assigned Numbers RFC.
  72.  */
  73. #define HTYPE_ETHERNET          1
  74. #define HTYPE_EXP_ETHERNET      2
  75. #define HTYPE_AX25          3
  76. #define HTYPE_PRONET          4
  77. #define HTYPE_CHAOS          5
  78. #define HTYPE_IEEE802          6
  79. #define HTYPE_ARCNET          7
  80.  
  81. /*
  82.  * Vendor magic cookie (v_magic) for CMU
  83.  */
  84. #define VM_CMU        "CMU"
  85.  
  86. /*
  87.  * Vendor magic cookie (v_magic) for RFC1048
  88.  */
  89. #define VM_RFC1048    { 99, 130, 83, 99 }
  90.  
  91.  
  92.  
  93. /*
  94.  * Tag values used to specify what information is being supplied in
  95.  * the vendor (options) data area of the packet.
  96.  */
  97. /* RFC 1048 */
  98. /* End of cookie */
  99. #define TAG_END            ((unsigned char) 255)
  100. /* padding for alignment */
  101. #define TAG_PAD            ((unsigned char)   0)
  102. /* Subnet mask */
  103. #define TAG_SUBNET_MASK        ((unsigned char)   1)
  104. /* Time offset from UTC for this system */
  105. #define TAG_TIME_OFFSET        ((unsigned char)   2)
  106. /* List of routers on this subnet */
  107. #define TAG_GATEWAY        ((unsigned char)   3)
  108. /* List of rfc868 time servers available to client */
  109. #define TAG_TIME_SERVER        ((unsigned char)   4)
  110. /* List of IEN 116 name servers */
  111. #define TAG_NAME_SERVER        ((unsigned char)   5)
  112. /* List of DNS name servers */
  113. #define TAG_DOMAIN_SERVER    ((unsigned char)   6)
  114. /* List of MIT-LCS UDL log servers */
  115. #define TAG_LOG_SERVER        ((unsigned char)   7)
  116. /* List of rfc865 cookie servers */
  117. #define TAG_COOKIE_SERVER    ((unsigned char)   8)
  118. /* List of rfc1179 printer servers (in order to try) */
  119. #define TAG_LPR_SERVER        ((unsigned char)   9)
  120. /* List of Imagen Impress servers (in prefered order) */
  121. #define TAG_IMPRESS_SERVER    ((unsigned char)  10)
  122. /* List of rfc887 Resourse Location servers */
  123. #define TAG_RLP_SERVER        ((unsigned char)  11)
  124. /* Hostname of client */
  125. #define TAG_HOST_NAME        ((unsigned char)  12)
  126. /* boot file size */
  127. #define TAG_BOOT_SIZE        ((unsigned char)  13)
  128. /* RFC 1395 */
  129. /* path to dump to in case of crash */
  130. #define TAG_DUMP_FILE        ((unsigned char)  14)
  131. /* domain name for use with the DNS */
  132. #define TAG_DOMAIN_NAME        ((unsigned char)  15)
  133. /* IP address of the swap server for this machine */
  134. #define TAG_SWAP_SERVER        ((unsigned char)  16)
  135. /* The path name to the root filesystem for this machine */
  136. #define TAG_ROOT_PATH        ((unsigned char)  17)
  137. /* RFC 1497 */
  138. /* filename to tftp with more options in it */
  139. #define TAG_EXTEN_FILE        ((unsigned char)  18)
  140. /* RFC 1533 */
  141. /* The following are in rfc1533 and may be used by BOOTP/DHCP */
  142. /* IP forwarding enable/disable */
  143. #define TAG_IP_FORWARD          ((unsigned char)  19)
  144. /* Non-Local source routing enable/disable */
  145. #define TAG_IP_NLSR             ((unsigned char)  20)
  146. /* List of pairs of addresses/masks to allow non-local source routing to */
  147. #define TAG_IP_POLICY_FILTER    ((unsigned char)  21)
  148. /* Maximum size of datagrams client should be prepared to reassemble */
  149. #define TAG_IP_MAX_DRS          ((unsigned char)  22)
  150. /* Default IP TTL */
  151. #define TAG_IP_TTL              ((unsigned char)  23)
  152. /* Timeout in seconds to age path MTU values found with rfc1191 */
  153. #define TAG_IP_MTU_AGE          ((unsigned char)  24)
  154. /* Table of MTU sizes to use when doing rfc1191 MTU discovery */
  155. #define TAG_IP_MTU_PLAT         ((unsigned char)  25)
  156. /* MTU to use on this interface */
  157. #define TAG_IP_MTU              ((unsigned char)  26)
  158. /* All subnets are local option */
  159. #define TAG_IP_SNARL            ((unsigned char)  27)
  160. /* broadcast address */
  161. #define TAG_IP_BROADCAST        ((unsigned char)  28)
  162. /* perform subnet mask discovery using ICMP */
  163. #define TAG_IP_SMASKDISC        ((unsigned char)  29)
  164. /* act as a subnet mask server using ICMP */
  165. #define TAG_IP_SMASKSUPP        ((unsigned char)  30)
  166. /* perform rfc1256 router discovery */
  167. #define TAG_IP_ROUTERDISC       ((unsigned char)  31)
  168. /* address to send router solicitation requests */
  169. #define TAG_IP_ROUTER_SOL_ADDR  ((unsigned char)  32)
  170. /* list of static routes to addresses (addr, router) pairs */
  171. #define TAG_IP_STATIC_ROUTES    ((unsigned char)  33)
  172. /* use trailers (rfc893) when using ARP */
  173. #define TAG_IP_TRAILER_ENC      ((unsigned char)  34)
  174. /* timeout in seconds for ARP cache entries */
  175. #define TAG_ARP_TIMEOUT         ((unsigned char)  35)
  176. /* use either Ethernet version 2 (rfc894) or IEEE 802.3 (rfc1042) */
  177. #define TAG_ETHER_IEEE          ((unsigned char)  36)
  178. /* default TCP TTL when sending TCP segments */
  179. #define TAG_IP_TCP_TTL          ((unsigned char)  37)
  180. /* time for client to wait before sending a keepalive on a TCP connection */
  181. #define TAG_IP_TCP_KA_INT       ((unsigned char)  38)
  182. /* don't send keepalive with an octet of garbage for compatability */
  183. #define TAG_IP_TCP_KA_GARBAGE   ((unsigned char)  39)
  184. /* NIS domainname */
  185. #define TAG_NIS_DOMAIN        ((unsigned char)  40)
  186. /* list of NIS servers */
  187. #define TAG_NIS_SERVER        ((unsigned char)  41)
  188. /* list of NTP servers */
  189. #define TAG_NTP_SERVER        ((unsigned char)  42)
  190. /* and stuff vendors may want to add */
  191. #define TAG_VEND_SPECIFIC       ((unsigned char)  43)
  192. /* NetBios over TCP/IP name server */
  193. #define TAG_NBNS_SERVER         ((unsigned char)  44)
  194. /* NetBios over TCP/IP NBDD servers (rfc1001/1002) */
  195. #define TAG_NBDD_SERVER         ((unsigned char)  45)
  196. /* NetBios over TCP/IP node type option for use with above */
  197. #define TAG_NBOTCP_OTPION       ((unsigned char)  46)
  198. /* NetBios over TCP/IP scopt option for use with above */
  199. #define TAG_NB_SCOPE            ((unsigned char)  47)
  200. /* list of X Window system font servers */
  201. #define TAG_XFONT_SERVER        ((unsigned char)  48)
  202. /* list of systems running X Display Manager (xdm) available to this client */
  203. #define TAG_XDISPLAY_SERVER     ((unsigned char)  49)
  204.  
  205. /* While the following are only allowed for DHCP */
  206. /* DHCP requested IP address */
  207. #define TAG_DHCP_REQ_IP         ((unsigned char)  50)
  208. /* DHCP time for lease of IP address */
  209. #define TAG_DHCP_LEASE_TIME     ((unsigned char)  51)
  210. /* DHCP options overload */
  211. #define TAG_DHCP_OPTOVER        ((unsigned char)  52)
  212. /* DHCP message type */
  213. #define TAG_DHCP_MESS_TYPE      ((unsigned char)  53)
  214. /* DHCP server identification */
  215. #define TAG_DHCP_SERVER_ID      ((unsigned char)  54)
  216. /* DHCP ordered list of requested parameters */
  217. #define TAG_DHCP_PARM_REQ_LIST  ((unsigned char)  55)
  218. /* DHCP reply message */
  219. #define TAG_DHCP_TEXT_MESSAGE   ((unsigned char)  56)
  220. /* DHCP maximum packet size willing to accept */
  221. #define TAG_DHCP_MAX_MSGSZ      ((unsigned char)  57)
  222. /* DHCP time 'til client needs to renew */
  223. #define TAG_DHCP_RENEWAL_TIME   ((unsigned char)  58)
  224. /* DHCP  time 'til client needs to rebind */
  225. #define TAG_DHCP_REBIND_TIME    ((unsigned char)  59)
  226. /* DHCP class identifier */
  227. #define TAG_DHCP_CLASSID        ((unsigned char)  60)
  228. /* DHCP client unique identifier */
  229. #define TAG_DHCP_CLIENTID       ((unsigned char)  61)
  230.  
  231. /* XXX - Add new tags here */
  232.  
  233.  
  234. /*
  235.  * "vendor" data permitted for CMU bootp clients.
  236.  */
  237.  
  238. struct cmu_vend {
  239.     char        v_magic[4];    /* magic number */
  240.     unsigned int32    v_flags;    /* flags/opcodes, etc. */
  241.     struct in_addr     v_smask;    /* Subnet mask */
  242.     struct in_addr     v_dgate;    /* Default gateway */
  243.     struct in_addr    v_dns1, v_dns2; /* Domain name servers */
  244.     struct in_addr    v_ins1, v_ins2; /* IEN-116 name servers */
  245.     struct in_addr    v_ts1, v_ts2;    /* Time servers */
  246.     int32        v_unused[6];    /* currently unused */
  247. };
  248.  
  249.  
  250. /* v_flags values */
  251. #define VF_SMASK    1    /* Subnet mask field contains valid data */
  252.