mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-20 18:01:44 +00:00 
			
		
		
		
	fix(ble): fix flushout and sync issues
This commit is contained in:
		| @@ -176,8 +176,10 @@ IRAM_ATTR static void esp_timer_cb_flushout(void) | |||||||
|         if (trans_head->trans.length) { |         if (trans_head->trans.length) { | ||||||
|             spi_out_append_trans(); |             spi_out_append_trans(); | ||||||
|         } |         } | ||||||
|     } else { |     } | ||||||
|         // Restart flushout timer |  | ||||||
|  |     // Restart flushout timer if not active | ||||||
|  |     if (!esp_timer_is_active(flushout_timer_handle)) { | ||||||
|         esp_timer_start_once(flushout_timer_handle, SPI_OUT_FLUSHOUT_TIMEOUT); |         esp_timer_start_once(flushout_timer_handle, SPI_OUT_FLUSHOUT_TIMEOUT); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -193,6 +195,9 @@ IRAM_ATTR static void esp_timer_cb_ts_sync(void) | |||||||
|     uint32_t lc_ts = 0; |     uint32_t lc_ts = 0; | ||||||
|     uint32_t esp_ts = 0; |     uint32_t esp_ts = 0; | ||||||
|  |  | ||||||
|  |     // Toggle sync IO | ||||||
|  |     sync_io_level = !sync_io_level; | ||||||
|  |  | ||||||
|     // Enter critical |     // Enter critical | ||||||
|     portMUX_TYPE spinlock = portMUX_INITIALIZER_UNLOCKED; |     portMUX_TYPE spinlock = portMUX_INITIALIZER_UNLOCKED; | ||||||
|     portENTER_CRITICAL_SAFE(&spinlock); |     portENTER_CRITICAL_SAFE(&spinlock); | ||||||
| @@ -205,7 +210,7 @@ IRAM_ATTR static void esp_timer_cb_ts_sync(void) | |||||||
|     lc_ts = r_os_cputime_get32(); |     lc_ts = r_os_cputime_get32(); | ||||||
| #endif // CONFIG_IDF_TARGET_ESP32C2 | #endif // CONFIG_IDF_TARGET_ESP32C2 | ||||||
|  |  | ||||||
|     // Toggle Sync IO |     // Set sync IO level | ||||||
|     gpio_set_level(CONFIG_BT_BLE_LOG_SPI_OUT_SYNC_IO_NUM, (uint32_t)sync_io_level); |     gpio_set_level(CONFIG_BT_BLE_LOG_SPI_OUT_SYNC_IO_NUM, (uint32_t)sync_io_level); | ||||||
|  |  | ||||||
|     // Get ESP timestamp |     // Get ESP timestamp | ||||||
| @@ -219,9 +224,6 @@ IRAM_ATTR static void esp_timer_cb_ts_sync(void) | |||||||
|     memcpy(sync_frame + 1, &lc_ts, sizeof(lc_ts)); |     memcpy(sync_frame + 1, &lc_ts, sizeof(lc_ts)); | ||||||
|     memcpy(sync_frame + 5, &esp_ts, sizeof(esp_ts)); |     memcpy(sync_frame + 5, &esp_ts, sizeof(esp_ts)); | ||||||
|     ble_log_spi_out_write(BLE_LOG_SPI_OUT_SOURCE_SYNC, sync_frame, 9); |     ble_log_spi_out_write(BLE_LOG_SPI_OUT_SOURCE_SYNC, sync_frame, 9); | ||||||
|  |  | ||||||
|     // Update IO level |  | ||||||
|     sync_io_level = !sync_io_level; |  | ||||||
| } | } | ||||||
| #endif // CONFIG_BT_BLE_LOG_SPI_OUT_TS_SYNC_ENABLED | #endif // CONFIG_BT_BLE_LOG_SPI_OUT_TS_SYNC_ENABLED | ||||||
|  |  | ||||||
| @@ -351,6 +353,10 @@ void ble_log_spi_out_ts_sync_stop(void) | |||||||
|         if (esp_timer_is_active(ts_sync_timer_handle)) { |         if (esp_timer_is_active(ts_sync_timer_handle)) { | ||||||
|             esp_timer_stop(ts_sync_timer_handle); |             esp_timer_stop(ts_sync_timer_handle); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         // Set sync IO to low level | ||||||
|  |         sync_io_level = 0; | ||||||
|  |         gpio_set_level(CONFIG_BT_BLE_LOG_SPI_OUT_SYNC_IO_NUM, (uint32_t)sync_io_level); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| #endif // CONFIG_BT_BLE_LOG_SPI_OUT_TS_SYNC_ENABLED | #endif // CONFIG_BT_BLE_LOG_SPI_OUT_TS_SYNC_ENABLED | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ | |||||||
| #ifndef __BT_SPI_OUT_H__ | #ifndef __BT_SPI_OUT_H__ | ||||||
| #define __BT_SPI_OUT_H__ | #define __BT_SPI_OUT_H__ | ||||||
|  |  | ||||||
|  | #include <stdarg.h> | ||||||
| #include <string.h> | #include <string.h> | ||||||
| #include "driver/spi_master.h" | #include "driver/spi_master.h" | ||||||
| #include "driver/gpio.h" | #include "driver/gpio.h" | ||||||
| @@ -19,6 +20,7 @@ | |||||||
| #define BLE_LOG_SPI_OUT_SOURCE_NIMBLE 3 | #define BLE_LOG_SPI_OUT_SOURCE_NIMBLE 3 | ||||||
| #define BLE_LOG_SPI_OUT_SOURCE_HCI_UPSTREAM 4 | #define BLE_LOG_SPI_OUT_SOURCE_HCI_UPSTREAM 4 | ||||||
| #define BLE_LOG_SPI_OUT_SOURCE_HCI_DOWNSTREAM 5 | #define BLE_LOG_SPI_OUT_SOURCE_HCI_DOWNSTREAM 5 | ||||||
|  | #define BLE_LOG_SPI_OUT_SOURCE_USER 0x10 | ||||||
| #define BLE_LOG_SPI_OUT_SOURCE_SYNC 0xFE | #define BLE_LOG_SPI_OUT_SOURCE_SYNC 0xFE | ||||||
| #define BLE_LOG_SPI_OUT_SOURCE_LOSS 0xFF | #define BLE_LOG_SPI_OUT_SOURCE_LOSS 0xFF | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Zhou Xiao
					Zhou Xiao