X-Git-Url: http://git.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=netifd.h;h=2167d6f91c556d0c56aa1c3169dafe82944c1d7c;hp=f86fb15e00cd7a1d94ae8f84bd79fc0bb73c6d6d;hb=8699ae1f82f685b26cc8fcbcc4779c7988e0cb17;hpb=8c4dface377cf03de38c642b90940530e47296d3 diff --git a/netifd.h b/netifd.h index f86fb15..2167d6f 100644 --- a/netifd.h +++ b/netifd.h @@ -27,6 +27,14 @@ extern const char *resolv_conf; 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, @@ -44,20 +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; }; +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;