summaryrefslogtreecommitdiffstats
path: root/src/input.c
blob: 4a7d4ca735552aa31cf738d4bee49b1a4baf3daf (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
/*
 * input.c            Input API
 *
 * Copyright (c) 2001-2013 Thomas Graf <tgraf@suug.ch>
 * Copyright (c) 2013 Red Hat, Inc.
 *
 * 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 <bmon/bmon.h>
#include <bmon/input.h>
#include <bmon/module.h>
#include <bmon/utils.h>

static struct bmon_subsys input_subsys;

void input_register(struct bmon_module *m)
{
	module_register(&input_subsys, m);
}

static void activate_default(void)
{
	/*
	 * Try to activate a default input module if the user did not make
	 * a selection
	 */
	if (!input_subsys.s_nmod) {
		struct bmon_module *m;

#ifdef SYS_LINUX
		if (!input_set("netlink"))
			return;

		if (!input_set("proc"))
			return;
#endif

#ifdef SYS_BSD
		if (!input_set("sysctl"))
			return;
#endif

		/* Fall back to anything that could act as default */
		list_for_each_entry(m, &input_subsys.s_mod_list, m_list) {
			if (m->m_flags & BMON_MODULE_DEFAULT)
				if (!input_set(m->m_name))
					return;
		}

		quit("No input module found\n");
	}
}

void input_read(void)
{
	module_foreach_run_enabled(&input_subsys);
}

int input_set(const char *name)
{
	return module_set(&input_subsys, name);
}

static struct bmon_subsys input_subsys = {
	.s_name			= "input",
	.s_activate_default	= &activate_default,
	.s_mod_list		= LIST_SELF(input_subsys.s_mod_list),
};

static void __init __input_init(void)
{
	module_register_subsys(&input_subsys);
}