 224d0aefe4
			
		
	
	
		224d0aefe4
		
			
		
	
	
	
	
		
			
			* First part of multitarget porting * Delete firmware/targets/f7/Inc directory * Delete firmware/targets/f7/Src directory * gpio: cli fixes; about: using version from HAL * sdk: path fixes * gui: include fixes * applications: more include fixes * gpio: ported to new apis * hal: introduced furi_hal_target_hw.h; libs: added one_wire * hal: f18 target * github: also build f18 by default * typo fix * fbt: removed extra checks on app list * api: explicitly bundling select mlib headers with sdk * hal: f18: changed INPUT_DEBOUNCE_TICKS to match f7 * cleaned up commented out code * docs: added info on hw targets * docs: targets: formatting fixes * f18: fixed link error * f18: fixed API version to match f7 * docs: hardware: minor wording fixes * faploader: added fw target check * docs: typo fixes * github: not building komi target by default * fbt: support for `targets` field for built-in apps * github: reworked build flow to exclude app_set; fbt: removed komi-specific appset; added additional target buildset check * github: fixed build; nfc: fixed pvs warnings * attempt to fix target id * f7, f18: removed certain HAL function from public API * apps: debug: enabled bt_debug_app for f18 * Targets: backport input pins configuration routine from F7 to F18 Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
		
			
				
	
	
		
			109 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <furi_hal_spi_config.h>
 | |
| #include <stdbool.h>
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /** Early initialize SPI HAL */
 | |
| void furi_hal_spi_config_init_early();
 | |
| 
 | |
| /** Early deinitialize SPI HAL */
 | |
| void furi_hal_spi_config_deinit_early();
 | |
| 
 | |
| /** Initialize SPI HAL */
 | |
| void furi_hal_spi_config_init();
 | |
| 
 | |
| /** Initialize SPI Bus
 | |
|  *
 | |
|  * @param      handle  pointer to FuriHalSpiBus instance
 | |
|  */
 | |
| void furi_hal_spi_bus_init(FuriHalSpiBus* bus);
 | |
| 
 | |
| /** Deinitialize SPI Bus
 | |
|  *
 | |
|  * @param      handle  pointer to FuriHalSpiBus instance
 | |
|  */
 | |
| void furi_hal_spi_bus_deinit(FuriHalSpiBus* bus);
 | |
| 
 | |
| /** Initialize SPI Bus Handle
 | |
|  *
 | |
|  * @param      handle  pointer to FuriHalSpiBusHandle instance
 | |
|  */
 | |
| void furi_hal_spi_bus_handle_init(FuriHalSpiBusHandle* handle);
 | |
| 
 | |
| /** Deinitialize SPI Bus Handle
 | |
|  *
 | |
|  * @param      handle  pointer to FuriHalSpiBusHandle instance
 | |
|  */
 | |
| void furi_hal_spi_bus_handle_deinit(FuriHalSpiBusHandle* handle);
 | |
| 
 | |
| /** Acquire SPI bus
 | |
|  *
 | |
|  * @warning blocking, calls `furi_crash` on programming error, CS transition is up to handler event routine
 | |
|  *
 | |
|  * @param      handle  pointer to FuriHalSpiBusHandle instance
 | |
|  */
 | |
| void furi_hal_spi_acquire(FuriHalSpiBusHandle* handle);
 | |
| 
 | |
| /** Release SPI bus
 | |
|  *
 | |
|  * @warning calls `furi_crash` on programming error, CS transition is up to handler event routine
 | |
|  * 
 | |
|  * @param      handle  pointer to FuriHalSpiBusHandle instance
 | |
|  */
 | |
| void furi_hal_spi_release(FuriHalSpiBusHandle* handle);
 | |
| 
 | |
| /** SPI Receive
 | |
|  *
 | |
|  * @param      handle   pointer to FuriHalSpiBusHandle instance
 | |
|  * @param      buffer   receive buffer
 | |
|  * @param      size     transaction size (buffer size)
 | |
|  * @param      timeout  operation timeout in ms
 | |
|  *
 | |
|  * @return     true on sucess
 | |
|  */
 | |
| bool furi_hal_spi_bus_rx(
 | |
|     FuriHalSpiBusHandle* handle,
 | |
|     uint8_t* buffer,
 | |
|     size_t size,
 | |
|     uint32_t timeout);
 | |
| 
 | |
| /** SPI Transmit
 | |
|  *
 | |
|  * @param      handle   pointer to FuriHalSpiBusHandle instance
 | |
|  * @param      buffer   transmit buffer
 | |
|  * @param      size     transaction size (buffer size)
 | |
|  * @param      timeout  operation timeout in ms
 | |
|  *
 | |
|  * @return     true on success
 | |
|  */
 | |
| bool furi_hal_spi_bus_tx(
 | |
|     FuriHalSpiBusHandle* handle,
 | |
|     uint8_t* buffer,
 | |
|     size_t size,
 | |
|     uint32_t timeout);
 | |
| 
 | |
| /** SPI Transmit and Receive
 | |
|  *
 | |
|  * @param      handle     pointer to FuriHalSpiBusHandle instance
 | |
|  * @param      tx_buffer  pointer to tx buffer
 | |
|  * @param      rx_buffer  pointer to rx buffer
 | |
|  * @param      size       transaction size (buffer size)
 | |
|  * @param      timeout    operation timeout in ms
 | |
|  *
 | |
|  * @return     true on success
 | |
|  */
 | |
| bool furi_hal_spi_bus_trx(
 | |
|     FuriHalSpiBusHandle* handle,
 | |
|     uint8_t* tx_buffer,
 | |
|     uint8_t* rx_buffer,
 | |
|     size_t size,
 | |
|     uint32_t timeout);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 |