mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-01 00:28:18 +00:00
btstack_run_loop_corefoundation: implement execute on main thread
This commit is contained in:
parent
dcf86b2997
commit
f8d5edf1c3
@ -51,12 +51,17 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
static struct timeval init_tv;
|
static struct timeval init_tv;
|
||||||
static CFAbsoluteTime init_cf;
|
static CFAbsoluteTime init_cf;
|
||||||
static CFRunLoopRef current_runloop;
|
static CFRunLoopRef current_runloop;
|
||||||
|
|
||||||
static const btstack_run_loop_t btstack_run_loop_corefoundation;
|
// to trigger run loop from other thread
|
||||||
|
static int run_loop_pipe_fd;
|
||||||
|
static btstack_data_source_t run_loop_pipe_ds;
|
||||||
|
static pthread_mutex_t run_loop_callback_mutex = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
CFSocketRef socket;
|
CFSocketRef socket;
|
||||||
@ -213,12 +218,54 @@ static void btstack_run_loop_corefoundation_set_timer(btstack_timer_source_t *a,
|
|||||||
log_debug("btstack_run_loop_corefoundation_set_timer to %u ms (now %u, timeout %u)", a->timeout, time_ms, timeout_in_ms);
|
log_debug("btstack_run_loop_corefoundation_set_timer to %u ms (now %u, timeout %u)", a->timeout, time_ms, timeout_in_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void btstack_run_loop_corefoundation_pipe_process(btstack_data_source_t * ds, btstack_data_source_callback_type_t callback_type){
|
||||||
|
UNUSED(callback_type);
|
||||||
|
uint8_t buffer[1];
|
||||||
|
(void) read(ds->source.fd, buffer, 1);
|
||||||
|
// execute callbacks - protect list with mutex
|
||||||
|
while (1){
|
||||||
|
pthread_mutex_lock(&run_loop_callback_mutex);
|
||||||
|
btstack_context_callback_registration_t * callback_registration = (btstack_context_callback_registration_t *) btstack_linked_list_pop(&btstack_run_loop_base_callbacks);
|
||||||
|
pthread_mutex_unlock(&run_loop_callback_mutex);
|
||||||
|
if (callback_registration == NULL){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
(*callback_registration->callback)(callback_registration->context);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void btstack_run_loop_corefoundation_execute_on_main_thread(btstack_context_callback_registration_t * callback_registration){
|
||||||
|
// protect list with mutex
|
||||||
|
pthread_mutex_lock(&run_loop_callback_mutex);
|
||||||
|
btstack_run_loop_base_add_callback(callback_registration);
|
||||||
|
pthread_mutex_unlock(&run_loop_callback_mutex);
|
||||||
|
// trigger run loop
|
||||||
|
if (run_loop_pipe_fd >= 0){
|
||||||
|
const uint8_t x = (uint8_t) 'x';
|
||||||
|
(void) write(run_loop_pipe_fd, &x, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void btstack_run_loop_corefoundation_init(void){
|
static void btstack_run_loop_corefoundation_init(void){
|
||||||
gettimeofday(&init_tv, NULL);
|
gettimeofday(&init_tv, NULL);
|
||||||
// calc CFAbsoluteTime for init_tv
|
// calc CFAbsoluteTime for init_tv
|
||||||
// note: timeval uses unix time: seconds since Jan 1st 1970, CF uses Jan 1st 2001 as reference date
|
// note: timeval uses unix time: seconds since Jan 1st 1970, CF uses Jan 1st 2001 as reference date
|
||||||
init_cf = ((double)init_tv.tv_sec) + (((double)init_tv.tv_usec)/1000000.0) - kCFAbsoluteTimeIntervalSince1970; // unix time - since Jan 1st 1970
|
init_cf = ((double)init_tv.tv_sec) + (((double)init_tv.tv_usec)/1000000.0) - kCFAbsoluteTimeIntervalSince1970; // unix time - since Jan 1st 1970
|
||||||
|
|
||||||
|
// create pipe and register as data source
|
||||||
|
int fildes[2];
|
||||||
|
int status = pipe(fildes);
|
||||||
|
if (status == 0 ) {
|
||||||
|
run_loop_pipe_fd = fildes[1];
|
||||||
|
run_loop_pipe_ds.source.fd = fildes[0];
|
||||||
|
run_loop_pipe_ds.flags = DATA_SOURCE_CALLBACK_READ;
|
||||||
|
run_loop_pipe_ds.process = &btstack_run_loop_corefoundation_pipe_process;
|
||||||
|
btstack_run_loop_base_add_data_source(&run_loop_pipe_ds);
|
||||||
|
log_info("Pipe in %u, out %u", run_loop_pipe_fd, fildes[0]);
|
||||||
|
} else {
|
||||||
|
run_loop_pipe_fd = -1;
|
||||||
|
log_error("pipe() failed");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void btstack_run_loop_corefoundation_execute(void) {
|
static void btstack_run_loop_corefoundation_execute(void) {
|
||||||
@ -237,13 +284,6 @@ static void btstack_run_loop_corefoundation_dump_timer(void){
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Provide btstack_run_loop_corefoundation instance
|
|
||||||
*/
|
|
||||||
const btstack_run_loop_t * btstack_run_loop_corefoundation_get_instance(void){
|
|
||||||
return &btstack_run_loop_corefoundation;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const btstack_run_loop_t btstack_run_loop_corefoundation = {
|
static const btstack_run_loop_t btstack_run_loop_corefoundation = {
|
||||||
&btstack_run_loop_corefoundation_init,
|
&btstack_run_loop_corefoundation_init,
|
||||||
&btstack_run_loop_corefoundation_add_data_source,
|
&btstack_run_loop_corefoundation_add_data_source,
|
||||||
@ -257,7 +297,13 @@ static const btstack_run_loop_t btstack_run_loop_corefoundation = {
|
|||||||
&btstack_run_loop_corefoundation_dump_timer,
|
&btstack_run_loop_corefoundation_dump_timer,
|
||||||
&btstack_run_loop_corefoundation_get_time_ms,
|
&btstack_run_loop_corefoundation_get_time_ms,
|
||||||
NULL, /* poll data sources from irq */
|
NULL, /* poll data sources from irq */
|
||||||
NULL, /* execute on main thread */
|
&btstack_run_loop_corefoundation_execute_on_main_thread,
|
||||||
&btstack_run_loop_corefoundation_trigger_exit,
|
&btstack_run_loop_corefoundation_trigger_exit,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provide btstack_run_loop_corefoundation instance
|
||||||
|
*/
|
||||||
|
const btstack_run_loop_t * btstack_run_loop_corefoundation_get_instance(void){
|
||||||
|
return &btstack_run_loop_corefoundation;
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user