X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=netifd.h;h=9bf3f98b6885d2af0c76c6449730b38fdc1c3608;hp=5eeb5e25b291be5317151c496c78b2b62d96ede9;hb=f88662d0361fa1561ee15f544934655a0dbc9414;hpb=745016bc4a0c143296861d6a322042f217467e28 diff --git a/netifd.h b/netifd.h index 5eeb5e2..9bf3f98 100644 --- a/netifd.h +++ b/netifd.h @@ -19,7 +19,7 @@ #define DEFAULT_RESOLV_CONF "./tmp/resolv.conf" #else #define DEFAULT_MAIN_PATH "/lib/netifd" -#define DEFAULT_HOTPLUG_PATH "/sbin/hotplug-cmd" +#define DEFAULT_HOTPLUG_PATH "/sbin/hotplug-call" #define DEFAULT_RESOLV_CONF "/tmp/resolv.conf.auto" #endif @@ -28,6 +28,14 @@ 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, @@ -44,19 +52,40 @@ 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, ...) { } +struct netifd_fd { + struct list_head list; + struct netifd_process *proc; + int fd; +}; + struct netifd_process { struct list_head list; struct uloop_process uloop; void (*cb)(struct netifd_process *, int ret); + int dir_fd; + + struct netifd_fd log_fd; + struct uloop_fd log_uloop; + const char *log_prefix; + char *log_buf; + int log_buf_ofs; + bool log_overflow; }; -int netifd_start_process(const char **argv, char **env, int dir_fd, struct netifd_process *proc); +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); +void netifd_fd_add(struct netifd_fd *fd); +void netifd_fd_delete(struct netifd_fd *fd); + struct device; struct interface;