~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/uapi/linux/mroute.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/uapi/linux/mroute.h (Version linux-6.12-rc7) and /include/uapi/linux/mroute.h (Version linux-4.14.336)


  1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux      1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
  2 #ifndef _UAPI__LINUX_MROUTE_H                       2 #ifndef _UAPI__LINUX_MROUTE_H
  3 #define _UAPI__LINUX_MROUTE_H                       3 #define _UAPI__LINUX_MROUTE_H
  4                                                     4 
  5 #include <linux/sockios.h>                          5 #include <linux/sockios.h>
  6 #include <linux/types.h>                            6 #include <linux/types.h>
  7 #include <linux/in.h>           /* For struct       7 #include <linux/in.h>           /* For struct in_addr. */
  8                                                     8 
  9 /* Based on the MROUTING 3.5 defines primarily      9 /* Based on the MROUTING 3.5 defines primarily to keep
 10  * source compatibility with BSD.                  10  * source compatibility with BSD.
 11  *                                                 11  *
 12  * See the mrouted code for the original histo     12  * See the mrouted code for the original history.
 13  *                                                 13  *
 14  * Protocol Independent Multicast (PIM) data s     14  * Protocol Independent Multicast (PIM) data structures included
 15  * Carlos Picoto (cap@di.fc.ul.pt)                 15  * Carlos Picoto (cap@di.fc.ul.pt)
 16  */                                                16  */
 17                                                    17 
 18 #define MRT_BASE        200                        18 #define MRT_BASE        200
 19 #define MRT_INIT        (MRT_BASE)      /* Act     19 #define MRT_INIT        (MRT_BASE)      /* Activate the kernel mroute code      */
 20 #define MRT_DONE        (MRT_BASE+1)    /* Shu     20 #define MRT_DONE        (MRT_BASE+1)    /* Shutdown the kernel mroute           */
 21 #define MRT_ADD_VIF     (MRT_BASE+2)    /* Add     21 #define MRT_ADD_VIF     (MRT_BASE+2)    /* Add a virtual interface              */
 22 #define MRT_DEL_VIF     (MRT_BASE+3)    /* Del     22 #define MRT_DEL_VIF     (MRT_BASE+3)    /* Delete a virtual interface           */
 23 #define MRT_ADD_MFC     (MRT_BASE+4)    /* Add     23 #define MRT_ADD_MFC     (MRT_BASE+4)    /* Add a multicast forwarding entry     */
 24 #define MRT_DEL_MFC     (MRT_BASE+5)    /* Del     24 #define MRT_DEL_MFC     (MRT_BASE+5)    /* Delete a multicast forwarding entry  */
 25 #define MRT_VERSION     (MRT_BASE+6)    /* Get     25 #define MRT_VERSION     (MRT_BASE+6)    /* Get the kernel multicast version     */
 26 #define MRT_ASSERT      (MRT_BASE+7)    /* Act     26 #define MRT_ASSERT      (MRT_BASE+7)    /* Activate PIM assert mode             */
 27 #define MRT_PIM         (MRT_BASE+8)    /* ena     27 #define MRT_PIM         (MRT_BASE+8)    /* enable PIM code                      */
 28 #define MRT_TABLE       (MRT_BASE+9)    /* Spe     28 #define MRT_TABLE       (MRT_BASE+9)    /* Specify mroute table ID              */
 29 #define MRT_ADD_MFC_PROXY       (MRT_BASE+10)      29 #define MRT_ADD_MFC_PROXY       (MRT_BASE+10)   /* Add a (*,*|G) mfc entry      */
 30 #define MRT_DEL_MFC_PROXY       (MRT_BASE+11)      30 #define MRT_DEL_MFC_PROXY       (MRT_BASE+11)   /* Del a (*,*|G) mfc entry      */
 31 #define MRT_FLUSH       (MRT_BASE+12)   /* Flu !!  31 #define MRT_MAX         (MRT_BASE+11)
 32 #define MRT_MAX         (MRT_BASE+12)          << 
 33                                                    32 
 34 #define SIOCGETVIFCNT   SIOCPROTOPRIVATE           33 #define SIOCGETVIFCNT   SIOCPROTOPRIVATE        /* IP protocol privates */
 35 #define SIOCGETSGCNT    (SIOCPROTOPRIVATE+1)       34 #define SIOCGETSGCNT    (SIOCPROTOPRIVATE+1)
 36 #define SIOCGETRPF      (SIOCPROTOPRIVATE+2)       35 #define SIOCGETRPF      (SIOCPROTOPRIVATE+2)
 37                                                    36 
 38 /* MRT_FLUSH optional flags */                 << 
 39 #define MRT_FLUSH_MFC   1       /* Flush multi << 
 40 #define MRT_FLUSH_MFC_STATIC    2       /* Flu << 
 41 #define MRT_FLUSH_VIFS  4       /* Flush multi << 
 42 #define MRT_FLUSH_VIFS_STATIC   8       /* Flu << 
 43                                                << 
 44 #define MAXVIFS         32                         37 #define MAXVIFS         32
 45 typedef unsigned long vifbitmap_t;      /* Use     38 typedef unsigned long vifbitmap_t;      /* User mode code depends on this lot */
 46 typedef unsigned short vifi_t;                     39 typedef unsigned short vifi_t;
 47 #define ALL_VIFS        ((vifi_t)(-1))             40 #define ALL_VIFS        ((vifi_t)(-1))
 48                                                    41 
 49 /* Same idea as select */                          42 /* Same idea as select */
 50                                                    43 
 51 #define VIFM_SET(n,m)   ((m)|=(1<<(n)))            44 #define VIFM_SET(n,m)   ((m)|=(1<<(n)))
 52 #define VIFM_CLR(n,m)   ((m)&=~(1<<(n)))           45 #define VIFM_CLR(n,m)   ((m)&=~(1<<(n)))
 53 #define VIFM_ISSET(n,m) ((m)&(1<<(n)))             46 #define VIFM_ISSET(n,m) ((m)&(1<<(n)))
 54 #define VIFM_CLRALL(m)  ((m)=0)                    47 #define VIFM_CLRALL(m)  ((m)=0)
 55 #define VIFM_COPY(mfrom,mto)    ((mto)=(mfrom)     48 #define VIFM_COPY(mfrom,mto)    ((mto)=(mfrom))
 56 #define VIFM_SAME(m1,m2)        ((m1)==(m2))       49 #define VIFM_SAME(m1,m2)        ((m1)==(m2))
 57                                                    50 
 58 /* Passed by mrouted for an MRT_ADD_VIF - agai     51 /* Passed by mrouted for an MRT_ADD_VIF - again we use the
 59  * mrouted 3.6 structures for compatibility        52  * mrouted 3.6 structures for compatibility
 60  */                                                53  */
 61 struct vifctl {                                    54 struct vifctl {
 62         vifi_t  vifc_vifi;              /* Ind     55         vifi_t  vifc_vifi;              /* Index of VIF */
 63         unsigned char vifc_flags;       /* VIF     56         unsigned char vifc_flags;       /* VIFF_ flags */
 64         unsigned char vifc_threshold;   /* ttl     57         unsigned char vifc_threshold;   /* ttl limit */
 65         unsigned int vifc_rate_limit;   /* Rat     58         unsigned int vifc_rate_limit;   /* Rate limiter values (NI) */
 66         union {                                    59         union {
 67                 struct in_addr vifc_lcl_addr;      60                 struct in_addr vifc_lcl_addr;     /* Local interface address */
 68                 int            vifc_lcl_ifinde     61                 int            vifc_lcl_ifindex;  /* Local interface index   */
 69         };                                         62         };
 70         struct in_addr vifc_rmt_addr;   /* IPI     63         struct in_addr vifc_rmt_addr;   /* IPIP tunnel addr */
 71 };                                                 64 };
 72                                                    65 
 73 #define VIFF_TUNNEL             0x1     /* IPI     66 #define VIFF_TUNNEL             0x1     /* IPIP tunnel */
 74 #define VIFF_SRCRT              0x2     /* NI      67 #define VIFF_SRCRT              0x2     /* NI */
 75 #define VIFF_REGISTER           0x4     /* reg     68 #define VIFF_REGISTER           0x4     /* register vif */
 76 #define VIFF_USE_IFINDEX        0x8     /* use     69 #define VIFF_USE_IFINDEX        0x8     /* use vifc_lcl_ifindex instead of
 77                                            vif     70                                            vifc_lcl_addr to find an interface */
 78                                                    71 
 79 /* Cache manipulation structures for mrouted a     72 /* Cache manipulation structures for mrouted and PIMd */
 80 struct mfcctl {                                    73 struct mfcctl {
 81         struct in_addr mfcc_origin;                74         struct in_addr mfcc_origin;             /* Origin of mcast      */
 82         struct in_addr mfcc_mcastgrp;              75         struct in_addr mfcc_mcastgrp;           /* Group in question    */
 83         vifi_t  mfcc_parent;                       76         vifi_t  mfcc_parent;                    /* Where it arrived     */
 84         unsigned char mfcc_ttls[MAXVIFS];          77         unsigned char mfcc_ttls[MAXVIFS];       /* Where it is going    */
 85         unsigned int mfcc_pkt_cnt;                 78         unsigned int mfcc_pkt_cnt;              /* pkt count for src-grp */
 86         unsigned int mfcc_byte_cnt;                79         unsigned int mfcc_byte_cnt;
 87         unsigned int mfcc_wrong_if;                80         unsigned int mfcc_wrong_if;
 88         int          mfcc_expire;                  81         int          mfcc_expire;
 89 };                                                 82 };
 90                                                    83 
 91 /*  Group count retrieval for mrouted */           84 /*  Group count retrieval for mrouted */
 92 struct sioc_sg_req {                               85 struct sioc_sg_req {
 93         struct in_addr src;                        86         struct in_addr src;
 94         struct in_addr grp;                        87         struct in_addr grp;
 95         unsigned long pktcnt;                      88         unsigned long pktcnt;
 96         unsigned long bytecnt;                     89         unsigned long bytecnt;
 97         unsigned long wrong_if;                    90         unsigned long wrong_if;
 98 };                                                 91 };
 99                                                    92 
