X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=netifd.h;h=926cab848dd5727b3db8b98aef73e1a27d20bc38;hp=77c8719d17cf7d7b8fc1a2403f3bebabed4e0b5a;hb=11bd51d22596cf26be9ba486d52ef336b4035cae;hpb=e15ef7a8d23fbc6c931d7221ac792fce67729218 diff --git a/netifd.h b/netifd.h index 77c8719..926cab8 100644 --- a/netifd.h +++ b/netifd.h @@ -7,58 +7,47 @@ #include #include -#include #include #include -#include + +#include "utils.h" + +#ifdef DUMMY_MODE +#define DEFAULT_HOTPLUG_PATH "./scripts/hotplug-cmd" +#else +#define DEFAULT_HOTPLUG_PATH "/sbin/hotplug-cmd" +#endif + +extern char *hotplug_cmd_path; +extern unsigned int debug_mask; + +enum { + DEBUG_SYSTEM = 0, + DEBUG_DEVICE = 1, + DEBUG_INTERFACE = 2, +}; #ifdef DEBUG #define DPRINTF(format, ...) fprintf(stderr, "%s(%d): " format, __func__, __LINE__, ## __VA_ARGS__) +#define D(level, format, ...) do { \ + if (debug_mask & (1 << (DEBUG_ ## level))) \ + DPRINTF(format, ##__VA_ARGS__); \ + } while (0) #else -#define DPRINTF(...) do {} while(0) +#define DPRINTF(format, ...) no_debug(0, format, ## __VA_ARGS__) +#define D(level, format, ...) no_debug(DEBUG_ ## level, format, ## __VA_ARGS__) #endif -#define __init __attribute__((constructor)) +static inline void no_debug(int level, const char *fmt, ...) +{ +} struct device; struct interface; -extern struct uci_context *uci_ctx; -extern bool config_init; - -int avl_strcmp(const void *k1, const void *k2, void *ptr); -void config_init_interfaces(const char *name); - -#ifdef __linux__ -static inline int fls(int x) -{ - int r = 32; - - if (!x) - return 0; - if (!(x & 0xffff0000u)) { - x <<= 16; - r -= 16; - } - if (!(x & 0xff000000u)) { - x <<= 8; - r -= 8; - } - if (!(x & 0xf0000000u)) { - x <<= 4; - r -= 4; - } - if (!(x & 0xc0000000u)) { - x <<= 2; - r -= 2; - } - if (!(x & 0x80000000u)) { - x <<= 1; - r -= 1; - } - return r; -} -#endif +extern const char *main_path; +void netifd_restart(void); +void netifd_reload(void); #endif