1*cc4ad7daSAndroid Build Coastguard Worker #pragma once 2*cc4ad7daSAndroid Build Coastguard Worker 3*cc4ad7daSAndroid Build Coastguard Worker #include <stdbool.h> 4*cc4ad7daSAndroid Build Coastguard Worker #include <stdio.h> 5*cc4ad7daSAndroid Build Coastguard Worker #include <syslog.h> 6*cc4ad7daSAndroid Build Coastguard Worker #include <limits.h> 7*cc4ad7daSAndroid Build Coastguard Worker 8*cc4ad7daSAndroid Build Coastguard Worker #include <shared/macro.h> 9*cc4ad7daSAndroid Build Coastguard Worker #include <shared/missing.h> 10*cc4ad7daSAndroid Build Coastguard Worker 11*cc4ad7daSAndroid Build Coastguard Worker #include "libkmod.h" 12*cc4ad7daSAndroid Build Coastguard Worker 13*cc4ad7daSAndroid Build Coastguard Worker static _always_inline_ _printf_format_(2, 3) void kmod_log_null(const struct kmod_ctx * ctx,const char * format,...)14*cc4ad7daSAndroid Build Coastguard Worker kmod_log_null(const struct kmod_ctx *ctx, const char *format, ...) {} 15*cc4ad7daSAndroid Build Coastguard Worker 16*cc4ad7daSAndroid Build Coastguard Worker #define kmod_log_cond(ctx, prio, arg...) \ 17*cc4ad7daSAndroid Build Coastguard Worker do { \ 18*cc4ad7daSAndroid Build Coastguard Worker if (kmod_get_log_priority(ctx) >= prio) \ 19*cc4ad7daSAndroid Build Coastguard Worker kmod_log(ctx, prio, __FILE__, __LINE__, __func__, ## arg);\ 20*cc4ad7daSAndroid Build Coastguard Worker } while (0) 21*cc4ad7daSAndroid Build Coastguard Worker 22*cc4ad7daSAndroid Build Coastguard Worker #ifdef ENABLE_LOGGING 23*cc4ad7daSAndroid Build Coastguard Worker # ifdef ENABLE_DEBUG 24*cc4ad7daSAndroid Build Coastguard Worker # define DBG(ctx, arg...) kmod_log_cond(ctx, LOG_DEBUG, ## arg) 25*cc4ad7daSAndroid Build Coastguard Worker # else 26*cc4ad7daSAndroid Build Coastguard Worker # define DBG(ctx, arg...) kmod_log_null(ctx, ## arg) 27*cc4ad7daSAndroid Build Coastguard Worker # endif 28*cc4ad7daSAndroid Build Coastguard Worker # define NOTICE(ctx, arg...) kmod_log_cond(ctx, LOG_NOTICE, ## arg) 29*cc4ad7daSAndroid Build Coastguard Worker # define INFO(ctx, arg...) kmod_log_cond(ctx, LOG_INFO, ## arg) 30*cc4ad7daSAndroid Build Coastguard Worker # define ERR(ctx, arg...) kmod_log_cond(ctx, LOG_ERR, ## arg) 31*cc4ad7daSAndroid Build Coastguard Worker #else 32*cc4ad7daSAndroid Build Coastguard Worker # define DBG(ctx, arg...) kmod_log_null(ctx, ## arg) 33*cc4ad7daSAndroid Build Coastguard Worker # define NOTICE(ctx, arg...) kmod_log_null(ctx, ## arg) 34*cc4ad7daSAndroid Build Coastguard Worker # define INFO(ctx, arg...) kmod_log_null(ctx, ## arg) 35*cc4ad7daSAndroid Build Coastguard Worker # define ERR(ctx, arg...) kmod_log_null(ctx, ## arg) 36*cc4ad7daSAndroid Build Coastguard Worker #endif 37*cc4ad7daSAndroid Build Coastguard Worker 38*cc4ad7daSAndroid Build Coastguard Worker #define KMOD_EXPORT __attribute__ ((visibility("default"))) 39*cc4ad7daSAndroid Build Coastguard Worker 40*cc4ad7daSAndroid Build Coastguard Worker #define KCMD_LINE_SIZE 4096 41*cc4ad7daSAndroid Build Coastguard Worker 42*cc4ad7daSAndroid Build Coastguard Worker #ifndef HAVE_SECURE_GETENV 43*cc4ad7daSAndroid Build Coastguard Worker # ifdef HAVE___SECURE_GETENV 44*cc4ad7daSAndroid Build Coastguard Worker # define secure_getenv __secure_getenv 45*cc4ad7daSAndroid Build Coastguard Worker # else 46*cc4ad7daSAndroid Build Coastguard Worker # warning neither secure_getenv nor __secure_getenv is available 47*cc4ad7daSAndroid Build Coastguard Worker # define secure_getenv getenv 48*cc4ad7daSAndroid Build Coastguard Worker # endif 49*cc4ad7daSAndroid Build Coastguard Worker #endif 50*cc4ad7daSAndroid Build Coastguard Worker 51*cc4ad7daSAndroid Build Coastguard Worker void kmod_log(const struct kmod_ctx *ctx, 52*cc4ad7daSAndroid Build Coastguard Worker int priority, const char *file, int line, const char *fn, 53*cc4ad7daSAndroid Build Coastguard Worker const char *format, ...) __attribute__((format(printf, 6, 7))) __attribute__((nonnull(1, 3, 5))); 54*cc4ad7daSAndroid Build Coastguard Worker 55*cc4ad7daSAndroid Build Coastguard Worker struct list_node { 56*cc4ad7daSAndroid Build Coastguard Worker struct list_node *next, *prev; 57*cc4ad7daSAndroid Build Coastguard Worker }; 58*cc4ad7daSAndroid Build Coastguard Worker 59*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list { 60*cc4ad7daSAndroid Build Coastguard Worker struct list_node node; 61*cc4ad7daSAndroid Build Coastguard Worker void *data; 62*cc4ad7daSAndroid Build Coastguard Worker }; 63*cc4ad7daSAndroid Build Coastguard Worker 64*cc4ad7daSAndroid Build Coastguard Worker enum kmod_file_compression_type { 65*cc4ad7daSAndroid Build Coastguard Worker KMOD_FILE_COMPRESSION_NONE = 0, 66*cc4ad7daSAndroid Build Coastguard Worker KMOD_FILE_COMPRESSION_ZSTD, 67*cc4ad7daSAndroid Build Coastguard Worker KMOD_FILE_COMPRESSION_XZ, 68*cc4ad7daSAndroid Build Coastguard Worker KMOD_FILE_COMPRESSION_ZLIB, 69*cc4ad7daSAndroid Build Coastguard Worker }; 70*cc4ad7daSAndroid Build Coastguard Worker 71*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_append(struct kmod_list *list, const void *data) _must_check_ __attribute__((nonnull(2))); 72*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_prepend(struct kmod_list *list, const void *data) _must_check_ __attribute__((nonnull(2))); 73*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_remove(struct kmod_list *list) _must_check_; 74*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_remove_data(struct kmod_list *list, 75*cc4ad7daSAndroid Build Coastguard Worker const void *data) _must_check_ __attribute__((nonnull(2))); 76*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_remove_n_latest(struct kmod_list *list, 77*cc4ad7daSAndroid Build Coastguard Worker unsigned int n) _must_check_; 78*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_insert_after(struct kmod_list *list, const void *data) __attribute__((nonnull(2))); 79*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_insert_before(struct kmod_list *list, const void *data) __attribute__((nonnull(2))); 80*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *kmod_list_append_list(struct kmod_list *list1, struct kmod_list *list2) _must_check_; 81*cc4ad7daSAndroid Build Coastguard Worker 82*cc4ad7daSAndroid Build Coastguard Worker #undef kmod_list_foreach 83*cc4ad7daSAndroid Build Coastguard Worker #define kmod_list_foreach(list_entry, first_entry) \ 84*cc4ad7daSAndroid Build Coastguard Worker for (list_entry = ((first_entry) == NULL) ? NULL : (first_entry); \ 85*cc4ad7daSAndroid Build Coastguard Worker list_entry != NULL; \ 86*cc4ad7daSAndroid Build Coastguard Worker list_entry = (list_entry->node.next == &((first_entry)->node)) ? NULL : \ 87*cc4ad7daSAndroid Build Coastguard Worker container_of(list_entry->node.next, struct kmod_list, node)) 88*cc4ad7daSAndroid Build Coastguard Worker 89*cc4ad7daSAndroid Build Coastguard Worker #undef kmod_list_foreach_reverse 90*cc4ad7daSAndroid Build Coastguard Worker #define kmod_list_foreach_reverse(list_entry, first_entry) \ 91*cc4ad7daSAndroid Build Coastguard Worker for (list_entry = (((first_entry) == NULL) ? NULL : container_of(first_entry->node.prev, struct kmod_list, node)); \ 92*cc4ad7daSAndroid Build Coastguard Worker list_entry != NULL; \ 93*cc4ad7daSAndroid Build Coastguard Worker list_entry = ((list_entry == first_entry) ? NULL : \ 94*cc4ad7daSAndroid Build Coastguard Worker container_of(list_entry->node.prev, struct kmod_list, node))) 95*cc4ad7daSAndroid Build Coastguard Worker 96*cc4ad7daSAndroid Build Coastguard Worker /* libkmod.c */ 97*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_config(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 98*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_symbols_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 99*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_aliases_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 100*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_moddep_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 101*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_kernel_builtin_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 102*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_builtin_file(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 103*cc4ad7daSAndroid Build Coastguard Worker bool kmod_lookup_alias_is_builtin(struct kmod_ctx *ctx, const char *name) __attribute__((nonnull(1, 2))); 104*cc4ad7daSAndroid Build Coastguard Worker int kmod_lookup_alias_from_commands(struct kmod_ctx *ctx, const char *name, struct kmod_list **list) __attribute__((nonnull(1, 2, 3))); 105*cc4ad7daSAndroid Build Coastguard Worker void kmod_set_modules_visited(struct kmod_ctx *ctx, bool visited) __attribute__((nonnull((1)))); 106*cc4ad7daSAndroid Build Coastguard Worker void kmod_set_modules_required(struct kmod_ctx *ctx, bool required) __attribute__((nonnull((1)))); 107*cc4ad7daSAndroid Build Coastguard Worker 108*cc4ad7daSAndroid Build Coastguard Worker char *kmod_search_moddep(struct kmod_ctx *ctx, const char *name) __attribute__((nonnull(1,2))); 109*cc4ad7daSAndroid Build Coastguard Worker 110*cc4ad7daSAndroid Build Coastguard Worker struct kmod_module *kmod_pool_get_module(struct kmod_ctx *ctx, const char *key) __attribute__((nonnull(1,2))); 111*cc4ad7daSAndroid Build Coastguard Worker void kmod_pool_add_module(struct kmod_ctx *ctx, struct kmod_module *mod, const char *key) __attribute__((nonnull(1, 2, 3))); 112*cc4ad7daSAndroid Build Coastguard Worker void kmod_pool_del_module(struct kmod_ctx *ctx, struct kmod_module *mod, const char *key) __attribute__((nonnull(1, 2, 3))); 113*cc4ad7daSAndroid Build Coastguard Worker 114*cc4ad7daSAndroid Build Coastguard Worker const struct kmod_config *kmod_get_config(const struct kmod_ctx *ctx) __attribute__((nonnull(1))); 115*cc4ad7daSAndroid Build Coastguard Worker enum kmod_file_compression_type kmod_get_kernel_compression(const struct kmod_ctx *ctx) __attribute__((nonnull(1))); 116*cc4ad7daSAndroid Build Coastguard Worker 117*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-config.c */ 118*cc4ad7daSAndroid Build Coastguard Worker struct kmod_config_path { 119*cc4ad7daSAndroid Build Coastguard Worker unsigned long long stamp; 120*cc4ad7daSAndroid Build Coastguard Worker char path[]; 121*cc4ad7daSAndroid Build Coastguard Worker }; 122*cc4ad7daSAndroid Build Coastguard Worker 123*cc4ad7daSAndroid Build Coastguard Worker struct kmod_config { 124*cc4ad7daSAndroid Build Coastguard Worker struct kmod_ctx *ctx; 125*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *aliases; 126*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *blacklists; 127*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *options; 128*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *remove_commands; 129*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *install_commands; 130*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *softdeps; 131*cc4ad7daSAndroid Build Coastguard Worker 132*cc4ad7daSAndroid Build Coastguard Worker struct kmod_list *paths; 133*cc4ad7daSAndroid Build Coastguard Worker }; 134*cc4ad7daSAndroid Build Coastguard Worker 135*cc4ad7daSAndroid Build Coastguard Worker int kmod_config_new(struct kmod_ctx *ctx, struct kmod_config **config, const char * const *config_paths) __attribute__((nonnull(1, 2,3))); 136*cc4ad7daSAndroid Build Coastguard Worker void kmod_config_free(struct kmod_config *config) __attribute__((nonnull(1))); 137*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_blacklist_get_modname(const struct kmod_list *l) __attribute__((nonnull(1))); 138*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_alias_get_name(const struct kmod_list *l) __attribute__((nonnull(1))); 139*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_alias_get_modname(const struct kmod_list *l) __attribute__((nonnull(1))); 140*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_option_get_options(const struct kmod_list *l) __attribute__((nonnull(1))); 141*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_option_get_modname(const struct kmod_list *l) __attribute__((nonnull(1))); 142*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_command_get_command(const struct kmod_list *l) __attribute__((nonnull(1))); 143*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_command_get_modname(const struct kmod_list *l) __attribute__((nonnull(1))); 144*cc4ad7daSAndroid Build Coastguard Worker 145*cc4ad7daSAndroid Build Coastguard Worker const char *kmod_softdep_get_name(const struct kmod_list *l) __attribute__((nonnull(1))); 146*cc4ad7daSAndroid Build Coastguard Worker const char * const *kmod_softdep_get_pre(const struct kmod_list *l, unsigned int *count) __attribute__((nonnull(1, 2))); 147*cc4ad7daSAndroid Build Coastguard Worker const char * const *kmod_softdep_get_post(const struct kmod_list *l, unsigned int *count); 148*cc4ad7daSAndroid Build Coastguard Worker 149*cc4ad7daSAndroid Build Coastguard Worker 150*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-module.c */ 151*cc4ad7daSAndroid Build Coastguard Worker int kmod_module_new_from_alias(struct kmod_ctx *ctx, const char *alias, const char *name, struct kmod_module **mod); 152*cc4ad7daSAndroid Build Coastguard Worker int kmod_module_parse_depline(struct kmod_module *mod, char *line) __attribute__((nonnull(1, 2))); 153*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_set_install_commands(struct kmod_module *mod, const char *cmd) __attribute__((nonnull(1))); 154*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_set_remove_commands(struct kmod_module *mod, const char *cmd) __attribute__((nonnull(1))); 155*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_set_visited(struct kmod_module *mod, bool visited) __attribute__((nonnull(1))); 156*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_set_builtin(struct kmod_module *mod, bool builtin) __attribute__((nonnull((1)))); 157*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_set_required(struct kmod_module *mod, bool required) __attribute__((nonnull(1))); 158*cc4ad7daSAndroid Build Coastguard Worker bool kmod_module_is_builtin(struct kmod_module *mod) __attribute__((nonnull(1))); 159*cc4ad7daSAndroid Build Coastguard Worker 160*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-file.c */ 161*cc4ad7daSAndroid Build Coastguard Worker struct kmod_file *kmod_file_open(const struct kmod_ctx *ctx, const char *filename) _must_check_ __attribute__((nonnull(1,2))); 162*cc4ad7daSAndroid Build Coastguard Worker struct kmod_elf *kmod_file_get_elf(struct kmod_file *file) __attribute__((nonnull(1))); 163*cc4ad7daSAndroid Build Coastguard Worker void kmod_file_load_contents(struct kmod_file *file) __attribute__((nonnull(1))); 164*cc4ad7daSAndroid Build Coastguard Worker void *kmod_file_get_contents(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1))); 165*cc4ad7daSAndroid Build Coastguard Worker off_t kmod_file_get_size(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1))); 166*cc4ad7daSAndroid Build Coastguard Worker enum kmod_file_compression_type kmod_file_get_compression(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1))); 167*cc4ad7daSAndroid Build Coastguard Worker int kmod_file_get_fd(const struct kmod_file *file) _must_check_ __attribute__((nonnull(1))); 168*cc4ad7daSAndroid Build Coastguard Worker void kmod_file_unref(struct kmod_file *file) __attribute__((nonnull(1))); 169*cc4ad7daSAndroid Build Coastguard Worker 170*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-elf.c */ 171*cc4ad7daSAndroid Build Coastguard Worker struct kmod_elf; 172*cc4ad7daSAndroid Build Coastguard Worker struct kmod_modversion { 173*cc4ad7daSAndroid Build Coastguard Worker uint64_t crc; 174*cc4ad7daSAndroid Build Coastguard Worker enum kmod_symbol_bind bind; 175*cc4ad7daSAndroid Build Coastguard Worker char *symbol; 176*cc4ad7daSAndroid Build Coastguard Worker }; 177*cc4ad7daSAndroid Build Coastguard Worker 178*cc4ad7daSAndroid Build Coastguard Worker struct kmod_elf *kmod_elf_new(const void *memory, off_t size) _must_check_; 179*cc4ad7daSAndroid Build Coastguard Worker void kmod_elf_unref(struct kmod_elf *elf) __attribute__((nonnull(1))); 180*cc4ad7daSAndroid Build Coastguard Worker const void *kmod_elf_get_memory(const struct kmod_elf *elf) _must_check_ __attribute__((nonnull(1))); 181*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_get_strings(const struct kmod_elf *elf, const char *section, char ***array) _must_check_ __attribute__((nonnull(1,2,3))); 182*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_get_modversions(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2))); 183*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_get_symbols(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2))); 184*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_get_dependency_symbols(const struct kmod_elf *elf, struct kmod_modversion **array) _must_check_ __attribute__((nonnull(1,2))); 185*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_strip_section(struct kmod_elf *elf, const char *section) _must_check_ __attribute__((nonnull(1,2))); 186*cc4ad7daSAndroid Build Coastguard Worker int kmod_elf_strip_vermagic(struct kmod_elf *elf) _must_check_ __attribute__((nonnull(1))); 187*cc4ad7daSAndroid Build Coastguard Worker 188*cc4ad7daSAndroid Build Coastguard Worker /* 189*cc4ad7daSAndroid Build Coastguard Worker * Debug mock lib need to find section ".gnu.linkonce.this_module" in order to 190*cc4ad7daSAndroid Build Coastguard Worker * get modname 191*cc4ad7daSAndroid Build Coastguard Worker */ 192*cc4ad7daSAndroid Build Coastguard Worker int 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))); 193*cc4ad7daSAndroid Build Coastguard Worker 194*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-signature.c */ 195*cc4ad7daSAndroid Build Coastguard Worker struct kmod_signature_info { 196*cc4ad7daSAndroid Build Coastguard Worker const char *signer; 197*cc4ad7daSAndroid Build Coastguard Worker size_t signer_len; 198*cc4ad7daSAndroid Build Coastguard Worker const char *key_id; 199*cc4ad7daSAndroid Build Coastguard Worker size_t key_id_len; 200*cc4ad7daSAndroid Build Coastguard Worker const char *algo, *hash_algo, *id_type; 201*cc4ad7daSAndroid Build Coastguard Worker const char *sig; 202*cc4ad7daSAndroid Build Coastguard Worker size_t sig_len; 203*cc4ad7daSAndroid Build Coastguard Worker void (*free)(void *); 204*cc4ad7daSAndroid Build Coastguard Worker void *private; 205*cc4ad7daSAndroid Build Coastguard Worker }; 206*cc4ad7daSAndroid Build Coastguard Worker bool kmod_module_signature_info(const struct kmod_file *file, struct kmod_signature_info *sig_info) _must_check_ __attribute__((nonnull(1, 2))); 207*cc4ad7daSAndroid Build Coastguard Worker void kmod_module_signature_info_free(struct kmod_signature_info *sig_info) __attribute__((nonnull)); 208*cc4ad7daSAndroid Build Coastguard Worker 209*cc4ad7daSAndroid Build Coastguard Worker /* libkmod-builtin.c */ 210*cc4ad7daSAndroid Build Coastguard Worker ssize_t kmod_builtin_get_modinfo(struct kmod_ctx *ctx, const char *modname, char ***modinfo) __attribute__((nonnull(1, 2, 3))); 211