3 * Copyright (C) 2018 Network Device Education Foundation, Inc. ("NetDEF")
5 * FRR is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2, or (at your option) any
10 * FRR is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with FRR; see the file COPYING. If not, write to the Free
17 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
26 #include "lib/version.h"
32 DEFINE_MGROUP(BFDD
, "Bidirectional Forwarding Detection Daemon");
33 DEFINE_MTYPE(BFDD
, BFDD_TMP
, "short-lived temporary memory");
34 DEFINE_MTYPE(BFDD
, BFDD_CONFIG
, "long-lived configuration memory");
35 DEFINE_MTYPE(BFDD
, BFDD_LABEL
, "long-lived label memory");
36 DEFINE_MTYPE(BFDD
, BFDD_CONTROL
, "long-lived control socket memory");
37 DEFINE_MTYPE(BFDD
, BFDD_SESSION_OBSERVER
, "Session observer");
38 DEFINE_MTYPE(BFDD
, BFDD_NOTIFICATION
, "short-lived control notification data");
39 DEFINE_MTYPE(BFDD
, BFDD_VRF
, "BFD VRF");
41 /* Master of threads. */
42 struct thread_master
*master
;
45 static zebra_capabilities_t _caps_p
[] = {ZCAP_BIND
, ZCAP_SYS_ADMIN
, ZCAP_NET_RAW
};
47 void socket_close(int *s
)
53 log_error("%s: close(%d): (%d) %s", __func__
, *s
, errno
,
59 static void sigusr1_handler(void)
64 static void sigterm_handler(void)
66 /* Signalize shutdown. */
69 /* Stop receiving message from zebra. */
72 /* Shutdown controller to avoid receiving anymore commands. */
75 /* Shutdown and free all protocol related memory. */
80 /* Terminate and free() FRR related memory. */
86 static struct quagga_signal_t bfd_signals
[] = {
89 .handler
= &sigusr1_handler
,
93 .handler
= &sigterm_handler
,
97 .handler
= &sigterm_handler
,
101 FRR_DAEMON_INFO(bfdd
, BFD
, .vty_port
= 2617,
102 .proghelp
= "Implementation of the BFD protocol.",
103 .signals
= bfd_signals
, .n_signals
= array_size(bfd_signals
),
104 .privs
= &bglobal
.bfdd_privs
)
106 #define OPTION_CTLSOCK 1001
107 static struct option longopts
[] = {
108 {"bfdctl", required_argument
, NULL
, OPTION_CTLSOCK
},
114 * BFD daemon related code.
116 struct bfd_global bglobal
;
118 struct bfd_diag_str_list diag_list
[] = {
119 {.str
= "control-expired", .type
= BD_CONTROL_EXPIRED
},
120 {.str
= "echo-failed", .type
= BD_ECHO_FAILED
},
121 {.str
= "neighbor-down", .type
= BD_NEIGHBOR_DOWN
},
122 {.str
= "forwarding-reset", .type
= BD_FORWARDING_RESET
},
123 {.str
= "path-down", .type
= BD_PATH_DOWN
},
124 {.str
= "concatenated-path-down", .type
= BD_CONCATPATH_DOWN
},
125 {.str
= "administratively-down", .type
= BD_ADMIN_DOWN
},
126 {.str
= "reverse-concat-path-down", .type
= BD_REVCONCATPATH_DOWN
},
130 struct bfd_state_str_list state_list
[] = {
131 {.str
= "admin-down", .type
= PTM_BFD_ADM_DOWN
},
132 {.str
= "down", .type
= PTM_BFD_DOWN
},
133 {.str
= "init", .type
= PTM_BFD_INIT
},
134 {.str
= "up", .type
= PTM_BFD_UP
},
139 static void bg_init(void)
141 struct zebra_privs_t bfdd_privs
= {
142 #if defined(FRR_USER) && defined(FRR_GROUP)
146 #if defined(VTY_GROUP)
147 .vty_group
= VTY_GROUP
,
150 .cap_num_p
= array_size(_caps_p
),
154 TAILQ_INIT(&bglobal
.bg_bcslist
);
155 TAILQ_INIT(&bglobal
.bg_obslist
);
157 memcpy(&bglobal
.bfdd_privs
, &bfdd_privs
,
161 int main(int argc
, char *argv
[])
164 bool ctlsockused
= false;
167 /* Initialize system sockets. */
170 frr_preinit(&bfdd_di
, argc
, argv
);
171 frr_opt_add("", longopts
,
172 " --bfdctl Specify bfdd control socket\n");
174 snprintf(ctl_path
, sizeof(ctl_path
), BFDD_CONTROL_SOCKET
,
177 opt
= frr_getopt(argc
, argv
, NULL
);
183 strlcpy(ctl_path
, optarg
, sizeof(ctl_path
));
193 if (bfdd_di
.pathspace
&& !ctlsockused
)
194 snprintf(ctl_path
, sizeof(ctl_path
), BFDD_CONTROL_SOCKET
,
195 "/", bfdd_di
.pathspace
);
197 #if 0 /* TODO add support for JSON configuration files. */
201 /* Initialize logging API. */
202 log_init(1, BLOG_DEBUG
, &bfdd_di
);
204 /* Initialize control socket. */
205 control_init(ctl_path
);
207 /* Initialize FRR infrastructure. */
210 /* Initialize BFD data structures. */
217 /* Initialize zebra connection. */
218 bfdd_zclient_init(&bglobal
.bfdd_privs
);
220 thread_add_read(master
, control_accept
, NULL
, bglobal
.bg_csock
,
221 &bglobal
.bg_csockev
);
223 /* Install commands. */
226 /* read configuration file and daemonize */