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
|
/*
* SPDX license identifier: MPL-2.0
*
* Copyright (C) 2015, Advanced Driver Information Technology
* Copyright of Advanced Driver Information Technology, Bosch and Denso
*
* This file is part of GENIVI Project DLT - Diagnostic Log and Trace.
*
* This Source Code Form is subject to the terms of the
* Mozilla Public License (MPL), v. 2.0.
* If a copy of the MPL was not distributed with this file,
* You can obtain one at http://mozilla.org/MPL/2.0/.
*
* For further information see http://www.genivi.org/.
*/
/*!
* \author
* Christoph Lipka <clipka@jp.adit-jv.com>
*
* \copyright Copyright © 2015 ADIT. \n
* License MPL-2.0: Mozilla Public License version 2.0 http://mozilla.org/MPL/2.0/.
*
* \file dlt_daemon_unix_socket.c
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/un.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <syslog.h>
#include <errno.h>
#include "dlt-daemon.h"
#include "dlt_common.h"
#include "dlt-daemon_cfg.h"
#include "dlt_daemon_socket.h"
#include "dlt_daemon_unix_socket.h"
int dlt_daemon_unix_socket_open(int *sock, char *sock_path, int type, int mask)
{
struct sockaddr_un addr;
int old_mask;
if ((sock == NULL) || (sock_path == NULL)) {
dlt_log(LOG_ERR, "dlt_daemon_unix_socket_open: arguments invalid");
return -1;
}
if ((*sock = socket(AF_UNIX, type, 0)) == -1) {
dlt_log(LOG_WARNING, "unix socket: socket() error");
return -1;
}
memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
memcpy(addr.sun_path, sock_path, sizeof(addr.sun_path));
unlink(sock_path);
/* set appropriate access permissions */
old_mask = umask(mask);
if (bind(*sock, (struct sockaddr *)&addr, sizeof(addr)) == -1) {
dlt_log(LOG_WARNING, "unix socket: bind() error");
return -1;
}
if (listen(*sock, 1) == -1) {
dlt_log(LOG_WARNING, "unix socket: listen error");
return -1;
}
/* restore permissions */
umask(old_mask);
return 0;
}
int dlt_daemon_unix_socket_close(int sock)
{
int ret = close(sock);
if (ret != 0) {
dlt_vlog(LOG_WARNING, "unix socket close failed: %s", strerror(errno));
}
return ret;
}
|