182636622SMatthias Ringwald /* 282636622SMatthias Ringwald * Copyright (C) 2014 BlueKitchen GmbH 382636622SMatthias Ringwald * 482636622SMatthias Ringwald * Redistribution and use in source and binary forms, with or without 582636622SMatthias Ringwald * modification, are permitted provided that the following conditions 682636622SMatthias Ringwald * are met: 782636622SMatthias Ringwald * 882636622SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 982636622SMatthias Ringwald * notice, this list of conditions and the following disclaimer. 1082636622SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 1182636622SMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 1282636622SMatthias Ringwald * documentation and/or other materials provided with the distribution. 1382636622SMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 1482636622SMatthias Ringwald * contributors may be used to endorse or promote products derived 1582636622SMatthias Ringwald * from this software without specific prior written permission. 1682636622SMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 1782636622SMatthias Ringwald * personal benefit and not for any commercial purpose or for 1882636622SMatthias Ringwald * monetary gain. 1982636622SMatthias Ringwald * 2082636622SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 2182636622SMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 2282636622SMatthias Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 2382636622SMatthias Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 2482636622SMatthias Ringwald * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 2582636622SMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 2682636622SMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 2782636622SMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 2882636622SMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 2982636622SMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 3082636622SMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 3182636622SMatthias Ringwald * SUCH DAMAGE. 3282636622SMatthias Ringwald * 3382636622SMatthias Ringwald * Please inquire about commercial licensing options at 3482636622SMatthias Ringwald * [email protected] 3582636622SMatthias Ringwald * 3682636622SMatthias Ringwald */ 3782636622SMatthias Ringwald 3882636622SMatthias Ringwald /* 3982636622SMatthias Ringwald * run_loop.h 4082636622SMatthias Ringwald * 4182636622SMatthias Ringwald * Created by Matthias Ringwald on 6/6/09. 4282636622SMatthias Ringwald */ 4382636622SMatthias Ringwald 44528a4a3bSMatthias Ringwald #ifndef __btstack_run_loop_H 45528a4a3bSMatthias Ringwald #define __btstack_run_loop_H 4682636622SMatthias Ringwald 477907f069SMatthias Ringwald #include "btstack_config.h" 4882636622SMatthias Ringwald 4982636622SMatthias Ringwald #include "btstack_linked_list.h" 5082636622SMatthias Ringwald 5182636622SMatthias Ringwald #include <stdint.h> 5282636622SMatthias Ringwald 5382636622SMatthias Ringwald #ifdef HAVE_TIME 5482636622SMatthias Ringwald #include <sys/time.h> 5582636622SMatthias Ringwald #endif 5682636622SMatthias Ringwald 5782636622SMatthias Ringwald #if defined __cplusplus 5882636622SMatthias Ringwald extern "C" { 5982636622SMatthias Ringwald #endif 6082636622SMatthias Ringwald 617cd5ef95SMatthias Ringwald 627cd5ef95SMatthias Ringwald /** 637cd5ef95SMatthias Ringwald * Callback types for run loop data sources 647cd5ef95SMatthias Ringwald */ 657cd5ef95SMatthias Ringwald typedef enum { 667cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_POLL = 1 << 0, 677cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_READ = 1 << 1, 687cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_WRITE = 1 << 2, 697cd5ef95SMatthias Ringwald } btstack_data_source_callback_type_t; 707cd5ef95SMatthias Ringwald 71ec820d77SMatthias Ringwald typedef struct btstack_data_source { 725ed06181SMatthias Ringwald // 7382636622SMatthias Ringwald btstack_linked_item_t item; 745ed06181SMatthias Ringwald // file descriptor to watch for run loops that support file descriptors 755ed06181SMatthias Ringwald int fd; 765ed06181SMatthias Ringwald // callback to call for enabled callback types 777cd5ef95SMatthias Ringwald void (*process)(struct btstack_data_source *ds, btstack_data_source_callback_type_t callback_type); 785ed06181SMatthias Ringwald // flags storing enabled callback types 795ed06181SMatthias Ringwald uint16_t flags; 80ec820d77SMatthias Ringwald } btstack_data_source_t; 8182636622SMatthias Ringwald 82eb886013SMatthias Ringwald typedef struct btstack_timer_source { 8382636622SMatthias Ringwald btstack_linked_item_t item; 8482636622SMatthias Ringwald #ifdef HAVE_TIME 8582636622SMatthias Ringwald struct timeval timeout; // <-- next timeout 8682636622SMatthias Ringwald #endif 8782636622SMatthias Ringwald #if defined(HAVE_TICK) || defined(HAVE_TIME_MS) 8882636622SMatthias Ringwald uint32_t timeout; // timeout in system ticks (HAVE_TICK) or millis (HAVE_TIME_MS) 8982636622SMatthias Ringwald #endif 90fd939756SMatthias Ringwald // will be called when timer fired 91fd939756SMatthias Ringwald void (*process)(struct btstack_timer_source *ts); 92fd939756SMatthias Ringwald void * context; 93ec820d77SMatthias Ringwald } btstack_timer_source_t; 9482636622SMatthias Ringwald 95ec820d77SMatthias Ringwald typedef struct btstack_run_loop { 9682636622SMatthias Ringwald void (*init)(void); 97*0d70dd62SMatthias Ringwald void (*add_data_source)(btstack_data_source_t * data_source); 98*0d70dd62SMatthias Ringwald int (*remove_data_source)(btstack_data_source_t * data_source); 99*0d70dd62SMatthias Ringwald void (*enable_data_source_callbacks)(btstack_data_source_t * data_source, uint16_t callbacks); 100*0d70dd62SMatthias Ringwald void (*disable_data_source_callbacks)(btstack_data_source_t * data_source, uint16_t callbacks); 101ec820d77SMatthias Ringwald void (*set_timer)(btstack_timer_source_t * timer, uint32_t timeout_in_ms); 102ec820d77SMatthias Ringwald void (*add_timer)(btstack_timer_source_t *timer); 103ec820d77SMatthias Ringwald int (*remove_timer)(btstack_timer_source_t *timer); 10482636622SMatthias Ringwald void (*execute)(void); 10582636622SMatthias Ringwald void (*dump_timer)(void); 10682636622SMatthias Ringwald uint32_t (*get_time_ms)(void); 107528a4a3bSMatthias Ringwald } btstack_run_loop_t; 10882636622SMatthias Ringwald 109528a4a3bSMatthias Ringwald void btstack_run_loop_timer_dump(void); 11082636622SMatthias Ringwald 11182636622SMatthias Ringwald /* API_START */ 11282636622SMatthias Ringwald 11382636622SMatthias Ringwald /** 11482636622SMatthias Ringwald * @brief Init main run loop. Must be called before any other run loop call. 11582636622SMatthias Ringwald * 116528a4a3bSMatthias Ringwald * Use btstack_run_loop_$(btstack_run_loop_TYPE)_get_instance() from btstack_run_loop_$(btstack_run_loop_TYPE).h to get instance 11782636622SMatthias Ringwald */ 118528a4a3bSMatthias Ringwald void btstack_run_loop_init(const btstack_run_loop_t * run_loop); 11982636622SMatthias Ringwald 12082636622SMatthias Ringwald /** 12182636622SMatthias Ringwald * @brief Set timer based on current time in milliseconds. 12282636622SMatthias Ringwald */ 123896424b7SMatthias Ringwald void btstack_run_loop_set_timer(btstack_timer_source_t * ts, uint32_t timeout_in_ms); 12482636622SMatthias Ringwald 12582636622SMatthias Ringwald /** 12682636622SMatthias Ringwald * @brief Set callback that will be executed when timer expires. 12782636622SMatthias Ringwald */ 128ec820d77SMatthias Ringwald void btstack_run_loop_set_timer_handler(btstack_timer_source_t * ts, void (*process)(btstack_timer_source_t *_ts)); 12982636622SMatthias Ringwald 13082636622SMatthias Ringwald /** 131fd939756SMatthias Ringwald * @brief Set context for this timer 132fd939756SMatthias Ringwald */ 133fd939756SMatthias Ringwald void btstack_run_loop_set_timer_context(btstack_timer_source_t * ts, void * context); 134fd939756SMatthias Ringwald 135fd939756SMatthias Ringwald /** 136fd939756SMatthias Ringwald * @brief Get context for this timer 137fd939756SMatthias Ringwald */ 138fd939756SMatthias Ringwald void * btstack_run_loop_get_timer_context(btstack_timer_source_t * ts); 139fd939756SMatthias Ringwald 140fd939756SMatthias Ringwald /** 141fd939756SMatthias Ringwald * @brief Add timer source. 14282636622SMatthias Ringwald */ 143ec820d77SMatthias Ringwald void btstack_run_loop_add_timer(btstack_timer_source_t * timer); 144fd939756SMatthias Ringwald 145fd939756SMatthias Ringwald /** 146fd939756SMatthias Ringwald * @brief Remove timer source. 147fd939756SMatthias Ringwald */ 148ec820d77SMatthias Ringwald int btstack_run_loop_remove_timer(btstack_timer_source_t * timer); 14982636622SMatthias Ringwald 15082636622SMatthias Ringwald /** 15182636622SMatthias Ringwald * @brief Get current time in ms 15282636622SMatthias Ringwald * @note 32-bit ms counter will overflow after approx. 52 days 15382636622SMatthias Ringwald */ 154528a4a3bSMatthias Ringwald uint32_t btstack_run_loop_get_time_ms(void); 15582636622SMatthias Ringwald 15682636622SMatthias Ringwald /** 15782636622SMatthias Ringwald * @brief Set data source callback. 15882636622SMatthias Ringwald */ 159896424b7SMatthias Ringwald void btstack_run_loop_set_data_source_handler(btstack_data_source_t * data_source, void (*process)(btstack_data_source_t *_ds, btstack_data_source_callback_type_t callback_type)); 16082636622SMatthias Ringwald 16182636622SMatthias Ringwald /** 1623a5c43eeSMatthias Ringwald * @brief Set data source file descriptor. 163896424b7SMatthias Ringwald * @param data_source 164896424b7SMatthias Ringwald * @param fd file descriptor 1653a5c43eeSMatthias Ringwald * @note No effect if port doensn't have file descriptors 1663a5c43eeSMatthias Ringwald */ 167896424b7SMatthias Ringwald void btstack_run_loop_set_data_source_fd(btstack_data_source_t * data_source, int fd); 1683a5c43eeSMatthias Ringwald 1693a5c43eeSMatthias Ringwald /** 1703a5c43eeSMatthias Ringwald * @brief Get data source file descriptor. 171896424b7SMatthias Ringwald * @param data_source 1723a5c43eeSMatthias Ringwald */ 173896424b7SMatthias Ringwald int btstack_run_loop_get_data_source_fd(btstack_data_source_t * data_source); 1743a5c43eeSMatthias Ringwald 1753a5c43eeSMatthias Ringwald /** 176896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 177896424b7SMatthias Ringwald * @param data_source to remove 178896424b7SMatthias Ringwald * @param callback types to enable 17982636622SMatthias Ringwald */ 18024ced5a6SMatthias Ringwald void btstack_run_loop_enable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 181896424b7SMatthias Ringwald 182896424b7SMatthias Ringwald /** 183896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 184896424b7SMatthias Ringwald * @param data_source to remove 185896424b7SMatthias Ringwald * @param callback types to disable 186896424b7SMatthias Ringwald */ 18724ced5a6SMatthias Ringwald void btstack_run_loop_disable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 188896424b7SMatthias Ringwald 189896424b7SMatthias Ringwald /** 190896424b7SMatthias Ringwald * @brief Add data source to run loop 191896424b7SMatthias Ringwald * @param data_source to add 192896424b7SMatthias Ringwald */ 193896424b7SMatthias Ringwald void btstack_run_loop_add_data_source(btstack_data_source_t * data_source); 194896424b7SMatthias Ringwald 195896424b7SMatthias Ringwald /** 196896424b7SMatthias Ringwald * @brief Remove data source from run loop 197896424b7SMatthias Ringwald * @param data_source to remove 198896424b7SMatthias Ringwald */ 199896424b7SMatthias Ringwald int btstack_run_loop_remove_data_source(btstack_data_source_t * data_source); 20082636622SMatthias Ringwald 20182636622SMatthias Ringwald /** 20282636622SMatthias Ringwald * @brief Execute configured run loop. This function does not return. 20382636622SMatthias Ringwald */ 204528a4a3bSMatthias Ringwald void btstack_run_loop_execute(void); 20582636622SMatthias Ringwald 20682636622SMatthias Ringwald /* API_END */ 20782636622SMatthias Ringwald 20882636622SMatthias Ringwald #if defined __cplusplus 20982636622SMatthias Ringwald } 21082636622SMatthias Ringwald #endif 21182636622SMatthias Ringwald 212528a4a3bSMatthias Ringwald #endif // __btstack_run_loop_H 213