]> git.proxmox.com Git - mirror_frr.git/blob - bfdd/bfdctl.h
Merge pull request #6333 from Spantik/ospf_default
[mirror_frr.git] / bfdd / bfdctl.h
1 /*********************************************************************
2 * Copyright 2017-2018 Network Device Education Foundation, Inc. ("NetDEF")
3 *
4 * This program is free software; you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License as published by the Free
6 * Software Foundation; either version 2 of the License, or (at your option)
7 * any later version.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12 * more details.
13 *
14 * You should have received a copy of the GNU General Public License along
15 * with this program; see the file COPYING; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17 *
18 * bfdctl.h: all BFDd control socket protocol definitions.
19 *
20 * Authors
21 * -------
22 * Rafael Zalamena <rzalamena@opensourcerouting.org>
23 */
24
25 #ifndef _BFDCTRL_H_
26 #define _BFDCTRL_H_
27
28 #include <netinet/in.h>
29
30 #include <stdbool.h>
31 #include <stdint.h>
32
33 /*
34 * Auxiliary definitions
35 */
36 struct sockaddr_any {
37 union {
38 struct sockaddr_in sa_sin;
39 struct sockaddr_in6 sa_sin6;
40 };
41 };
42
43 #ifndef MAXNAMELEN
44 #define MAXNAMELEN 32
45 #endif
46
47 #define BPC_DEF_DETECTMULTIPLIER 3
48 #define BPC_DEF_RECEIVEINTERVAL 300 /* milliseconds */
49 #define BPC_DEF_TRANSMITINTERVAL 300 /* milliseconds */
50 #define BPC_DEF_ECHOINTERVAL 50 /* milliseconds */
51
52 /* Peer status */
53 enum bfd_peer_status {
54 BPS_SHUTDOWN = 0, /* == PTM_BFD_ADM_DOWN, "adm-down" */
55 BPS_DOWN = 1, /* == PTM_BFD_DOWN, "down" */
56 BPS_INIT = 2, /* == PTM_BFD_INIT, "init" */
57 BPS_UP = 3, /* == PTM_BFD_UP, "up" */
58 };
59
60 struct bfd_peer_cfg {
61 bool bpc_mhop;
62 bool bpc_ipv4;
63 struct sockaddr_any bpc_peer;
64 struct sockaddr_any bpc_local;
65
66 bool bpc_has_label;
67 char bpc_label[MAXNAMELEN];
68
69 bool bpc_has_localif;
70 char bpc_localif[MAXNAMELEN + 1];
71
72 bool bpc_has_vrfname;
73 char bpc_vrfname[MAXNAMELEN + 1];
74
75 bool bpc_has_detectmultiplier;
76 uint8_t bpc_detectmultiplier;
77
78 bool bpc_has_recvinterval;
79 uint64_t bpc_recvinterval;
80
81 bool bpc_has_txinterval;
82 uint64_t bpc_txinterval;
83
84 bool bpc_has_echointerval;
85 uint64_t bpc_echointerval;
86
87 bool bpc_echo;
88 bool bpc_createonly;
89 bool bpc_shutdown;
90
91 bool bpc_cbit;
92
93 bool bpc_has_profile;
94 char bpc_profile[64];
95
96 /* Status information */
97 enum bfd_peer_status bpc_bps;
98 uint32_t bpc_id;
99 uint32_t bpc_remoteid;
100 uint8_t bpc_diag;
101 uint8_t bpc_remotediag;
102 uint8_t bpc_remote_detectmultiplier;
103 uint64_t bpc_remote_recvinterval;
104 uint64_t bpc_remote_txinterval;
105 uint64_t bpc_remote_echointerval;
106 uint64_t bpc_lastevent;
107 };
108
109
110 /*
111 * Protocol definitions
112 */
113 enum bc_msg_version {
114 BMV_VERSION_1 = 1,
115 };
116
117 enum bc_msg_type {
118 BMT_RESPONSE = 1,
119 BMT_REQUEST_ADD = 2,
120 BMT_REQUEST_DEL = 3,
121 BMT_NOTIFY = 4,
122 BMT_NOTIFY_ADD = 5,
123 BMT_NOTIFY_DEL = 6,
124 };
125
126 /* Notify flags to use with bcm_notify. */
127 #define BCM_NOTIFY_ALL ((uint64_t)-1)
128 #define BCM_NOTIFY_PEER_STATE (1ULL << 0)
129 #define BCM_NOTIFY_CONFIG (1ULL << 1)
130 #define BCM_NOTIFY_NONE 0
131
132 /* Response 'status' definitions. */
133 #define BCM_RESPONSE_OK "ok"
134 #define BCM_RESPONSE_ERROR "error"
135
136 /* Notify operation. */
137 #define BCM_NOTIFY_PEER_STATUS "status"
138 #define BCM_NOTIFY_CONFIG_ADD "add"
139 #define BCM_NOTIFY_CONFIG_DELETE "delete"
140 #define BCM_NOTIFY_CONFIG_UPDATE "update"
141
142 /* Notification special ID. */
143 #define BCM_NOTIFY_ID 0
144
145 struct bfd_control_msg {
146 /* Total length without the header. */
147 uint32_t bcm_length;
148 /*
149 * Message request/response id.
150 * All requests will have a correspondent response with the
151 * same id.
152 */
153 uint16_t bcm_id;
154 /* Message type. */
155 uint8_t bcm_type;
156 /* Message version. */
157 uint8_t bcm_ver;
158 /* Message payload. */
159 uint8_t bcm_data[0];
160 };
161
162 #endif