summaryrefslogtreecommitdiff
path: root/src/ipcpd/flow.c
blob: 395a0a0da77c6eb8e86643db60cdcf4df59bd526 (plain)
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
/*
 * Ouroboros - Copyright (C) 2016
 *
 * Flows
 *
 *    Dimitri Staessens <dimitri.staessens@intec.ugent.be>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 */

#include "flow.h"
#include <malloc.h>

#define OUROBOROS_PREFIX "ipcpd/flow"

#include <ouroboros/logs.h>

flow_t * flow_create(port_id_t port_id)
{
        flow_t * flow = malloc(sizeof *flow);
        flow->port_id = port_id;
        flow->flags = FLOW_O_DEFAULT;
        flow->state = FLOW_INIT;

#ifdef FLOW_MT_SAFE
        pthread_mutex_init(&flow->lock, NULL);
#endif
        return flow;
}

void flow_destroy(flow_t * flow)
{
        free(flow);
}

int flow_set_opts(flow_t * flow, uint16_t opts)
{
        if (flow == NULL) {
                LOG_ERR("Non-existing flow.");
                return -1;
        }

#ifdef FLOW_MT_SAFE
        pthread_mutex_lock(&flow->lock);
#endif

        if ((opts & FLOW_O_ACCMODE) == FLOW_O_ACCMODE) {
#ifdef FLOW_MT_SAFE
                pthread_mutex_unlock(&flow->lock);
#endif
                LOG_WARN("Invalid flow options. Setting default.");
                opts = FLOW_O_DEFAULT;
        }

        flow->flags = opts;

#ifdef FLOW_MT_SAFE
                pthread_mutex_unlock(&flow->lock);
#endif
        return 0;
}

uint16_t flow_get_opts(const flow_t * flow)
{
        if (flow == NULL) {
                LOG_ERR("Non-existing flow.");
                return FLOW_O_INVALID;
        }

        return flow->flags;
}