blob: 7748b143e4f4e61e68c36756092a150f9add55c8 [file] [log] [blame]
Lucas De Marchie8fd8fe2012-07-18 10:19:48 -03001#pragma once
Lucas De Marchi586fc302011-11-21 14:35:35 -02002
3#include <stdbool.h>
Lucas De Marchi4462c4a2011-11-29 18:05:43 -02004#include <stdio.h>
Lucas De Marchi586fc302011-11-21 14:35:35 -02005#include <syslog.h>
Gustavo Sverzut Barbierid917f272011-12-10 21:00:19 -02006#include <limits.h>
Lucas De Marchi586fc302011-11-21 14:35:35 -02007
Lucas De Marchi88e9c122011-11-23 12:23:46 -02008#include "macro.h"
Lucas De Marchi586fc302011-11-21 14:35:35 -02009#include "libkmod.h"
10
Lucas De Marchia70c1e72012-05-23 20:27:23 -030011static _always_inline_ _printf_format_(2, 3) void
Lucas De Marchi586fc302011-11-21 14:35:35 -020012 kmod_log_null(struct kmod_ctx *ctx, const char *format, ...) {}
13
14#define kmod_log_cond(ctx, prio, arg...) \
15 do { \
16 if (kmod_get_log_priority(ctx) >= prio) \
Jan Engelhardt87beacc2011-12-20 16:27:40 +010017 kmod_log(ctx, prio, __FILE__, __LINE__, __func__, ## arg);\
Lucas De Marchi586fc302011-11-21 14:35:35 -020018 } while (0)
19
20#ifdef ENABLE_LOGGING
21# ifdef ENABLE_DEBUG
Lucas De Marchiae6df842011-11-25 01:05:30 -020022# define DBG(ctx, arg...) kmod_log_cond(ctx, LOG_DEBUG, ## arg)
Lucas De Marchi586fc302011-11-21 14:35:35 -020023# else
Lucas De Marchiae6df842011-11-25 01:05:30 -020024# define DBG(ctx, arg...) kmod_log_null(ctx, ## arg)
Lucas De Marchi586fc302011-11-21 14:35:35 -020025# endif
Lucas De Marchiae6df842011-11-25 01:05:30 -020026# define INFO(ctx, arg...) kmod_log_cond(ctx, LOG_INFO, ## arg)
27# define ERR(ctx, arg...) kmod_log_cond(ctx, LOG_ERR, ## arg)
Lucas De Marchi586fc302011-11-21 14:35:35 -020028#else
Lucas De Marchiae6df842011-11-25 01:05:30 -020029# define DBG(ctx, arg...) kmod_log_null(ctx, ## arg)
30# define INFO(ctx, arg...) kmod_log_null(ctx, ## arg)
31# define ERR(ctx, arg...) kmod_log_null(ctx, ## arg)
Lucas De Marchi586fc302011-11-21 14:35:35 -020032#endif
33
34#define KMOD_EXPORT __attribute__ ((visibility("default")))
35
Lucas De Marchi1684e442011-12-14 17:19:19 -020036#define KCMD_LINE_SIZE 4096
37
Gustavo Sverzut Barbieri1bdd9512011-12-08 13:47:55 -020038void kmod_log(const struct kmod_ctx *ctx,
Lucas De Marchi586fc302011-11-21 14:35:35 -020039 int priority, const char *file, int line, const char *fn,
Gustavo Sverzut Barbieri12d94192011-12-02 20:34:58 -020040 const char *format, ...) __attribute__((format(printf, 6, 7))) __attribute__((nonnull(1, 3, 5)));
Lucas De Marchi586fc302011-11-21 14:35:35 -020041
Lucas De Marchi6924e472011-11-22 05:38:28 -020042struct list_node {
43 struct list_node *next, *prev;
44};
45
46struct kmod_list {
47 struct list_node node;
48 void *data;
49};
50
Lucas De Marchia70c1e72012-05-23 20:27:23 -030051struct kmod_list *kmod_list_append(struct kmod_list *list, const void *data) _must_check_ __attribute__((nonnull(2)));
52struct kmod_list *kmod_list_prepend(struct kmod_list *list, const void *data) _must_check_ __attribute__((nonnull(2)));
53struct kmod_list *kmod_list_remove(struct kmod_list *list) _must_check_;
Lucas De Marchi6924e472011-11-22 05:38:28 -020054struct kmod_list *kmod_list_remove_data(struct kmod_list *list,
Lucas De Marchia70c1e72012-05-23 20:27:23 -030055 const void *data) _must_check_ __attribute__((nonnull(2)));
Lucas De Marchi62be7992011-12-01 15:27:42 -020056struct kmod_list *kmod_list_remove_n_latest(struct kmod_list *list,
Lucas De Marchia70c1e72012-05-23 20:27:23 -030057 unsigned int n) _must_check_;
Lucas De Marchi86e87882011-12-05 23:41:14 -020058struct kmod_list *kmod_list_insert_after(struct kmod_list *list, const void *data) __attribute__((nonnull(2)));
Lucas De Marchib91a1c62011-12-05 23:53:56 -020059struct kmod_list *kmod_list_insert_before(struct kmod_list *list, const void *data) __attribute__((nonnull(2)));
Lucas De Marchia70c1e72012-05-23 20:27:23 -030060struct kmod_list *kmod_list_append_list(struct kmod_list *list1, struct kmod_list *list2) _must_check_;
Lucas De Marchi86e87882011-12-05 23:41:14 -020061
Lucas De Marchicf915792011-12-05 11:33:15 -020062#undef kmod_list_foreach
63#define kmod_list_foreach(list_entry, first_entry) \
Lucas De Marchid2d648d2011-12-06 01:44:08 -020064 for (list_entry = ((first_entry) == NULL) ? NULL : (first_entry); \
Lucas De Marchicf915792011-12-05 11:33:15 -020065 list_entry != NULL; \
Lucas De Marchid2d648d2011-12-06 01:44:08 -020066 list_entry = (list_entry->node.next == &((first_entry)->node)) ? NULL : \
Lucas De Marchicf915792011-12-05 11:33:15 -020067 container_of(list_entry->node.next, struct kmod_list, node))
Lucas De Marchi60aa4d82011-11-30 18:57:38 -020068
Gustavo Sverzut Barbierid6b55b72011-12-16 22:33:08 -020069#undef kmod_list_foreach_reverse
70#define kmod_list_foreach_reverse(list_entry, first_entry) \
71 for (list_entry = (((first_entry) == NULL) ? NULL : container_of(first_entry->node.prev, struct kmod_list, node)); \
72 list_entry != NULL; \
73 list_entry = ((list_entry == first_entry) ? NULL : \
74 container_of(list_entry->node.prev, struct kmod_list, node)))
75
Lucas De Marchi60aa4d82011-11-30 18:57:38 -020076/* libkmod.c */
Gustavo Sverzut Barbieri1ce08a52011-12-02 20:24:07 -020077const char *kmod_get_dirname(const struct kmod_ctx *ctx) __attribute__((nonnull(1)));
Lucas De Marchifd186ae2011-12-06 03:38:37 -020078
Gustavo Sverzut Barbieri12d94192011-12-02 20:34:58 -020079int kmod_lookup_alias_from_config(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
80int kmod_lookup_alias_from_symbols_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
81int kmod_lookup_alias_from_aliases_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
82int kmod_lookup_alias_from_moddep_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
Lucas De Marchi38052742012-02-16 20:43:16 -020083int kmod_lookup_alias_from_builtin_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
Lucas De Marchif4fc5522011-12-16 03:57:12 -020084int kmod_lookup_alias_from_commands(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3)));
Lucas De Marchiece09aa2012-01-18 01:26:44 -020085void kmod_set_modules_visited(struct kmod_ctx *ctx, bool visited) __attribute__((nonnull((1))));
Lucas De Marchifd186ae2011-12-06 03:38:37 -020086
Lucas De Marchi671d4892011-12-05 20:23:05 -020087char *kmod_search_moddep(struct kmod_ctx *ctx, const char *name) __attribute__((nonnull(1,2)));
Lucas De Marchi221631d2011-11-24 16:41:01 -020088
Lucas De Marchi8bdeca12011-12-15 13:11:51 -020089struct kmod_module *kmod_pool_get_module(struct kmod_ctx *ctx, const char *key) __attribute__((nonnull(1,2)));
90void kmod_pool_add_module(struct kmod_ctx *ctx, struct kmod_module *mod, const char *key) __attribute__((nonnull(1,2, 3)));
91void kmod_pool_del_module(struct kmod_ctx *ctx, struct kmod_module *mod, const char *key) __attribute__((nonnull(1,2, 3)));
Lucas De Marchifd186ae2011-12-06 03:38:37 -020092
Lucas De Marchie7fc2c82012-06-12 01:43:46 -030093const struct kmod_config *kmod_get_config(const struct kmod_ctx *ctx) __attribute__((nonnull(1)));
Lucas De Marchifd186ae2011-12-06 03:38:37 -020094
Lucas De Marchi60aa4d82011-11-30 18:57:38 -020095/* libkmod-config.c */
Lucas De Marchib6a4dfb2011-12-31 18:48:05 -020096struct kmod_config_path {
97 unsigned long long stamp;
98 char path[];
99};
100
Lucas De Marchi7c2ab352011-11-29 18:07:43 -0200101struct kmod_config {
Gustavo Sverzut Barbierid13e6062011-12-02 21:40:22 -0200102 struct kmod_ctx *ctx;
Lucas De Marchi7c2ab352011-11-29 18:07:43 -0200103 struct kmod_list *aliases;
Lucas De Marchi81cf2062011-11-29 18:48:02 -0200104 struct kmod_list *blacklists;
Lucas De Marchi615c42b2011-12-07 03:18:57 -0200105 struct kmod_list *options;
Lucas De Marchia5cce6d2011-12-07 11:31:28 -0200106 struct kmod_list *remove_commands;
107 struct kmod_list *install_commands;
Gustavo Sverzut Barbieri1c522602011-12-16 21:18:10 -0200108 struct kmod_list *softdeps;
Lucas De Marchib6a4dfb2011-12-31 18:48:05 -0200109
110 struct kmod_list *paths;
Lucas De Marchi7c2ab352011-11-29 18:07:43 -0200111};
Lucas De Marchib6a4dfb2011-12-31 18:48:05 -0200112
Gustavo Sverzut Barbiericb8d4d32011-12-11 20:37:01 -0200113int kmod_config_new(struct kmod_ctx *ctx, struct kmod_config **config, const char * const *config_paths) __attribute__((nonnull(1, 2,3)));
Gustavo Sverzut Barbierid13e6062011-12-02 21:40:22 -0200114void kmod_config_free(struct kmod_config *config) __attribute__((nonnull(1)));
Lucas De Marchic1c9c442011-12-24 10:50:47 -0200115const char *kmod_blacklist_get_modname(const struct kmod_list *l) __attribute__((nonnull(1)));
Gustavo Sverzut Barbieri12d94192011-12-02 20:34:58 -0200116const char *kmod_alias_get_name(const struct kmod_list *l) __attribute__((nonnull(1)));
117const char *kmod_alias_get_modname(const struct kmod_list *l) __attribute__((nonnull(1)));
Gustavo Sverzut Barbieribd3f5532011-12-10 20:47:01 -0200118const char *kmod_option_get_options(const struct kmod_list *l) __attribute__((nonnull(1)));
119const char *kmod_option_get_modname(const struct kmod_list *l) __attribute__((nonnull(1)));
120const char *kmod_command_get_command(const struct kmod_list *l) __attribute__((nonnull(1)));
121const char *kmod_command_get_modname(const struct kmod_list *l) __attribute__((nonnull(1)));
122
Gustavo Sverzut Barbieri1c522602011-12-16 21:18:10 -0200123const char *kmod_softdep_get_name(const struct kmod_list *l) __attribute__((nonnull(1)));
124const char * const *kmod_softdep_get_pre(const struct kmod_list *l, unsigned int *count) __attribute__((nonnull(1, 2)));
125const char * const *kmod_softdep_get_post(const struct kmod_list *l, unsigned int *count);
126
Lucas De Marchi7c2ab352011-11-29 18:07:43 -0200127
Lucas De Marchi7636e722011-12-01 17:56:03 -0200128/* libkmod-module.c */
Lucas De Marchi6ad5f262011-12-13 14:12:50 -0200129int kmod_module_new_from_alias(struct kmod_ctx *ctx, const char *alias, const char *name, struct kmod_module **mod);
Lucas De Marchi671d4892011-12-05 20:23:05 -0200130int kmod_module_parse_depline(struct kmod_module *mod, char *line) __attribute__((nonnull(1, 2)));
Lucas De Marchif4fc5522011-12-16 03:57:12 -0200131void kmod_module_set_install_commands(struct kmod_module *mod, const char *cmd) __attribute__((nonnull(1)));
132void kmod_module_set_remove_commands(struct kmod_module *mod, const char *cmd) __attribute__((nonnull(1)));
Lucas De Marchiece09aa2012-01-18 01:26:44 -0200133void kmod_module_set_visited(struct kmod_module *mod, bool visited) __attribute__((nonnull(1)));
Lucas De Marchi38052742012-02-16 20:43:16 -0200134void kmod_module_set_builtin(struct kmod_module *mod, bool builtin) __attribute__((nonnull((1))));
Lucas De Marchi7636e722011-12-01 17:56:03 -0200135
Gustavo Sverzut Barbieri7db08652011-12-05 00:17:37 -0200136/* libkmod-hash.c */
Lucas De Marchi529148e2011-12-27 12:26:51 -0200137
138#include "libkmod-hash.h"
Gustavo Sverzut Barbieri7db08652011-12-05 00:17:37 -0200139
Gustavo Sverzut Barbieri3d8226e2011-12-16 16:08:53 -0200140/* libkmod-file.c */
Lucas De Marchia70c1e72012-05-23 20:27:23 -0300141struct kmod_file *kmod_file_open(const struct kmod_ctx *ctx, const char *filename) _must_check_ __attribute__((nonnull(1,2)));
Lucas De Marchi1eff9422012-10-18 01:36:33 -0300142struct kmod_elf *kmod_file_get_elf(struct kmod_file *file) __attribute__((nonnull(1)));
Lucas De Marchia70c1e72012-05-23 20:27:23 -0300143void *kmod_file_get_contents(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1)));
144off_t kmod_file_get_size(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1)));
Kees Cook144d1822013-02-18 12:02:32 -0800145bool kmod_file_get_direct(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1)));
146int kmod_file_get_fd(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1)));
Gustavo Sverzut Barbieri3d8226e2011-12-16 16:08:53 -0200147void kmod_file_unref(struct kmod_file *file) __attribute__((nonnull(1)));
148
Gustavo Sverzut Barbieri708624a2011-12-18 01:25:06 -0200149/* libkmod-elf.c */
150struct kmod_elf;
151struct kmod_modversion {
152 uint64_t crc;
Gustavo Sverzut Barbieri674f8592011-12-20 11:54:53 -0200153 enum kmod_symbol_bind bind;
Gustavo Sverzut Barbieri708624a2011-12-18 01:25:06 -0200154 char *symbol;
155};
156
Lucas De Marchia70c1e72012-05-23 20:27:23 -0300157struct kmod_elf *kmod_elf_new(const void *memory, off_t size) _must_check_ __attribute__((nonnull(1)));
Gustavo Sverzut Barbieri708624a2011-12-18 01:25:06 -0200158void kmod_elf_unref(struct kmod_elf *elf) __attribute__((nonnull(1)));
Lucas De Marchia70c1e72012-05-23 20:27:23 -0300159const void *kmod_elf_get_memory(const struct kmod_elf *elf) _must_check_ __attribute__((nonnull(1)));
160int kmod_elf_get_strings(const struct kmod_elf *elf, const char *section, char ***array) _must_check_ __attribute__((nonnull(1,2,3)));
161int kmod_elf_get_modversions(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2)));
162int kmod_elf_get_symbols(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2)));
163int kmod_elf_get_dependency_symbols(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2)));
164int kmod_elf_strip_section(struct kmod_elf *elf, const char *section) _must_check_ __attribute__((nonnull(1,2)));
165int kmod_elf_strip_vermagic(struct kmod_elf *elf) _must_check_ __attribute__((nonnull(1)));
Gustavo Sverzut Barbieri7db08652011-12-05 00:17:37 -0200166
Lucas De Marchiea17e2b2012-01-26 01:21:17 -0200167/*
168 * Debug mock lib need to find section ".gnu.linkonce.this_module" in order to
169 * get modname
170 */
Lucas De Marchia70c1e72012-05-23 20:27:23 -0300171int kmod_elf_get_section(const struct kmod_elf *elf, const char *section, const void **buf, uint64_t *buf_size) _must_check_ __attribute__((nonnull(1,2,3,4)));
Lucas De Marchiea17e2b2012-01-26 01:21:17 -0200172
Michal Marek8fe16812013-01-16 09:52:01 +0100173/* libkmod-signature.c */
174struct kmod_signature_info {
175 const char *signer;
176 size_t signer_len;
177 const char *key_id;
178 size_t key_id_len;
179 const char *algo, *hash_algo, *id_type;
180};
181bool kmod_module_signature_info(const struct kmod_file *file, struct kmod_signature_info *sig_info) _must_check_ __attribute__((nonnull(1, 2)));
Lucas De Marchi60aa4d82011-11-30 18:57:38 -0200182/* util functions */
Lucas De Marchia4848e22011-12-27 14:38:26 -0200183#include "libkmod-util.h"