Lines Matching refs:eloop

47 	WPA_TRACE_REF(eloop);
58 WPA_TRACE_REF(eloop);
115 static struct eloop_data eloop; variable
133 wpa_trace_add_ref(&table->table[i], eloop, in eloop_trace_sock_add_ref()
148 wpa_trace_remove_ref(&table->table[i], eloop, in eloop_trace_sock_remove_ref()
165 os_memset(&eloop, 0, sizeof(eloop)); in eloop_init()
166 dl_list_init(&eloop.timeout); in eloop_init()
168 eloop.epollfd = epoll_create1(0); in eloop_init()
169 if (eloop.epollfd < 0) { in eloop_init()
176 eloop.kqueuefd = kqueue(); in eloop_init()
177 if (eloop.kqueuefd < 0) { in eloop_init()
184 eloop.readers.type = EVENT_TYPE_READ; in eloop_init()
185 eloop.writers.type = EVENT_TYPE_WRITE; in eloop_init()
186 eloop.exceptions.type = EVENT_TYPE_EXCEPTION; in eloop_init()
218 if (epoll_ctl(eloop.epollfd, EPOLL_CTL_ADD, sock, &ev) < 0) { in eloop_sock_queue()
248 if (kevent(eloop.kqueuefd, &ke, 1, NULL, 0, NULL) == -1) { in eloop_sock_queue()
276 if (sock > eloop.max_sock) in eloop_sock_table_add_sock()
279 new_max_sock = eloop.max_sock; in eloop_sock_table_add_sock()
285 if ((size_t) new_max_sock >= eloop.max_pollfd_map) { in eloop_sock_table_add_sock()
287 nmap = os_realloc_array(eloop.pollfds_map, new_max_sock + 50, in eloop_sock_table_add_sock()
292 eloop.max_pollfd_map = new_max_sock + 50; in eloop_sock_table_add_sock()
293 eloop.pollfds_map = nmap; in eloop_sock_table_add_sock()
296 if (eloop.count + 1 > eloop.max_poll_fds) { in eloop_sock_table_add_sock()
298 size_t nmax = eloop.count + 1 + 50; in eloop_sock_table_add_sock()
300 n = os_realloc_array(eloop.pollfds, nmax, in eloop_sock_table_add_sock()
305 eloop.max_poll_fds = nmax; in eloop_sock_table_add_sock()
306 eloop.pollfds = n; in eloop_sock_table_add_sock()
310 if (new_max_sock >= eloop.max_fd) { in eloop_sock_table_add_sock()
312 temp_table = os_realloc_array(eloop.fd_table, next, in eloop_sock_table_add_sock()
317 eloop.max_fd = next; in eloop_sock_table_add_sock()
318 eloop.fd_table = temp_table; in eloop_sock_table_add_sock()
323 if (eloop.count + 1 > eloop.epoll_max_event_num) { in eloop_sock_table_add_sock()
324 next = eloop.epoll_max_event_num == 0 ? 8 : in eloop_sock_table_add_sock()
325 eloop.epoll_max_event_num * 2; in eloop_sock_table_add_sock()
326 temp_events = os_realloc_array(eloop.epoll_events, next, in eloop_sock_table_add_sock()
334 eloop.epoll_max_event_num = next; in eloop_sock_table_add_sock()
335 eloop.epoll_events = temp_events; in eloop_sock_table_add_sock()
339 if (eloop.count + 1 > eloop.kqueue_nevents) { in eloop_sock_table_add_sock()
340 next = eloop.kqueue_nevents == 0 ? 8 : eloop.kqueue_nevents * 2; in eloop_sock_table_add_sock()
349 os_free(eloop.kqueue_events); in eloop_sock_table_add_sock()
350 eloop.kqueue_events = temp_events; in eloop_sock_table_add_sock()
351 eloop.kqueue_nevents = next; in eloop_sock_table_add_sock()
370 eloop.max_sock = new_max_sock; in eloop_sock_table_add_sock()
371 eloop.count++; in eloop_sock_table_add_sock()
378 os_memcpy(&eloop.fd_table[sock], &table->table[table->count - 1], in eloop_sock_table_add_sock()
409 eloop.count--; in eloop_sock_table_remove_sock()
413 if (epoll_ctl(eloop.epollfd, EPOLL_CTL_DEL, sock, NULL) < 0) { in eloop_sock_table_remove_sock()
418 os_memset(&eloop.fd_table[sock], 0, sizeof(struct eloop_sock)); in eloop_sock_table_remove_sock()
423 if (kevent(eloop.kqueuefd, &ke, 1, NULL, 0, NULL) < 0) { in eloop_sock_table_remove_sock()
428 os_memset(&eloop.fd_table[sock], 0, sizeof(struct eloop_sock)); in eloop_sock_table_remove_sock()
622 table = &eloop.fd_table[events[i].data.fd]; in eloop_sock_table_dispatch()
627 if (eloop.readers.changed || in eloop_sock_table_dispatch()
628 eloop.writers.changed || in eloop_sock_table_dispatch()
629 eloop.exceptions.changed) in eloop_sock_table_dispatch()
644 table = &eloop.fd_table[events[i].ident]; in eloop_sock_table_dispatch()
649 if (eloop.readers.changed || in eloop_sock_table_dispatch()
650 eloop.writers.changed || in eloop_sock_table_dispatch()
651 eloop.exceptions.changed) in eloop_sock_table_dispatch()
678 close(eloop.kqueuefd); in eloop_sock_requeue()
679 eloop.kqueuefd = kqueue(); in eloop_sock_requeue()
680 if (eloop.kqueuefd < 0) { in eloop_sock_requeue()
686 if (eloop_sock_table_requeue(&eloop.readers) < 0) in eloop_sock_requeue()
688 if (eloop_sock_table_requeue(&eloop.writers) < 0) in eloop_sock_requeue()
690 if (eloop_sock_table_requeue(&eloop.exceptions) < 0) in eloop_sock_requeue()
739 return &eloop.readers; in eloop_get_sock_table()
741 return &eloop.writers; in eloop_get_sock_table()
743 return &eloop.exceptions; in eloop_get_sock_table()
800 wpa_trace_add_ref(timeout, eloop, eloop_data); in eloop_register_timeout()
805 dl_list_for_each(tmp, &eloop.timeout, struct eloop_timeout, list) { in eloop_register_timeout()
811 dl_list_add_tail(&eloop.timeout, &timeout->list); in eloop_register_timeout()
831 wpa_trace_remove_ref(timeout, eloop, timeout->eloop_data); in eloop_remove_timeout()
843 dl_list_for_each_safe(timeout, prev, &eloop.timeout, in eloop_cancel_timeout()
870 dl_list_for_each_safe(timeout, prev, &eloop.timeout, in eloop_cancel_timeout_one()
891 dl_list_for_each(tmp, &eloop.timeout, struct eloop_timeout, list) { in eloop_is_timeout_registered()
909 dl_list_for_each(tmp, &eloop.timeout, struct eloop_timeout, list) { in eloop_deplete_timeout()
941 dl_list_for_each(tmp, &eloop.timeout, struct eloop_timeout, list) { in eloop_replenish_timeout()
984 if ((sig == SIGINT || sig == SIGTERM) && !eloop.pending_terminate) { in eloop_handle_signal()
987 eloop.pending_terminate = 1; in eloop_handle_signal()
993 eloop.signaled++; in eloop_handle_signal()
994 for (i = 0; i < eloop.signal_count; i++) { in eloop_handle_signal()
995 if (eloop.signals[i].sig == sig) { in eloop_handle_signal()
996 eloop.signals[i].signaled++; in eloop_handle_signal()
1007 if (eloop.signaled == 0) in eloop_process_pending_signals()
1009 eloop.signaled = 0; in eloop_process_pending_signals()
1011 if (eloop.pending_terminate) { in eloop_process_pending_signals()
1015 eloop.pending_terminate = 0; in eloop_process_pending_signals()
1018 for (i = 0; i < eloop.signal_count; i++) { in eloop_process_pending_signals()
1019 if (eloop.signals[i].signaled) { in eloop_process_pending_signals()
1020 eloop.signals[i].signaled = 0; in eloop_process_pending_signals()
1021 eloop.signals[i].handler(eloop.signals[i].sig, in eloop_process_pending_signals()
1022 eloop.signals[i].user_data); in eloop_process_pending_signals()
1033 tmp = os_realloc_array(eloop.signals, eloop.signal_count + 1, in eloop_register_signal()
1038 tmp[eloop.signal_count].sig = sig; in eloop_register_signal()
1039 tmp[eloop.signal_count].user_data = user_data; in eloop_register_signal()
1040 tmp[eloop.signal_count].handler = handler; in eloop_register_signal()
1041 tmp[eloop.signal_count].signaled = 0; in eloop_register_signal()
1042 eloop.signal_count++; in eloop_register_signal()
1043 eloop.signals = tmp; in eloop_register_signal()
1098 while (!eloop.terminate && in eloop_run()
1099 (!dl_list_empty(&eloop.timeout) || eloop.readers.count > 0 || in eloop_run()
1100 eloop.writers.count > 0 || eloop.exceptions.count > 0)) { in eloop_run()
1103 if (eloop.pending_terminate) { in eloop_run()
1112 if (eloop.terminate) in eloop_run()
1116 timeout = dl_list_first(&eloop.timeout, struct eloop_timeout, in eloop_run()
1139 &eloop.readers, &eloop.writers, &eloop.exceptions, in eloop_run()
1140 eloop.pollfds, eloop.pollfds_map, in eloop_run()
1141 eloop.max_pollfd_map); in eloop_run()
1142 res = poll(eloop.pollfds, num_poll_fds, in eloop_run()
1146 eloop_sock_table_set_fds(&eloop.readers, rfds); in eloop_run()
1147 eloop_sock_table_set_fds(&eloop.writers, wfds); in eloop_run()
1148 eloop_sock_table_set_fds(&eloop.exceptions, efds); in eloop_run()
1149 res = select(eloop.max_sock + 1, rfds, wfds, efds, in eloop_run()
1153 if (eloop.count == 0) { in eloop_run()
1156 res = epoll_wait(eloop.epollfd, eloop.epoll_events, in eloop_run()
1157 eloop.count, timeout_ms); in eloop_run()
1161 if (eloop.count == 0) { in eloop_run()
1164 res = kevent(eloop.kqueuefd, NULL, 0, in eloop_run()
1165 eloop.kqueue_events, eloop.kqueue_nevents, in eloop_run()
1188 eloop.readers.changed = 0; in eloop_run()
1189 eloop.writers.changed = 0; in eloop_run()
1190 eloop.exceptions.changed = 0; in eloop_run()
1196 timeout = dl_list_first(&eloop.timeout, struct eloop_timeout, in eloop_run()
1214 if (eloop.readers.changed || in eloop_run()
1215 eloop.writers.changed || in eloop_run()
1216 eloop.exceptions.changed) { in eloop_run()
1228 eloop_sock_table_dispatch(&eloop.readers, &eloop.writers, in eloop_run()
1229 &eloop.exceptions, eloop.pollfds_map, in eloop_run()
1230 eloop.max_pollfd_map); in eloop_run()
1233 eloop_sock_table_dispatch(&eloop.readers, rfds); in eloop_run()
1234 eloop_sock_table_dispatch(&eloop.writers, wfds); in eloop_run()
1235 eloop_sock_table_dispatch(&eloop.exceptions, efds); in eloop_run()
1238 eloop_sock_table_dispatch(eloop.epoll_events, res); in eloop_run()
1241 eloop_sock_table_dispatch(eloop.kqueue_events, res); in eloop_run()
1245 eloop.terminate = 0; in eloop_run()
1258 eloop.terminate = 1; in eloop_terminate()
1268 dl_list_for_each_safe(timeout, prev, &eloop.timeout, in eloop_destroy()
1286 eloop_sock_table_destroy(&eloop.readers); in eloop_destroy()
1287 eloop_sock_table_destroy(&eloop.writers); in eloop_destroy()
1288 eloop_sock_table_destroy(&eloop.exceptions); in eloop_destroy()
1289 os_free(eloop.signals); in eloop_destroy()
1292 os_free(eloop.pollfds); in eloop_destroy()
1293 os_free(eloop.pollfds_map); in eloop_destroy()
1296 os_free(eloop.fd_table); in eloop_destroy()
1299 os_free(eloop.epoll_events); in eloop_destroy()
1300 close(eloop.epollfd); in eloop_destroy()
1303 os_free(eloop.kqueue_events); in eloop_destroy()
1304 close(eloop.kqueuefd); in eloop_destroy()
1311 return eloop.terminate || eloop.pending_terminate; in eloop_terminated()