100 /* To get vif packet counts */                     93 /* To get vif packet counts */
101 struct sioc_vif_req {                              94 struct sioc_vif_req {
102         vifi_t  vifi;           /* Which iface     95         vifi_t  vifi;           /* Which iface */
103         unsigned long icount;   /* In packets      96         unsigned long icount;   /* In packets */
104         unsigned long ocount;   /* Out packets     97         unsigned long ocount;   /* Out packets */
105         unsigned long ibytes;   /* In bytes */     98         unsigned long ibytes;   /* In bytes */
106         unsigned long obytes;   /* Out bytes *     99         unsigned long obytes;   /* Out bytes */
107 };                                                100 };
108                                                   101 
109 /* This is the format the mroute daemon expect    102 /* This is the format the mroute daemon expects to see IGMP control
110  * data. Magically happens to be like an IP pa    103  * data. Magically happens to be like an IP packet as per the original
111  */                                               104  */
112 struct igmpmsg {                                  105 struct igmpmsg {
113         __u32 unused1,unused2;                    106         __u32 unused1,unused2;
114         unsigned char im_msgtype;                 107         unsigned char im_msgtype;               /* What is this */
115         unsigned char im_mbz;                     108         unsigned char im_mbz;                   /* Must be zero */
116         unsigned char im_vif;                  !! 109         unsigned char im_vif;                   /* Interface (this ought to be a vifi_t!) */
117         unsigned char im_vif_hi;               !! 110         unsigned char unused3;
118         struct in_addr im_src,im_dst;             111         struct in_addr im_src,im_dst;
119 };                                                112 };
120                                                   113 
121 /* ipmr netlink table attributes */               114 /* ipmr netlink table attributes */
122 enum {                                            115 enum {
123         IPMRA_TABLE_UNSPEC,                       116         IPMRA_TABLE_UNSPEC,
124         IPMRA_TABLE_ID,                           117         IPMRA_TABLE_ID,
125         IPMRA_TABLE_CACHE_RES_QUEUE_LEN,          118         IPMRA_TABLE_CACHE_RES_QUEUE_LEN,
126         IPMRA_TABLE_MROUTE_REG_VIF_NUM,           119         IPMRA_TABLE_MROUTE_REG_VIF_NUM,
127         IPMRA_TABLE_MROUTE_DO_ASSERT,             120         IPMRA_TABLE_MROUTE_DO_ASSERT,
128         IPMRA_TABLE_MROUTE_DO_PIM,                121         IPMRA_TABLE_MROUTE_DO_PIM,
129         IPMRA_TABLE_VIFS,                         122         IPMRA_TABLE_VIFS,
130         IPMRA_TABLE_MROUTE_DO_WRVIFWHOLE,      << 
131         __IPMRA_TABLE_MAX                         123         __IPMRA_TABLE_MAX
132 };                                                124 };
133 #define IPMRA_TABLE_MAX (__IPMRA_TABLE_MAX - 1    125 #define IPMRA_TABLE_MAX (__IPMRA_TABLE_MAX - 1)
134                                                   126 
135 /* ipmr netlink vif attribute format              127 /* ipmr netlink vif attribute format
136  * [ IPMRA_TABLE_VIFS ] - nested attribute        128  * [ IPMRA_TABLE_VIFS ] - nested attribute
137  *   [ IPMRA_VIF ] - nested attribute             129  *   [ IPMRA_VIF ] - nested attribute
138  *     [ IPMRA_VIFA_xxx ]                         130  *     [ IPMRA_VIFA_xxx ]
139  */                                               131  */
140 enum {                                            132 enum {
141         IPMRA_VIF_UNSPEC,                         133         IPMRA_VIF_UNSPEC,
142         IPMRA_VIF,                                134         IPMRA_VIF,
143         __IPMRA_VIF_MAX                           135         __IPMRA_VIF_MAX
144 };                                                136 };
145 #define IPMRA_VIF_MAX (__IPMRA_VIF_MAX - 1)       137 #define IPMRA_VIF_MAX (__IPMRA_VIF_MAX - 1)
146                                                   138 
147 /* vif-specific attributes */                     139 /* vif-specific attributes */
148 enum {                                            140 enum {
149         IPMRA_VIFA_UNSPEC,                        141         IPMRA_VIFA_UNSPEC,
150         IPMRA_VIFA_IFINDEX,                       142         IPMRA_VIFA_IFINDEX,
151         IPMRA_VIFA_VIF_ID,                        143         IPMRA_VIFA_VIF_ID,
152         IPMRA_VIFA_FLAGS,                         144         IPMRA_VIFA_FLAGS,
153         IPMRA_VIFA_BYTES_IN,                      145         IPMRA_VIFA_BYTES_IN,
154         IPMRA_VIFA_BYTES_OUT,                     146         IPMRA_VIFA_BYTES_OUT,
155         IPMRA_VIFA_PACKETS_IN,                    147         IPMRA_VIFA_PACKETS_IN,
156         IPMRA_VIFA_PACKETS_OUT,                   148         IPMRA_VIFA_PACKETS_OUT,
157         IPMRA_VIFA_LOCAL_ADDR,                    149         IPMRA_VIFA_LOCAL_ADDR,
158         IPMRA_VIFA_REMOTE_ADDR,                   150         IPMRA_VIFA_REMOTE_ADDR,
159         IPMRA_VIFA_PAD,                           151         IPMRA_VIFA_PAD,
160         __IPMRA_VIFA_MAX                          152         __IPMRA_VIFA_MAX
161 };                                                153 };
162 #define IPMRA_VIFA_MAX (__IPMRA_VIFA_MAX - 1)     154 #define IPMRA_VIFA_MAX (__IPMRA_VIFA_MAX - 1)
163                                                   155 
164 /* ipmr netlink cache report attributes */        156 /* ipmr netlink cache report attributes */
165 enum {                                            157 enum {
166         IPMRA_CREPORT_UNSPEC,                     158         IPMRA_CREPORT_UNSPEC,
167         IPMRA_CREPORT_MSGTYPE,                    159         IPMRA_CREPORT_MSGTYPE,
168         IPMRA_CREPORT_VIF_ID,                     160         IPMRA_CREPORT_VIF_ID,
169         IPMRA_CREPORT_SRC_ADDR,                   161         IPMRA_CREPORT_SRC_ADDR,
170         IPMRA_CREPORT_DST_ADDR,                   162         IPMRA_CREPORT_DST_ADDR,
171         IPMRA_CREPORT_PKT,                        163         IPMRA_CREPORT_PKT,
172         IPMRA_CREPORT_TABLE,                   << 
173         __IPMRA_CREPORT_MAX                       164         __IPMRA_CREPORT_MAX
174 };                                                165 };
175 #define IPMRA_CREPORT_MAX (__IPMRA_CREPORT_MAX    166 #define IPMRA_CREPORT_MAX (__IPMRA_CREPORT_MAX - 1)
176                                                   167 
177 /* That's all usermode folks */                   168 /* That's all usermode folks */
178                                                   169 
179 #define MFC_ASSERT_THRESH (3*HZ)                  170 #define MFC_ASSERT_THRESH (3*HZ)                /* Maximal freq. of asserts */
180                                                   171 
181 /* Pseudo messages used by mrouted */             172 /* Pseudo messages used by mrouted */
182 #define IGMPMSG_NOCACHE         1                 173 #define IGMPMSG_NOCACHE         1               /* Kern cache fill request to mrouted */
183 #define IGMPMSG_WRONGVIF        2                 174 #define IGMPMSG_WRONGVIF        2               /* For PIM assert processing (unused) */
184 #define IGMPMSG_WHOLEPKT        3                 175 #define IGMPMSG_WHOLEPKT        3               /* For PIM Register processing */
185 #define IGMPMSG_WRVIFWHOLE      4              << 
186                                                   176 
187 #endif /* _UAPI__LINUX_MROUTE_H */                177 #endif /* _UAPI__LINUX_MROUTE_H */
188                                                   178 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php