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 4480e33422SMatthias Ringwald #ifndef btstack_run_loop_H 4580e33422SMatthias Ringwald #define btstack_run_loop_H 4682636622SMatthias Ringwald 477907f069SMatthias Ringwald #include "btstack_config.h" 4882636622SMatthias Ringwald 49*d58a1b5fSMatthias Ringwald #include "btstack_bool.h" 5082636622SMatthias Ringwald #include "btstack_linked_list.h" 5182636622SMatthias Ringwald 5282636622SMatthias Ringwald #include <stdint.h> 5382636622SMatthias Ringwald 5482636622SMatthias Ringwald #if defined __cplusplus 5582636622SMatthias Ringwald extern "C" { 5682636622SMatthias Ringwald #endif 5782636622SMatthias Ringwald 587cd5ef95SMatthias Ringwald 597cd5ef95SMatthias Ringwald /** 607cd5ef95SMatthias Ringwald * Callback types for run loop data sources 617cd5ef95SMatthias Ringwald */ 627cd5ef95SMatthias Ringwald typedef enum { 637cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_POLL = 1 << 0, 647cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_READ = 1 << 1, 657cd5ef95SMatthias Ringwald DATA_SOURCE_CALLBACK_WRITE = 1 << 2, 667cd5ef95SMatthias Ringwald } btstack_data_source_callback_type_t; 677cd5ef95SMatthias Ringwald 68ec820d77SMatthias Ringwald typedef struct btstack_data_source { 693aad8623SMatthias Ringwald // linked item 7082636622SMatthias Ringwald btstack_linked_item_t item; 713aad8623SMatthias Ringwald 723aad8623SMatthias Ringwald // item to watch in run loop 733aad8623SMatthias Ringwald union { 743aad8623SMatthias Ringwald // file descriptor for posix systems 755ed06181SMatthias Ringwald int fd; 763aad8623SMatthias Ringwald // handle on windows 773aad8623SMatthias Ringwald void * handle; 78398a95ecSMatthias Ringwald } source; 793aad8623SMatthias Ringwald 805ed06181SMatthias Ringwald // callback to call for enabled callback types 817cd5ef95SMatthias Ringwald void (*process)(struct btstack_data_source *ds, btstack_data_source_callback_type_t callback_type); 823aad8623SMatthias Ringwald 835ed06181SMatthias Ringwald // flags storing enabled callback types 845ed06181SMatthias Ringwald uint16_t flags; 853aad8623SMatthias Ringwald 86ec820d77SMatthias Ringwald } btstack_data_source_t; 8782636622SMatthias Ringwald 88eb886013SMatthias Ringwald typedef struct btstack_timer_source { 8982636622SMatthias Ringwald btstack_linked_item_t item; 90f316a845SMatthias Ringwald // timeout in system ticks (HAVE_EMBEDDED_TICK) or milliseconds (HAVE_EMBEDDED_TIME_MS) 91f316a845SMatthias Ringwald uint32_t timeout; 92fd939756SMatthias Ringwald // will be called when timer fired 93fd939756SMatthias Ringwald void (*process)(struct btstack_timer_source *ts); 94fd939756SMatthias Ringwald void * context; 95ec820d77SMatthias Ringwald } btstack_timer_source_t; 9682636622SMatthias Ringwald 97ec820d77SMatthias Ringwald typedef struct btstack_run_loop { 9882636622SMatthias Ringwald void (*init)(void); 990d70dd62SMatthias Ringwald void (*add_data_source)(btstack_data_source_t * data_source); 100*d58a1b5fSMatthias Ringwald bool (*remove_data_source)(btstack_data_source_t * data_source); 1010d70dd62SMatthias Ringwald void (*enable_data_source_callbacks)(btstack_data_source_t * data_source, uint16_t callbacks); 1020d70dd62SMatthias Ringwald void (*disable_data_source_callbacks)(btstack_data_source_t * data_source, uint16_t callbacks); 103ec820d77SMatthias Ringwald void (*set_timer)(btstack_timer_source_t * timer, uint32_t timeout_in_ms); 104ec820d77SMatthias Ringwald void (*add_timer)(btstack_timer_source_t *timer); 105*d58a1b5fSMatthias Ringwald bool (*remove_timer)(btstack_timer_source_t *timer); 10682636622SMatthias Ringwald void (*execute)(void); 10782636622SMatthias Ringwald void (*dump_timer)(void); 10882636622SMatthias Ringwald uint32_t (*get_time_ms)(void); 109528a4a3bSMatthias Ringwald } btstack_run_loop_t; 11082636622SMatthias Ringwald 111528a4a3bSMatthias Ringwald void btstack_run_loop_timer_dump(void); 11282636622SMatthias Ringwald 11382636622SMatthias Ringwald /* API_START */ 11482636622SMatthias Ringwald 11582636622SMatthias Ringwald /** 11682636622SMatthias Ringwald * @brief Init main run loop. Must be called before any other run loop call. 11782636622SMatthias Ringwald * 118528a4a3bSMatthias Ringwald * Use btstack_run_loop_$(btstack_run_loop_TYPE)_get_instance() from btstack_run_loop_$(btstack_run_loop_TYPE).h to get instance 11982636622SMatthias Ringwald */ 120528a4a3bSMatthias Ringwald void btstack_run_loop_init(const btstack_run_loop_t * run_loop); 12182636622SMatthias Ringwald 12282636622SMatthias Ringwald /** 12382636622SMatthias Ringwald * @brief Set timer based on current time in milliseconds. 12482636622SMatthias Ringwald */ 125896424b7SMatthias Ringwald void btstack_run_loop_set_timer(btstack_timer_source_t * ts, uint32_t timeout_in_ms); 12682636622SMatthias Ringwald 12782636622SMatthias Ringwald /** 12882636622SMatthias Ringwald * @brief Set callback that will be executed when timer expires. 12982636622SMatthias Ringwald */ 130ec820d77SMatthias Ringwald void btstack_run_loop_set_timer_handler(btstack_timer_source_t * ts, void (*process)(btstack_timer_source_t *_ts)); 13182636622SMatthias Ringwald 13282636622SMatthias Ringwald /** 133fd939756SMatthias Ringwald * @brief Set context for this timer 134fd939756SMatthias Ringwald */ 135fd939756SMatthias Ringwald void btstack_run_loop_set_timer_context(btstack_timer_source_t * ts, void * context); 136fd939756SMatthias Ringwald 137fd939756SMatthias Ringwald /** 138fd939756SMatthias Ringwald * @brief Get context for this timer 139fd939756SMatthias Ringwald */ 140fd939756SMatthias Ringwald void * btstack_run_loop_get_timer_context(btstack_timer_source_t * ts); 141fd939756SMatthias Ringwald 142fd939756SMatthias Ringwald /** 143fd939756SMatthias Ringwald * @brief Add timer source. 14482636622SMatthias Ringwald */ 145ec820d77SMatthias Ringwald void btstack_run_loop_add_timer(btstack_timer_source_t * timer); 146fd939756SMatthias Ringwald 147fd939756SMatthias Ringwald /** 148fd939756SMatthias Ringwald * @brief Remove timer source. 149fd939756SMatthias Ringwald */ 150ec820d77SMatthias Ringwald int btstack_run_loop_remove_timer(btstack_timer_source_t * timer); 15182636622SMatthias Ringwald 15282636622SMatthias Ringwald /** 15382636622SMatthias Ringwald * @brief Get current time in ms 15482636622SMatthias Ringwald * @note 32-bit ms counter will overflow after approx. 52 days 15582636622SMatthias Ringwald */ 156528a4a3bSMatthias Ringwald uint32_t btstack_run_loop_get_time_ms(void); 15782636622SMatthias Ringwald 15882636622SMatthias Ringwald /** 15982636622SMatthias Ringwald * @brief Set data source callback. 16082636622SMatthias Ringwald */ 161896424b7SMatthias 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)); 16282636622SMatthias Ringwald 16382636622SMatthias Ringwald /** 1643a5c43eeSMatthias Ringwald * @brief Set data source file descriptor. 165896424b7SMatthias Ringwald * @param data_source 166896424b7SMatthias Ringwald * @param fd file descriptor 1673a5c43eeSMatthias Ringwald * @note No effect if port doensn't have file descriptors 1683a5c43eeSMatthias Ringwald */ 169896424b7SMatthias Ringwald void btstack_run_loop_set_data_source_fd(btstack_data_source_t * data_source, int fd); 1703a5c43eeSMatthias Ringwald 1713a5c43eeSMatthias Ringwald /** 1723a5c43eeSMatthias Ringwald * @brief Get data source file descriptor. 173896424b7SMatthias Ringwald * @param data_source 1743a5c43eeSMatthias Ringwald */ 175896424b7SMatthias Ringwald int btstack_run_loop_get_data_source_fd(btstack_data_source_t * data_source); 1763a5c43eeSMatthias Ringwald 177f04a41aeSMatthias Ringwald 178f04a41aeSMatthias Ringwald /** 179f04a41aeSMatthias Ringwald * @brief Set data source file descriptor. 180f04a41aeSMatthias Ringwald * @param data_source 181f04a41aeSMatthias Ringwald * @param handle 182f04a41aeSMatthias Ringwald * @note No effect if port doensn't have file descriptors 183f04a41aeSMatthias Ringwald */ 184f04a41aeSMatthias Ringwald void btstack_run_loop_set_data_source_handle(btstack_data_source_t * data_source, void * handle); 185f04a41aeSMatthias Ringwald 186f04a41aeSMatthias Ringwald /** 187f04a41aeSMatthias Ringwald * @brief Get data source file descriptor. 188f04a41aeSMatthias Ringwald * @param data_source 189f04a41aeSMatthias Ringwald */ 190f04a41aeSMatthias Ringwald void * btstack_run_loop_get_data_source_handle(btstack_data_source_t * data_source); 191f04a41aeSMatthias Ringwald 1923a5c43eeSMatthias Ringwald /** 193896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 194896424b7SMatthias Ringwald * @param data_source to remove 195896424b7SMatthias Ringwald * @param callback types to enable 19682636622SMatthias Ringwald */ 19724ced5a6SMatthias Ringwald void btstack_run_loop_enable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 198896424b7SMatthias Ringwald 199896424b7SMatthias Ringwald /** 200896424b7SMatthias Ringwald * @brief Enable callbacks for a data source 201896424b7SMatthias Ringwald * @param data_source to remove 202896424b7SMatthias Ringwald * @param callback types to disable 203896424b7SMatthias Ringwald */ 20424ced5a6SMatthias Ringwald void btstack_run_loop_disable_data_source_callbacks(btstack_data_source_t * data_source, uint16_t callbacks); 205896424b7SMatthias Ringwald 206896424b7SMatthias Ringwald /** 207896424b7SMatthias Ringwald * @brief Add data source to run loop 208896424b7SMatthias Ringwald * @param data_source to add 209896424b7SMatthias Ringwald */ 210896424b7SMatthias Ringwald void btstack_run_loop_add_data_source(btstack_data_source_t * data_source); 211896424b7SMatthias Ringwald 212896424b7SMatthias Ringwald /** 213896424b7SMatthias Ringwald * @brief Remove data source from run loop 214896424b7SMatthias Ringwald * @param data_source to remove 215896424b7SMatthias Ringwald */ 216896424b7SMatthias Ringwald int btstack_run_loop_remove_data_source(btstack_data_source_t * data_source); 21782636622SMatthias Ringwald 21882636622SMatthias Ringwald /** 21982636622SMatthias Ringwald * @brief Execute configured run loop. This function does not return. 22082636622SMatthias Ringwald */ 221528a4a3bSMatthias Ringwald void btstack_run_loop_execute(void); 22282636622SMatthias Ringwald 22382636622SMatthias Ringwald /* API_END */ 22482636622SMatthias Ringwald 22582636622SMatthias Ringwald #if defined __cplusplus 22682636622SMatthias Ringwald } 22782636622SMatthias Ringwald #endif 22882636622SMatthias Ringwald 22980e33422SMatthias Ringwald #endif // btstack_run_loop_H 230