xref: /utopia/UTPA2-700.0.x/projects/tools/lint/mips-linux-gnu_include/linux/atmmpc.h (revision 53ee8cc121a030b8d368113ac3e966b4705770ef)
1*53ee8cc1Swenshuai.xi #ifndef _ATMMPC_H_
2*53ee8cc1Swenshuai.xi #define _ATMMPC_H_
3*53ee8cc1Swenshuai.xi 
4*53ee8cc1Swenshuai.xi #include <linux/atmapi.h>
5*53ee8cc1Swenshuai.xi #include <linux/atmioc.h>
6*53ee8cc1Swenshuai.xi #include <linux/atm.h>
7*53ee8cc1Swenshuai.xi 
8*53ee8cc1Swenshuai.xi #define ATMMPC_CTRL _IO('a', ATMIOC_MPOA)
9*53ee8cc1Swenshuai.xi #define ATMMPC_DATA _IO('a', ATMIOC_MPOA+1)
10*53ee8cc1Swenshuai.xi 
11*53ee8cc1Swenshuai.xi #define MPC_SOCKET_INGRESS 1
12*53ee8cc1Swenshuai.xi #define MPC_SOCKET_EGRESS  2
13*53ee8cc1Swenshuai.xi 
14*53ee8cc1Swenshuai.xi struct atmmpc_ioc {
15*53ee8cc1Swenshuai.xi         int dev_num;
16*53ee8cc1Swenshuai.xi         __be32 ipaddr;              /* the IP address of the shortcut    */
17*53ee8cc1Swenshuai.xi         int type;                     /* ingress or egress                 */
18*53ee8cc1Swenshuai.xi };
19*53ee8cc1Swenshuai.xi 
20*53ee8cc1Swenshuai.xi typedef struct in_ctrl_info {
21*53ee8cc1Swenshuai.xi         uint8_t   Last_NHRP_CIE_code;
22*53ee8cc1Swenshuai.xi         uint8_t   Last_Q2931_cause_value;
23*53ee8cc1Swenshuai.xi         uint8_t   eg_MPC_ATM_addr[ATM_ESA_LEN];
24*53ee8cc1Swenshuai.xi         __be32  tag;
25*53ee8cc1Swenshuai.xi         __be32  in_dst_ip;      /* IP address this ingress MPC sends packets to */
26*53ee8cc1Swenshuai.xi         uint16_t  holding_time;
27*53ee8cc1Swenshuai.xi         uint32_t  request_id;
28*53ee8cc1Swenshuai.xi } in_ctrl_info;
29*53ee8cc1Swenshuai.xi 
30*53ee8cc1Swenshuai.xi typedef struct eg_ctrl_info {
31*53ee8cc1Swenshuai.xi         uint8_t   DLL_header[256];
32*53ee8cc1Swenshuai.xi         uint8_t   DH_length;
33*53ee8cc1Swenshuai.xi         __be32  cache_id;
34*53ee8cc1Swenshuai.xi         __be32  tag;
35*53ee8cc1Swenshuai.xi         __be32  mps_ip;
36*53ee8cc1Swenshuai.xi         __be32  eg_dst_ip;      /* IP address to which ingress MPC sends packets */
37*53ee8cc1Swenshuai.xi         uint8_t   in_MPC_data_ATM_addr[ATM_ESA_LEN];
38*53ee8cc1Swenshuai.xi         uint16_t  holding_time;
39*53ee8cc1Swenshuai.xi } eg_ctrl_info;
40*53ee8cc1Swenshuai.xi 
41*53ee8cc1Swenshuai.xi struct mpc_parameters {
42*53ee8cc1Swenshuai.xi         uint16_t mpc_p1;   /* Shortcut-Setup Frame Count    */
43*53ee8cc1Swenshuai.xi         uint16_t mpc_p2;   /* Shortcut-Setup Frame Time     */
44*53ee8cc1Swenshuai.xi         uint8_t mpc_p3[8]; /* Flow-detection Protocols      */
45*53ee8cc1Swenshuai.xi         uint16_t mpc_p4;   /* MPC Initial Retry Time        */
46*53ee8cc1Swenshuai.xi         uint16_t mpc_p5;   /* MPC Retry Time Maximum        */
47*53ee8cc1Swenshuai.xi         uint16_t mpc_p6;   /* Hold Down Time                */
48*53ee8cc1Swenshuai.xi } ;
49*53ee8cc1Swenshuai.xi 
50*53ee8cc1Swenshuai.xi struct k_message {
51*53ee8cc1Swenshuai.xi         uint16_t type;
52*53ee8cc1Swenshuai.xi         __be32 ip_mask;
53*53ee8cc1Swenshuai.xi         uint8_t  MPS_ctrl[ATM_ESA_LEN];
54*53ee8cc1Swenshuai.xi         union {
55*53ee8cc1Swenshuai.xi                 in_ctrl_info in_info;
56*53ee8cc1Swenshuai.xi                 eg_ctrl_info eg_info;
57*53ee8cc1Swenshuai.xi                 struct mpc_parameters params;
58*53ee8cc1Swenshuai.xi         } content;
59*53ee8cc1Swenshuai.xi         struct atm_qos qos;
60*53ee8cc1Swenshuai.xi } __ATM_API_ALIGN;
61*53ee8cc1Swenshuai.xi 
62*53ee8cc1Swenshuai.xi struct llc_snap_hdr {
63*53ee8cc1Swenshuai.xi 	/* RFC 1483 LLC/SNAP encapsulation for routed IP PDUs */
64*53ee8cc1Swenshuai.xi         uint8_t  dsap;    /* Destination Service Access Point (0xAA)     */
65*53ee8cc1Swenshuai.xi         uint8_t  ssap;    /* Source Service Access Point      (0xAA)     */
66*53ee8cc1Swenshuai.xi         uint8_t  ui;      /* Unnumbered Information           (0x03)     */
67*53ee8cc1Swenshuai.xi         uint8_t  org[3];  /* Organizational identification    (0x000000) */
68*53ee8cc1Swenshuai.xi         uint8_t  type[2]; /* Ether type (for IP)              (0x0800)   */
69*53ee8cc1Swenshuai.xi };
70*53ee8cc1Swenshuai.xi 
71*53ee8cc1Swenshuai.xi /* TLVs this MPC recognizes */
72*53ee8cc1Swenshuai.xi #define TLV_MPOA_DEVICE_TYPE         0x00a03e2a
73*53ee8cc1Swenshuai.xi 
74*53ee8cc1Swenshuai.xi /* MPOA device types in MPOA Device Type TLV */
75*53ee8cc1Swenshuai.xi #define NON_MPOA    0
76*53ee8cc1Swenshuai.xi #define MPS         1
77*53ee8cc1Swenshuai.xi #define MPC         2
78*53ee8cc1Swenshuai.xi #define MPS_AND_MPC 3
79*53ee8cc1Swenshuai.xi 
80*53ee8cc1Swenshuai.xi 
81*53ee8cc1Swenshuai.xi /* MPC parameter defaults */
82*53ee8cc1Swenshuai.xi 
83*53ee8cc1Swenshuai.xi #define MPC_P1 10  /* Shortcut-Setup Frame Count  */
84*53ee8cc1Swenshuai.xi #define MPC_P2 1   /* Shortcut-Setup Frame Time   */
85*53ee8cc1Swenshuai.xi #define MPC_P3 0   /* Flow-detection Protocols    */
86*53ee8cc1Swenshuai.xi #define MPC_P4 5   /* MPC Initial Retry Time      */
87*53ee8cc1Swenshuai.xi #define MPC_P5 40  /* MPC Retry Time Maximum      */
88*53ee8cc1Swenshuai.xi #define MPC_P6 160 /* Hold Down Time              */
89*53ee8cc1Swenshuai.xi #define HOLDING_TIME_DEFAULT 1200 /* same as MPS-p7 */
90*53ee8cc1Swenshuai.xi 
91*53ee8cc1Swenshuai.xi /* MPC constants */
92*53ee8cc1Swenshuai.xi 
93*53ee8cc1Swenshuai.xi #define MPC_C1 2   /* Retry Time Multiplier       */
94*53ee8cc1Swenshuai.xi #define MPC_C2 60  /* Initial Keep-Alive Lifetime */
95*53ee8cc1Swenshuai.xi 
96*53ee8cc1Swenshuai.xi /* Message types - to MPOA daemon */
97*53ee8cc1Swenshuai.xi 
98*53ee8cc1Swenshuai.xi #define SND_MPOA_RES_RQST    201
99*53ee8cc1Swenshuai.xi #define SET_MPS_CTRL_ADDR    202
100*53ee8cc1Swenshuai.xi #define SND_MPOA_RES_RTRY    203 /* Different type in a retry due to req id         */
101*53ee8cc1Swenshuai.xi #define STOP_KEEP_ALIVE_SM   204
102*53ee8cc1Swenshuai.xi #define EGRESS_ENTRY_REMOVED 205
103*53ee8cc1Swenshuai.xi #define SND_EGRESS_PURGE     206
104*53ee8cc1Swenshuai.xi #define DIE                  207 /* tell the daemon to exit()                       */
105*53ee8cc1Swenshuai.xi #define DATA_PLANE_PURGE     208 /* Data plane purge because of egress cache hit miss or dead MPS */
106*53ee8cc1Swenshuai.xi #define OPEN_INGRESS_SVC     209
107*53ee8cc1Swenshuai.xi 
108*53ee8cc1Swenshuai.xi /* Message types - from MPOA daemon */
109*53ee8cc1Swenshuai.xi 
110*53ee8cc1Swenshuai.xi #define MPOA_TRIGGER_RCVD     101
111*53ee8cc1Swenshuai.xi #define MPOA_RES_REPLY_RCVD   102
112*53ee8cc1Swenshuai.xi #define INGRESS_PURGE_RCVD    103
113*53ee8cc1Swenshuai.xi #define EGRESS_PURGE_RCVD     104
114*53ee8cc1Swenshuai.xi #define MPS_DEATH             105
115*53ee8cc1Swenshuai.xi #define CACHE_IMPOS_RCVD      106
116*53ee8cc1Swenshuai.xi #define SET_MPC_CTRL_ADDR     107 /* Our MPC's control ATM address   */
117*53ee8cc1Swenshuai.xi #define SET_MPS_MAC_ADDR      108
118*53ee8cc1Swenshuai.xi #define CLEAN_UP_AND_EXIT     109
119*53ee8cc1Swenshuai.xi #define SET_MPC_PARAMS        110 /* MPC configuration parameters    */
120*53ee8cc1Swenshuai.xi 
121*53ee8cc1Swenshuai.xi /* Message types - bidirectional */
122*53ee8cc1Swenshuai.xi 
123*53ee8cc1Swenshuai.xi #define RELOAD                301 /* kill -HUP the daemon for reload */
124*53ee8cc1Swenshuai.xi 
125*53ee8cc1Swenshuai.xi #endif /* _ATMMPC_H_ */
126