* SubGhz: Fix recording RAW files, sometimes could not start at a high level * SubGhz: subghz_worker, add short duration filter setting * SubGhz: capture raw timings in cli. Furi: clear pending interrupts on ISR set/reset * SubGhz: fix start duration in furi_hal_subghz_start_async_rx * [FL-3093] SubGhz: hopping issue in some regions * [FL-3087] SubGhz: fix delete-ok issue * SubGhz: remove copypasta from rx_raw cli command Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
		
			
				
	
	
		
			81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#pragma once
 | 
						|
 | 
						|
#include <furi_hal.h>
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
typedef struct SubGhzWorker SubGhzWorker;
 | 
						|
 | 
						|
typedef void (*SubGhzWorkerOverrunCallback)(void* context);
 | 
						|
 | 
						|
typedef void (*SubGhzWorkerPairCallback)(void* context, bool level, uint32_t duration);
 | 
						|
 | 
						|
void subghz_worker_rx_callback(bool level, uint32_t duration, void* context);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Allocate SubGhzWorker.
 | 
						|
 * @return SubGhzWorker* Pointer to a SubGhzWorker instance
 | 
						|
 */
 | 
						|
SubGhzWorker* subghz_worker_alloc();
 | 
						|
 | 
						|
/** 
 | 
						|
 * Free SubGhzWorker.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 */
 | 
						|
void subghz_worker_free(SubGhzWorker* instance);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Overrun callback SubGhzWorker.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 * @param callback SubGhzWorkerOverrunCallback callback
 | 
						|
 */
 | 
						|
void subghz_worker_set_overrun_callback(
 | 
						|
    SubGhzWorker* instance,
 | 
						|
    SubGhzWorkerOverrunCallback callback);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Pair callback SubGhzWorker.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 * @param callback SubGhzWorkerOverrunCallback callback
 | 
						|
 */
 | 
						|
void subghz_worker_set_pair_callback(SubGhzWorker* instance, SubGhzWorkerPairCallback callback);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Context callback SubGhzWorker.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 * @param context 
 | 
						|
 */
 | 
						|
void subghz_worker_set_context(SubGhzWorker* instance, void* context);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Start SubGhzWorker.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 */
 | 
						|
void subghz_worker_start(SubGhzWorker* instance);
 | 
						|
 | 
						|
/** Stop SubGhzWorker
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 */
 | 
						|
void subghz_worker_stop(SubGhzWorker* instance);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Check if worker is running.
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 * @return bool - true if running
 | 
						|
 */
 | 
						|
bool subghz_worker_is_running(SubGhzWorker* instance);
 | 
						|
 | 
						|
/** 
 | 
						|
 * Short duration filter setting.
 | 
						|
 * glues short durations into 1. The default setting is 30 us, if set to 0 the filter will be disabled
 | 
						|
 * @param instance Pointer to a SubGhzWorker instance
 | 
						|
 * @param timeout time in us
 | 
						|
 */
 | 
						|
void subghz_worker_set_filter(SubGhzWorker* instance, uint16_t timeout);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 |