aboutsummaryrefslogtreecommitdiff
path: root/src/midbro.c
blob: 80433d663e0ff983811f6a2f322e4b1ec1ad4bd4 (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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
 * Copyright 2017 Robert Gustafsson
 * Copyright 2017 Robin Krahl
 * Copyright 2017 Andreas Lindhé
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

#include <pthread.h>
#include <unistd.h>
#include <signal.h>
#include "fifoqueue.h"
#include "broevent.h"
#include "midbro.h"
#ifdef BROCCOLI
#include <broccoli.h>
#endif

Fifo_q * queue;
pthread_t event_listener;
sigset_t signal_set;

    void
sigint_handler(int signal)
{
    printf("\nStatistics:\n"
            "Total values received: %d\n"
            "Total values dropped: %d\n"
            "Total values released: %d\n"
            "Maximum buffer utilization: %d\n"
            "Buffer fixed size: %d\n"
            "Buffer size upon termination: %d\n",
            queue->valuesReceived, queue->droppedValues,
            queue->valuesReleased, queue->largestBufferSize,
            queue->maxSize, queue->currentSize);
    exit(0);
}
    void
request_n_values(int number, int arrayOfValues[])
{
    int i;
    Sensor_t * sensor;
    for(i=0; i<number; ++i){
        sensor = pop_from_queue(queue);
        arrayOfValues[i] = sensor->value;
        free(sensor);
    }
#ifdef DEBUG
    printf("Release %d sensor data values\n", number);
#endif
}
    int
request_value()
{
    int value;
    Sensor_t * sensor;
    sensor = pop_from_queue(queue);
    value = sensor->value;
    free(sensor);
#ifdef DEBUG
    printf("Release 1 sensor data value\n");
#endif
    return value;
}

    void
start_data_capture()
{
    int res;
    queue = init_queue(500); /* Initiate queue with fixed size */
    /* Create producer thread that listen for bro events */
    sigemptyset(&signal_set);
    sigaddset(&signal_set, SIGINT);
    res = pthread_sigmask(SIG_BLOCK, &signal_set, NULL);
    if(res != 0)
        perror("SIGINT block");
    res = pthread_create(&event_listener, NULL, bro_event_listener, queue);
    if(res){
        perror("Unable to create thread");
        exit(-1);
    }
    res = pthread_sigmask(SIG_UNBLOCK, &signal_set, NULL);
    if(res != 0)
        perror("SIGINT unblock");
    signal(SIGINT, sigint_handler);
}