]> The Tcpdump Group git mirrors - tcpdump/blobdiff - ospf.h
Regenerate config files.
[tcpdump] / ospf.h
diff --git a/ospf.h b/ospf.h
index 2b1c6ee4c6b749b9b59ba5d1f163ec1e56649039..b47aaf69319deb1ca9ad49a12fade6fd62b30cde 100644 (file)
--- a/ospf.h
+++ b/ospf.h
@@ -1,4 +1,3 @@
-/* @(#) $Header: /tcpdump/master/tcpdump/ospf.h,v 1.23 2007-10-08 07:53:21 hannes Exp $ (LBL) */
 /*
  * Copyright (c) 1991, 1993, 1994, 1995, 1996, 1997
  *     The Regents of the University of California.  All rights reserved.
@@ -35,7 +34,7 @@
  * +------------------------------------+
  *
  */
-                
+
 #define OSPF_OPTION_T  0x01    /* T bit: TOS support   */
 #define OSPF_OPTION_E  0x02    /* E bit: External routes advertised    */
 #define        OSPF_OPTION_MC  0x04    /* MC bit: Multicast capable */
 #define        MCLA_VERTEX_NETWORK     2
 
 /* Link-Local-Signaling */
+#define OSPF_LLS_HDRLEN         4U /* RFC5613 Section 2.2 */
+
 #define OSPF_LLS_EO             1  /* RFC4811, RFC4812 */
 #define OSPF_LLS_MD5            2  /* RFC4813 */
 
  * TOS metric struct (will be 0 or more in router links update)
  */
 struct tos_metric {
-    u_int8_t tos_type;
-    u_int8_t reserved;
-    u_int8_t tos_metric[2];
+    uint8_t tos_type;
+    uint8_t reserved;
+    uint8_t tos_metric[2];
 };
 struct tos_link {
-    u_int8_t link_type;
-    u_int8_t link_tos_count;
-    u_int8_t tos_metric[2];
+    uint8_t link_type;
+    uint8_t link_tos_count;
+    uint8_t tos_metric[2];
 };
 union un_tos {
     struct tos_link link;
@@ -163,20 +164,20 @@ union un_tos {
 
 /* link state advertisement header */
 struct lsa_hdr {
-    u_int16_t ls_age;
-    u_int8_t ls_options;
-    u_int8_t ls_type;
+    uint16_t ls_age;
+    uint8_t ls_options;
+    uint8_t ls_type;
     union {
         struct in_addr lsa_id;
         struct { /* opaque LSAs change the LSA-ID field */
-            u_int8_t opaque_type;
-            u_int8_t opaque_id[3];
+            uint8_t opaque_type;
+            uint8_t opaque_id[3];
        } opaque_field;
     } un_lsa_id;
     struct in_addr ls_router;
-    u_int32_t ls_seq;
-    u_int16_t ls_chksum;
-    u_int16_t ls_length;
+    uint32_t ls_seq;
+    uint16_t ls_chksum;
+    uint16_t ls_length;
 };
 
 /* link state advertisement */
@@ -187,9 +188,9 @@ struct lsa {
     union {
        /* Router links advertisements */
        struct {
-           u_int8_t rla_flags;
-           u_int8_t rla_zero[1];
-           u_int16_t rla_count;
+           uint8_t rla_flags;
+           uint8_t rla_zero[1];
+           uint16_t rla_count;
            struct rlalink {
                struct in_addr link_id;
                struct in_addr link_data;
@@ -206,14 +207,14 @@ struct lsa {
        /* Summary links advertisements */
        struct {
            struct in_addr sla_mask;
-           u_int32_t sla_tosmetric[1]; /* may repeat   */
+           uint32_t sla_tosmetric[1];  /* may repeat   */
        } un_sla;
 
        /* AS external links advertisements */
        struct {
            struct in_addr asla_mask;
            struct aslametric {
-               u_int32_t asla_tosmetric;
+               uint32_t asla_tosmetric;
                struct in_addr asla_forward;
                struct in_addr asla_tag;
            } asla_metric[1];           /* may repeat   */
@@ -221,34 +222,34 @@ struct lsa {
 
        /* Multicast group membership */
        struct mcla {
-           u_int32_t mcla_vtype;
+           uint32_t mcla_vtype;
            struct in_addr mcla_vid;
        } un_mcla[1];
 
         /* Opaque TE LSA */
         struct {
-           u_int16_t type;
-           u_int16_t length;
-           u_int8_t data[1]; /* may repeat   */
+           uint16_t type;
+           uint16_t length;
+           uint8_t data[1]; /* may repeat   */
        } un_te_lsa_tlv;
 
         /* Opaque Grace LSA */
         struct {
-           u_int16_t type;
-           u_int16_t length;
-           u_int8_t data[1]; /* may repeat   */
+           uint16_t type;
+           uint16_t length;
+           uint8_t data[1]; /* may repeat   */
        } un_grace_tlv;
 
         /* Opaque Router information LSA */
         struct {
-           u_int16_t type;
-           u_int16_t length;
-           u_int8_t data[1]; /* may repeat   */
+           uint16_t type;
+           uint16_t length;
+           uint8_t data[1]; /* may repeat   */
        } un_ri_tlv;
 
         /* Unknown LSA */
         struct unknown {
-           u_int8_t data[1]; /* may repeat   */
+           uint8_t data[1]; /* may repeat   */
        } un_unknown[1];
 
     } lsa_un;
@@ -260,23 +261,23 @@ struct lsa {
  * the main header
  */
 struct ospfhdr {
-    u_int8_t ospf_version;
-    u_int8_t ospf_type;
-    u_int16_t ospf_len;
+    uint8_t ospf_version;
+    uint8_t ospf_type;
+    uint16_t ospf_len;
     struct in_addr ospf_routerid;
     struct in_addr ospf_areaid;
-    u_int16_t ospf_chksum;
-    u_int16_t ospf_authtype;
-    u_int8_t ospf_authdata[OSPF_AUTH_SIZE];
+    uint16_t ospf_chksum;
+    uint16_t ospf_authtype;
+    uint8_t ospf_authdata[OSPF_AUTH_SIZE];
     union {
 
        /* Hello packet */
        struct {
            struct in_addr hello_mask;
-           u_int16_t hello_helloint;
-           u_int8_t hello_options;
-           u_int8_t hello_priority;
-           u_int32_t hello_deadint;
+           uint16_t hello_helloint;
+           uint8_t hello_options;
+           uint8_t hello_priority;
+           uint32_t hello_deadint;
            struct in_addr hello_dr;
            struct in_addr hello_bdr;
            struct in_addr hello_neighbor[1]; /* may repeat     */
@@ -284,21 +285,21 @@ struct ospfhdr {
 
        /* Database Description packet */
        struct {
-           u_int16_t db_ifmtu;
-           u_int8_t db_options;
-           u_int8_t db_flags;
-           u_int32_t db_seq;
+           uint16_t db_ifmtu;
+           uint8_t db_options;
+           uint8_t db_flags;
+           uint32_t db_seq;
            struct lsa_hdr db_lshdr[1]; /* may repeat   */
        } un_db;
 
        /* Link State Request */
        struct lsr {
-           u_int8_t ls_type[4];
+           uint8_t ls_type[4];
             union {
                 struct in_addr ls_stateid;
                 struct { /* opaque LSAs change the LSA-ID field */
-                    u_int8_t opaque_type;
-                    u_int8_t opaque_id[3];
+                    uint8_t opaque_type;
+                    uint8_t opaque_id[3];
                 } opaque_field;
             } un_ls_stateid;
            struct in_addr ls_router;
@@ -306,7 +307,7 @@ struct ospfhdr {
 
        /* Link State Update */
        struct {
-           u_int32_t lsu_count;
+           uint32_t lsu_count;
            struct lsa lsu_lsa[1]; /* may repeat        */
        } un_lsu;
 
@@ -322,7 +323,3 @@ struct ospfhdr {
 #define        ospf_lsr        ospf_un.un_lsr
 #define        ospf_lsu        ospf_un.un_lsu
 #define        ospf_lsa        ospf_un.un_lsa
-
-/* Functions shared by ospf and ospf6 */
-extern int ospf_print_te_lsa(u_int8_t *, u_int);
-extern int ospf_print_grace_lsa(u_int8_t *, u_int);