2 * Copyright (c) 2004-2012 Apple Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
21 * @APPLE_LICENSE_HEADER_END@
28 #include <sys/types.h>
29 #include <sys/queue.h>
34 #include <asl_private.h>
35 #include <asl_store.h>
36 #include "asl_memory.h"
37 #include "asl_common.h"
39 #include <notify_keys.h>
41 #include <dispatch/dispatch.h>
42 #include <libkern/OSAtomic.h>
44 #include <TargetConditionals.h>
46 #define ADDFD_FLAGS_LOCAL 0x00000001
48 #define SELF_DB_NOTIFICATION "self.logger.message"
50 #define ASL_OPT_IGNORE "ignore"
51 #define ASL_OPT_STORE "store"
52 #define ASL_OPT_CONTROL "control"
53 #define ASL_OPT_DB_FILE "asl_db_file"
54 #define ASL_OPT_DB_MEMORY "asl_db_memory"
56 #if TARGET_IPHONE_SIMULATOR
57 /* These paths are appropriately prefixed in the simulator */
58 extern const char *_path_pidfile
;
59 extern const char *_path_syslogd_log
;
61 #define _PATH_PIDFILE _path_pidfile
62 #define _PATH_SYSLOGD_LOG _path_syslogd_log
64 #define _PATH_PIDFILE "/var/run/syslog.pid"
65 #define _PATH_SYSLOG_CONF "/etc/syslog.conf"
66 #define _PATH_SYSLOG_IN "/var/run/syslog"
67 #define _PATH_KLOG "/dev/klog"
68 #define _PATH_SYSLOGD_LOG "/var/log/syslogd.log"
71 #define NOTIFY_PATH_SERVICE "com.apple.system.notify.service.path:0x87:"
73 #define DB_TYPE_FILE 0x00000001
74 #define DB_TYPE_MEMORY 0x00000002
76 #define KERN_DISASTER_LEVEL 3
78 #define SOURCE_UNKNOWN 0
79 #define SOURCE_INTERNAL 1
80 #define SOURCE_BSD_SOCKET 2
81 #define SOURCE_UDP_SOCKET 3
83 #define SOURCE_ASL_MESSAGE 5
84 #define SOURCE_LAUNCHD 6
86 #define SOURCE_SESSION 100 /* does not generate messages */
88 #define STORE_FLAGS_FILE_CACHE_SWEEP_REQUESTED 0x00000001
90 #define FS_TTL_SEC 31622400
92 #define SEC_PER_DAY 86400
94 typedef struct sender_stats_s
99 struct sender_stats_s
*next
;
106 uint32_t bucket_count
;
107 sender_stats_t
**bucket
;
123 int disaster_occurred
;
124 mach_port_t listen_set
;
125 mach_port_t server_port
;
126 mach_port_t dead_session_port
;
127 launch_data_t launch_dict
;
128 int *lockdown_session_fds
;
129 int lockdown_session_count
;
133 int32_t work_queue_count
;
134 /* memory_size must be aligned for OSAtomicAdd64 */
135 __attribute__((aligned(8))) int64_t memory_size
;
136 int32_t asl_queue_count
;
137 int32_t bsd_queue_count
;
138 pthread_mutex_t
*db_lock
;
139 pthread_cond_t work_queue_cond
;
140 dispatch_queue_t work_queue
;
141 dispatch_source_t mark_timer
;
142 dispatch_source_t sig_hup_src
;
143 asl_store_t
*file_db
;
144 asl_memory_t
*memory_db
;
145 asl_memory_t
*disaster_db
;
150 asl_out_module_t
*asl_out_module
;
152 stats_table_t
*stats
;
154 /* parameters below are configurable as command-line args or in /etc/asl.conf */
159 uint32_t db_file_max
;
160 uint32_t db_memory_max
;
161 uint32_t db_memory_str_max
;
163 uint32_t remote_delay_time
;
164 uint64_t bsd_max_dup_time
;
167 time_t stats_interval
;
171 extern struct global_s global
;
173 void init_globals(void);
175 void config_debug(int enable
, const char *path
);
176 void config_data_store(int type
, uint32_t file_max
, uint32_t memory_max
, uint32_t str_memory_max
);
179 void asl_archive(void);
181 void asl_client_count_increment();
182 void asl_client_count_decrement();
184 int asldebug(const char *, ...);
185 int internal_log_message(const char *str
);
187 void send_to_direct_watchers(asl_msg_t
*msg
);
189 #if !TARGET_IPHONE_SIMULATOR
190 void launchd_callback();
193 int asl_syslog_faciliy_name_to_num(const char *fac
);
194 const char *asl_syslog_faciliy_num_to_name(int num
);
195 asl_msg_t
*asl_input_parse(const char *in
, int len
, char *rhost
, uint32_t source
);
197 void process_message(asl_msg_t
*msg
, uint32_t source
);
198 void asl_out_message(asl_msg_t
*msg
, int64_t msize
);
199 void bsd_out_message(asl_msg_t
*msg
, int64_t msize
);
200 int control_set_param(const char *s
, bool eval
);
201 int asl_action_control_set_param(const char *s
);
202 void asl_action_out_module_query(asl_msg_t
*q
, asl_msg_t
*m
, bool all
);
205 uint32_t notify_register_plain(const char *name
, int *out_token
);
207 #endif /* __DAEMON_H__ */