X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=netifd.h;h=5a908587efafeec1ce5640d219d52e6b08c37a91;hp=f86fb15e00cd7a1d94ae8f84bd79fc0bb73c6d6d;hb=fb2f843edf44c6f12b636cd82cdd1c71e953495f;hpb=8c4dface377cf03de38c642b90940530e47296d3 diff --git a/netifd.h b/netifd.h index f86fb15..5a90858 100644 --- a/netifd.h +++ b/netifd.h @@ -1,3 +1,16 @@ +/* + * netifd - network interface daemon + * Copyright (C) 2012 Felix Fietkau + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 + * as published by the Free Software Foundation + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ #ifndef __NETIFD_H #define __NETIFD_H @@ -8,18 +21,22 @@ #include #include +#include +#include #include #include "utils.h" #ifdef DUMMY_MODE -#define DEFAULT_MAIN_PATH "./dummy" -#define DEFAULT_HOTPLUG_PATH "./scripts/hotplug-cmd" +#define DEFAULT_MAIN_PATH "./examples" +#define DEFAULT_CONFIG_PATH "./config" +#define DEFAULT_HOTPLUG_PATH "./examples/hotplug-cmd" #define DEFAULT_RESOLV_CONF "./tmp/resolv.conf" #else #define DEFAULT_MAIN_PATH "/lib/netifd" -#define DEFAULT_HOTPLUG_PATH "/sbin/hotplug-cmd" +#define DEFAULT_CONFIG_PATH NULL /* use the default set in libuci */ +#define DEFAULT_HOTPLUG_PATH "/sbin/hotplug-call" #define DEFAULT_RESOLV_CONF "/tmp/resolv.conf.auto" #endif @@ -28,9 +45,18 @@ extern char *hotplug_cmd_path; extern unsigned int debug_mask; enum { + L_CRIT, + L_WARNING, + L_NOTICE, + L_INFO, + L_DEBUG +}; + +enum { DEBUG_SYSTEM = 0, DEBUG_DEVICE = 1, DEBUG_INTERFACE = 2, + DEBUG_WIRELESS = 3, }; #ifdef DEBUG @@ -44,6 +70,8 @@ enum { #define D(level, format, ...) no_debug(DEBUG_ ## level, format, ## __VA_ARGS__) #endif +#define LOG_BUF_SIZE 256 + static inline void no_debug(int level, const char *fmt, ...) { } @@ -53,8 +81,14 @@ struct netifd_process { struct uloop_process uloop; void (*cb)(struct netifd_process *, int ret); int dir_fd; + + struct ustream_fd log; + const char *log_prefix; + bool log_overflow; }; +void netifd_log_message(int priority, const char *format, ...); + int netifd_start_process(const char **argv, char **env, struct netifd_process *proc); void netifd_kill_process(struct netifd_process *proc); @@ -62,6 +96,7 @@ struct device; struct interface; extern const char *main_path; +extern const char *config_path; void netifd_restart(void); void netifd_reload(void);