1 /**************************************************************************/
2 /* ---------------------------------------------------------------------- */
3 /* Copyright (C) 2006 - 2008 FRESCOR consortium partners: */
5 /* Universidad de Cantabria, SPAIN */
6 /* University of York, UK */
7 /* Scuola Superiore Sant'Anna, ITALY */
8 /* Kaiserslautern University, GERMANY */
9 /* Univ. Politécnica Valencia, SPAIN */
10 /* Czech Technical University in Prague, CZECH REPUBLIC */
12 /* Thales Communication S.A. FRANCE */
13 /* Visual Tools S.A. SPAIN */
14 /* Rapita Systems Ltd UK */
17 /* See http://www.frescor.org for a link to partners' websites */
19 /* FRESCOR project (FP6/2005/IST/5-034026) is funded */
20 /* in part by the European Union Sixth Framework Programme */
21 /* The European Union is not liable of any use that may be */
22 /* made of this code. */
25 /* This file is part of FWP (Frescor WLAN Protocol) */
27 /* FWP is free software; you can redistribute it and/or modify it */
28 /* under terms of the GNU General Public License as published by the */
29 /* Free Software Foundation; either version 2, or (at your option) any */
30 /* later version. FWP is distributed in the hope that it will be */
31 /* useful, but WITHOUT ANY WARRANTY; without even the implied warranty */
32 /* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU */
33 /* General Public License for more details. You should have received a */
34 /* copy of the GNU General Public License along with FWP; see file */
35 /* COPYING. If not, write to the Free Software Foundation, 675 Mass Ave, */
36 /* Cambridge, MA 02139, USA. */
38 /* As a special exception, including FWP header files in a file, */
39 /* instantiating FWP generics or templates, or linking other files */
40 /* with FWP objects to produce an executable application, does not */
41 /* by itself cause the resulting executable application to be covered */
42 /* by the GNU General Public License. This exception does not */
43 /* however invalidate any other reasons why the executable file might be */
44 /* covered by the GNU Public License. */
45 /**************************************************************************/
46 #include "fwp_utils.h"
50 /*#include <stdlib.h>*/
51 #include "fwp_debug.h"
54 /*const int prio_to_ac[8] = {2,3,3,2,1,1,0,0};
55 const unsigned int ac_to_tos[4] = {224,160,96,64};
56 const char *ac_to_text[4] = {[AC_VO] = "AC_VO", [AC_VI] = "AC_VI",
57 [AC_BE] = "AC_BE", [AC_BK] = "AC_BK", };
60 void fwp_timespec_add (struct timespec *sum, const struct timespec *left,
61 const struct timespec *right)
63 sum->tv_sec = left->tv_sec + right->tv_sec;
64 sum->tv_nsec = left->tv_nsec + right->tv_nsec;
66 if (sum->tv_nsec >= 1000000000){
68 sum->tv_nsec -= 1000000000;
72 void fwp_timespec_sub (struct timespec *diff, const struct timespec *left,
73 const struct timespec *right)
75 diff->tv_sec = left->tv_sec - right->tv_sec;
76 diff->tv_nsec = left->tv_nsec - right->tv_nsec;
78 if (diff->tv_nsec < 0){
80 diff->tv_nsec += 1000000000;
84 void fwp_timespec_modulo(struct timespec *remainder, struct timespec *dividend,
85 struct timespec *dividor)
89 a = dividend->tv_sec * SEC_TO_USEC + dividend->tv_nsec / USEC_TO_NSEC;
90 b = dividor->tv_sec * SEC_TO_USEC + dividor->tv_nsec / USEC_TO_NSEC;
92 remainder->tv_sec = res / SEC_TO_USEC;
93 remainder->tv_nsec = ( res % SEC_TO_USEC ) * USEC_TO_NSEC;
96 int fwp_set_rt_prio(int priority)
99 static struct sched_param param;
101 if ((maxpri = sched_get_priority_max(SCHED_FIFO)) == -1) {
102 FWP_ERROR("sched_get_priority_max call failed: %s\n",
107 if ((minpri = sched_get_priority_min(SCHED_FIFO)) == -1) {
108 FWP_ERROR("sched_get_priority_min call failed: %s\n",
113 if (priority > maxpri) {
114 FWP_ERROR("parameter %d is greater than the maximal allowed"
115 " priority %d.\n", priority, maxpri);
120 if (priority < minpri) {
121 FWP_ERROR("priority parameter %d is lower than the minimal "
122 "allowed priority %d.\n", priority, minpri);
127 param.sched_priority = priority;
129 if (sched_setscheduler(0, SCHED_FIFO, ¶m) == -1) {
130 /*FWP_ERROR("sched_setscheduler call failed: %s\n",
138 int fwp_create_unix_socket(char *path, struct sockaddr_un *addr)
142 if ((sockfd = socket(AF_UNIX, SOCK_DGRAM, 0)) == -1){
143 FWP_ERROR("socket error: %s", strerror(errno));
147 bzero(addr, sizeof(addr));
148 addr->sun_family = AF_UNIX;
149 strcpy(addr->sun_path, path);
153 if (bind(sockfd, (struct sockaddr*)addr,
154 sizeof(*addr)) == -1) {
155 FWP_ERROR("fwp_open_unix_socket - bind error: %s", strerror(errno));
162 int fwp_create_inet_socket(unsigned int port, struct sockaddr_in *addr)
166 if ((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) == -1){
167 FWP_ERROR("socket error: %s", strerror(errno));
171 addr->sin_family = AF_INET;
172 addr->sin_addr.s_addr = INADDR_ANY;
173 addr->sin_port = htons(port);
175 if (bind(sockfd, (struct sockaddr*)addr,
176 sizeof(*addr)) == -1) {
178 FWP_ERROR("bind error: %s", strerror(errno));
185 /*void block_signals(void)
189 sigemptyset(&sigset);
190 sigaddset(&sigset, SIGINT);
191 sigaddset(&sigset, SIGTERM);
192 ret = pthread_sigmask(SIG_BLOCK, &sigset, NULL);
194 FWP_ERROR("pthread_sigmask failed: %s", strerror(errno));