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); 97ec820d77SMatthias Ringwald void (*add_data_source)(btstack_data_source_t *dataSource); 98ec820d77SMatthias Ringwald int (*remove_data_source)(btstack_data_source_t *dataSource); 99ec820d77SMatthias Ringwald void (*set_timer)(btstack_timer_source_t * timer, uint32_t timeout_in_ms); 100ec820d77SMatthias Ringwald void (*add_timer)(btstack_timer_source_t *timer); 101ec820d77SMatthias Ringwald int (*remove_timer)(btstack_timer_source_t *timer); 10282636622SMatthias Ringwald void (*execute)(void); 10382636622SMatthias Ringwald void (*dump_timer)(void); 10482636622SMatthias Ringwald uint32_t (*get_time_ms)(void); 105528a4a3bSMatthias Ringwald } btstack_run_loop_t; 10682636622SMatthias Ringwald 107528a4a3bSMatthias Ringwald void btstack_run_loop_timer_dump(void); 10882636622SMatthias Ringwald 10982636622SMatthias Ringwald /* API_START */ 11082636622SMatthias Ringwald 11182636622SMatthias Ringwald /** 11282636622SMatthias Ringwald * @brief Init main run loop. Must be called before any other run loop call. 11382636622SMatthias Ringwald * 114528a4a3bSMatthias Ringwald * Use btstack_run_loop_$(btstack_run_loop_TYPE)_get_instance() from btstack_run_loop_$(btstack_run_loop_TYPE).h to get instance 11582636622SMatthias Ringwald */ 116528a4a3bSMatthias Ringwald void btstack_run_loop_init(const btstack_run_loop_t * run_loop); 11782636622SMatthias Ringwald 11882636622SMatthias Ringwald /** 11982636622SMatthias Ringwald * @brief Set timer based on current time in milliseconds. 12082636622SMatthias Ringwald */ 121896424b7SMatthias Ringwald void btstack_run_loop_set_timer(btstack_timer_source_t * ts, uint32_t timeout_in_ms); 12282636622SMatthias Ringwald 12382636622SMatthias Ringwald /** 12482636622SMatthias Ringwald * @brief Set callback that will be executed when timer expires. 12582636622SMatthias Ringwald */ 126ec820d77SMatthias Ringwald void btstack_run_loop_set_timer_handler(btstack_timer_source_t * ts, void (*process)(btstack_timer_source_t *_ts)); 12782636622SMatthias Ringwald 12882636622SMatthias Ringwald /** 129fd939756SMatthias Ringwald * @brief Set context for this timer 130fd939756SMatthias Ringwald */ 131fd939756SMatthias Ringwald void btstack_run_loop_set_timer_context(btstack_timer_source_t * ts, void * context); 132fd939756SMatthias Ringwald 133fd939756SMatthias Ringwald /** 134fd939756SMatthias Ringwald * @brief Get context for this timer 135fd939756SMatthias Ringwald */ 136fd939756SMatthias Ringwald void * btstack_run_loop_get_timer_context(btstack_timer_source_t * ts); 137fd939756SMatthias Ringwald 138fd939756SMatthias Ringwald /** 139fd939756SMatthias Ringwald * @brief Add timer source. 14082636622SMatthias Ringwald */ 141ec820d77SMatthias Ringwald void btstack_run_loop_add_timer(btstack_timer_source_t * timer); 142fd939756SMatthias Ringwald 143fd939756SMatthias Ringwald /** 144fd939756SMatthias Ringwald * @brief Remove timer source. 145fd939756SMatthias Ringwald */ 146ec820d77SMatthias Ringwald int btstack_run_loop_remove_timer(btstack_timer_source_t * timer); 14782636622SMatthias Ringwald 14882636622SMatthias Ringwald /** 14982636622SMatthias Ringwald * @brief Get current time in ms 15082636622SMatthias Ringwald * @note 32-bit ms counter will overflow after approx. 52 days 15182636622SMatthias Ringwald */ 152528a4a3bSMatthias Ringwald uint32_t btstack_run_loop_get_time_ms(void); 15382636622SMatthias Ringwald 15482636622SMatthias Ringwald /** 15582636622SMatthias Ringwald * @brief Set data source callback. 15682636622SMatthias Ringwald */ 157896424b7SMatthias 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)); 15882636622SMatthias Ringwald 15982636622SMatthias Ringwald /** 1603a5c43eeSMatthias Ringwald * @brief Set data source file descriptor. 161896424b7SMatthias Ringwald * @param data_source 162896424b7SMatthias Ringwald * @param fd file descriptor 1633a5c43eeSMatthias Ringwald * @note No effect if port doensn't have file descriptors 1643a5c43eeSMatthias Ringwald */ 165896424b7SMatthias Ringwald void btstack_run_loop_set_data_source_fd(btstack_data_source_t * data_source, int fd); 1663a5c43eeSMatthias Ringwald 1673a5c43eeSMatthias Ringwald /** 1683a5c43eeSMatthias Ringwald * @brief Get data source file descriptor. 169896424b7SMatthias Ringwald * @param data_source 1703a5c43eeSMatthias Ringwald */ 171896424b7SMatthias Ringwald int btstack_run_loop_get_data_source_fd(btstack_data_source_t * data_source); 1723a5c43eeSMatthias Ringwald 1733a5c43eeSMatthias Ringwald /** 174896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 175896424b7SMatthias Ringwald * @param data_source to remove 176896424b7SMatthias Ringwald * @param callback types to enable 17782636622SMatthias Ringwald */ 178*24ced5a6SMatthias Ringwald void btstack_run_loop_enable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 179896424b7SMatthias Ringwald 180896424b7SMatthias Ringwald /** 181896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 182896424b7SMatthias Ringwald * @param data_source to remove 183896424b7SMatthias Ringwald * @param callback types to disable 184896424b7SMatthias Ringwald */ 185*24ced5a6SMatthias Ringwald void btstack_run_loop_disable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 186896424b7SMatthias Ringwald 187896424b7SMatthias Ringwald /** 188896424b7SMatthias Ringwald * @brief Add data source to run loop 189896424b7SMatthias Ringwald * @param data_source to add 190896424b7SMatthias Ringwald */ 191896424b7SMatthias Ringwald void btstack_run_loop_add_data_source(btstack_data_source_t * data_source); 192896424b7SMatthias Ringwald 193896424b7SMatthias Ringwald /** 194896424b7SMatthias Ringwald * @brief Remove data source from run loop 195896424b7SMatthias Ringwald * @param data_source to remove 196896424b7SMatthias Ringwald */ 197896424b7SMatthias Ringwald int btstack_run_loop_remove_data_source(btstack_data_source_t * data_source); 19882636622SMatthias Ringwald 19982636622SMatthias Ringwald /** 20082636622SMatthias Ringwald * @brief Execute configured run loop. This function does not return. 20182636622SMatthias Ringwald */ 202528a4a3bSMatthias Ringwald void btstack_run_loop_execute(void); 20382636622SMatthias Ringwald 20482636622SMatthias Ringwald /* API_END */ 20582636622SMatthias Ringwald 20682636622SMatthias Ringwald #if defined __cplusplus 20782636622SMatthias Ringwald } 20882636622SMatthias Ringwald #endif 20982636622SMatthias Ringwald 210528a4a3bSMatthias Ringwald #endif // __btstack_run_loop_H 211