forked from IRNAS/sfp-driver
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.c
105 lines (88 loc) · 2.43 KB
/
main.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/*
* sfp-driver - SFP driver
*
* Copyright (C) 2016 Jernej Kos <jernej@kos.mx>
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero General Public License as published by the
* Free Software Foundation, either version 3 of the License, or (at your
* option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License
* for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <unistd.h>
#include <libubox/uloop.h>
#include <libubus.h>
#include <uci.h>
#include <signal.h>
#include <syslog.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <stdlib.h>
#include "sfp.h"
#include "ubus.h"
// Global ubus connection context.
static struct ubus_context *ubus;
// Global UCI context.
static struct uci_context *uci;
int main(int argc, char **argv)
{
struct stat s;
const char *ubus_socket = NULL;
int log_option = 0;
int c;
while ((c = getopt(argc, argv, "s:")) != -1) {
switch (c) {
case 's': ubus_socket = optarg; break;
case 'f': log_option |= LOG_PERROR; break;
default: break;
}
}
// Open the syslog facility.
openlog("sfp-driver", log_option, LOG_DAEMON);
// Create directory for temporary run files.
if (stat("/var/run/sfp-driver", &s))
mkdir("/var/run/sfp-driver", 0700);
umask(0077);
// Setup signal handlers.
signal(SIGPIPE, SIG_IGN);
// Initialize the event loop.
uloop_init();
// Attempt to establish connection to ubus daemon.
for (;;) {
ubus = ubus_connect(ubus_socket);
if (!ubus) {
syslog(LOG_WARNING, "Failed to connect to ubus!");
sleep(10);
continue;
}
break;
}
ubus_add_uloop(ubus);
// Initialize UCI context.
uci = uci_alloc_context();
if (!uci) {
syslog(LOG_ERR, "Failed to initialize UCI!");
return -1;
}
if (sfp_init(uci) != 0) {
syslog(LOG_ERR, "Failed to initialize SFP!");
return -1;
}
if (ubus_init(ubus) != 0) {
syslog(LOG_ERR, "Failed to initialize ubus!");
return -1;
}
// Enter the event loop and cleanup after it exits.
uloop_run();
ubus_free(ubus);
uci_free_context(uci);
uloop_done();
return 0;
}