Cli: fix memleak, add more commands. (#244)
* Cli: add statndard applications, fix memory leak, add reset and reset to dfu. * Lib: pass proper data pointer to osMessageQueueGet * App-loader: optional cli * Format sources
This commit is contained in:
		
							parent
							
								
									459b61720c
								
							
						
					
					
						commit
						d57b7fd448
					
				| @ -1,4 +1,5 @@ | |||||||
| #include "flipper_v2.h" | #include "flipper_v2.h" | ||||||
|  | #include <cli/cli.h> | ||||||
| #include <gui/gui.h> | #include <gui/gui.h> | ||||||
| #include "menu/menu.h" | #include "menu/menu.h" | ||||||
| #include "menu/menu_item.h" | #include "menu/menu_item.h" | ||||||
| @ -52,6 +53,21 @@ static void handle_menu(void* _ctx) { | |||||||
|     ctx->state->handler = furiac_start(ctx->app->app, ctx->app->name, NULL); |     ctx->state->handler = furiac_start(ctx->app->app, ctx->app->name, NULL); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | static void handle_cli(string_t args, void* _ctx) { | ||||||
|  |     AppLoaderContext* ctx = (AppLoaderContext*)_ctx; | ||||||
|  | 
 | ||||||
|  |     cli_print("Starting furi application\r\n"); | ||||||
|  | 
 | ||||||
|  |     ctx->state->current_app = ctx->app; | ||||||
|  |     ctx->state->handler = furiac_start(ctx->app->app, ctx->app->name, NULL); | ||||||
|  | 
 | ||||||
|  |     cli_print("Press any key to kill application"); | ||||||
|  | 
 | ||||||
|  |     char c; | ||||||
|  |     cli_read(&c, 1); | ||||||
|  |     furiac_kill(ctx->state->handler); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void app_loader(void* p) { | void app_loader(void* p) { | ||||||
|     osThreadId_t self_id = osThreadGetId(); |     osThreadId_t self_id = osThreadGetId(); | ||||||
|     furi_check(self_id); |     furi_check(self_id); | ||||||
| @ -72,6 +88,8 @@ void app_loader(void* p) { | |||||||
|         furiac_exit(NULL); |         furiac_exit(NULL); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     Cli* cli = furi_open("cli"); | ||||||
|  | 
 | ||||||
|     // Open GUI and register widget
 |     // Open GUI and register widget
 | ||||||
|     GuiApi* gui = furi_open("gui"); |     GuiApi* gui = furi_open("gui"); | ||||||
|     if(gui == NULL) { |     if(gui == NULL) { | ||||||
| @ -93,20 +111,16 @@ void app_loader(void* p) { | |||||||
|                 state.menu_plugins, |                 state.menu_plugins, | ||||||
|                 menu_item_alloc_function( |                 menu_item_alloc_function( | ||||||
|                     FLIPPER_APPS[i].name, assets_icons_get(A_Infrared_14), handle_menu, ctx)); |                     FLIPPER_APPS[i].name, assets_icons_get(A_Infrared_14), handle_menu, ctx)); | ||||||
|         } |  | ||||||
| 
 | 
 | ||||||
|         /*
 |             // Add cli command
 | ||||||
|         menu_item_add(menu, menu_item_alloc_function("Sub 1 gHz", NULL, NULL, NULL)); |             if(cli) { | ||||||
|         menu_item_add(menu, menu_item_alloc_function("125 kHz RFID", NULL, NULL, NULL)); |                 string_t cli_name; | ||||||
|         menu_item_add(menu, menu_item_alloc_function("Infrared", NULL, NULL, NULL)); |                 string_init_set_str(cli_name, "app_"); | ||||||
|         menu_item_add(menu, menu_item_alloc_function("I-Button", NULL, NULL, NULL)); |                 string_cat_str(cli_name, FLIPPER_APPS[i].name); | ||||||
|         menu_item_add(menu, menu_item_alloc_function("USB", NULL, NULL, NULL)); |                 cli_add_command(cli, string_get_cstr(cli_name), handle_cli, ctx); | ||||||
|         menu_item_add(menu, menu_item_alloc_function("Bluetooth", NULL, NULL, NULL)); |                 string_clear(cli_name); | ||||||
|         menu_item_add(menu, menu_item_alloc_function("GPIO / HW", NULL, NULL, NULL)); |             } | ||||||
|         menu_item_add(menu, menu_item_alloc_function("U2F", NULL, NULL, NULL)); |         } | ||||||
|         menu_item_add(menu, menu_item_alloc_function("Tamagotchi", NULL, NULL, NULL)); |  | ||||||
|         menu_item_add(menu, menu_item_alloc_function("Plugins", NULL, NULL, NULL)); |  | ||||||
|         */ |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     with_value_mutex( |     with_value_mutex( | ||||||
|  | |||||||
| @ -67,7 +67,7 @@ const FlipperStartupApp FLIPPER_STARTUP[] = { | |||||||
| 
 | 
 | ||||||
| #ifdef APP_MENU | #ifdef APP_MENU | ||||||
|     {.app = menu_task, .name = "menu_task", .libs = {1, FURI_LIB{"gui_task"}}}, |     {.app = menu_task, .name = "menu_task", .libs = {1, FURI_LIB{"gui_task"}}}, | ||||||
|     {.app = app_loader, .name = "app_loader", .libs = {1, FURI_LIB{"menu_task"}}}, |     {.app = app_loader, .name = "app_loader", .libs = {2, FURI_LIB{"menu_task", "cli_task"}}}, | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #ifdef APP_IRUKAGOTCHI | #ifdef APP_IRUKAGOTCHI | ||||||
|  | |||||||
| @ -20,6 +20,7 @@ void cli_free(Cli* cli) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void cli_reset_state(Cli* cli) { | void cli_reset_state(Cli* cli) { | ||||||
|  |     // Release allocated buffer, reset state
 | ||||||
|     string_clear(cli->line); |     string_clear(cli->line); | ||||||
|     string_init(cli->line); |     string_init(cli->line); | ||||||
| } | } | ||||||
| @ -28,6 +29,10 @@ void cli_putc(char c) { | |||||||
|     api_hal_vcp_tx((uint8_t*)&c, 1); |     api_hal_vcp_tx((uint8_t*)&c, 1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void cli_read(char* buffer, size_t size) { | ||||||
|  |     api_hal_vcp_rx((uint8_t*)buffer, size); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void cli_print(const char* str) { | void cli_print(const char* str) { | ||||||
|     api_hal_vcp_tx((uint8_t*)str, strlen(str)); |     api_hal_vcp_tx((uint8_t*)str, strlen(str)); | ||||||
| } | } | ||||||
| @ -103,6 +108,7 @@ void cli_enter(Cli* cli) { | |||||||
|         cli_putc(CliSymbolAsciiBell); |         cli_putc(CliSymbolAsciiBell); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     string_clear(command); | ||||||
|     // Always finish with clean state
 |     // Always finish with clean state
 | ||||||
|     cli_reset_state(cli); |     cli_reset_state(cli); | ||||||
| } | } | ||||||
| @ -145,6 +151,13 @@ void cli_process_input(Cli* cli) { | |||||||
| void cli_add_command(Cli* cli, const char* name, CliCallback callback, void* context) { | void cli_add_command(Cli* cli, const char* name, CliCallback callback, void* context) { | ||||||
|     string_t name_str; |     string_t name_str; | ||||||
|     string_init_set_str(name_str, name); |     string_init_set_str(name_str, name); | ||||||
|  |     string_strim(name_str); | ||||||
|  | 
 | ||||||
|  |     size_t name_replace; | ||||||
|  |     do { | ||||||
|  |         name_replace = string_replace_str(name_str, " ", "_"); | ||||||
|  |     } while(name_replace != STRING_FAILURE); | ||||||
|  | 
 | ||||||
|     CliCommand c; |     CliCommand c; | ||||||
|     c.callback = callback; |     c.callback = callback; | ||||||
|     c.context = context; |     c.context = context; | ||||||
| @ -152,6 +165,8 @@ void cli_add_command(Cli* cli, const char* name, CliCallback callback, void* con | |||||||
|     furi_check(osMutexAcquire(cli->mutex, osWaitForever) == osOK); |     furi_check(osMutexAcquire(cli->mutex, osWaitForever) == osOK); | ||||||
|     CliCommandDict_set_at(cli->commands, name_str, c); |     CliCommandDict_set_at(cli->commands, name_str, c); | ||||||
|     furi_check(osMutexRelease(cli->mutex) == osOK); |     furi_check(osMutexRelease(cli->mutex) == osOK); | ||||||
|  | 
 | ||||||
|  |     string_clear(name_str); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void cli_task(void* p) { | void cli_task(void* p) { | ||||||
|  | |||||||
| @ -87,17 +87,32 @@ void power_free(Power* power) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void power_cli_poweroff(string_t args, void* context) { | void power_cli_poweroff(string_t args, void* context) { | ||||||
|     cli_print("Poweroff in 5 seconds"); |     cli_print("Poweroff in 3 seconds"); | ||||||
|     osDelay(5000); |     osDelay(3000); | ||||||
|     api_hal_power_off(); |     api_hal_power_off(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void power_cli_reset(string_t args, void* context) { | ||||||
|  |     cli_print("NVIC System Reset in 3 seconds"); | ||||||
|  |     osDelay(3000); | ||||||
|  |     NVIC_SystemReset(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void power_cli_dfu(string_t args, void* context) { | ||||||
|  |     cli_print("NVIC System Reset to DFU mode in 3 seconds"); | ||||||
|  |     api_hal_boot_set_mode(ApiHalBootModeDFU); | ||||||
|  |     osDelay(3000); | ||||||
|  |     NVIC_SystemReset(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void power_task(void* p) { | void power_task(void* p) { | ||||||
|     (void)p; |     (void)p; | ||||||
|     Power* power = power_alloc(); |     Power* power = power_alloc(); | ||||||
| 
 | 
 | ||||||
|     if(power->cli) { |     if(power->cli) { | ||||||
|         cli_add_command(power->cli, "poweroff", power_cli_poweroff, power); |         cli_add_command(power->cli, "poweroff", power_cli_poweroff, power); | ||||||
|  |         cli_add_command(power->cli, "reset", power_cli_reset, power); | ||||||
|  |         cli_add_command(power->cli, "dfu", power_cli_dfu, power); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); |     FuriRecordSubscriber* gui_record = furi_open_deprecated("gui", false, false, NULL, NULL, NULL); | ||||||
|  | |||||||
							
								
								
									
										15
									
								
								core/boot.h
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								core/boot.h
									
									
									
									
									
								
							| @ -1,15 +0,0 @@ | |||||||
| /*
 |  | ||||||
| Flipper devices inc. |  | ||||||
| 
 |  | ||||||
| Bootloader API, must be implemented by target |  | ||||||
| */ |  | ||||||
| 
 |  | ||||||
| #ifndef __BOOT_H |  | ||||||
| #define __BOOT_H |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * @brief Request DFU and reboot |  | ||||||
| */ |  | ||||||
| void boot_restart_in_dfu(); |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
							
								
								
									
										8
									
								
								firmware/targets/Inc/api-hal-boot.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								firmware/targets/Inc/api-hal-boot.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,8 @@ | |||||||
|  | #pragma once | ||||||
|  | 
 | ||||||
|  | typedef enum { | ||||||
|  |     ApiHalBootModeNormal, | ||||||
|  |     ApiHalBootModeDFU | ||||||
|  | } ApiHalBootMode; | ||||||
|  | 
 | ||||||
|  | void api_hal_boot_set_mode(ApiHalBootMode mode); | ||||||
| @ -1,5 +1,6 @@ | |||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
|  | #include "api-hal-boot.h" | ||||||
| #include "api-hal-gpio.h" | #include "api-hal-gpio.h" | ||||||
| #include "api-hal-delay.h" | #include "api-hal-delay.h" | ||||||
| #include "api-hal-pwm.h" | #include "api-hal-pwm.h" | ||||||
|  | |||||||
							
								
								
									
										13
									
								
								firmware/targets/f2/api-hal/api-hal-boot.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								firmware/targets/f2/api-hal/api-hal-boot.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | #include <api-hal-boot.h> | ||||||
|  | #include <stm32l4xx_ll_rtc.h> | ||||||
|  | 
 | ||||||
|  | #define BOOT_REQUEST_NONE 0x00000000 | ||||||
|  | #define BOOT_REQUEST_DFU 0xDF00B000 | ||||||
|  | 
 | ||||||
|  | void api_hal_boot_set_mode(ApiHalBootMode mode) { | ||||||
|  |     if (mode == ApiHalBootModeNormal) { | ||||||
|  |         LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_NONE); | ||||||
|  |     } else if (mode == ApiHalBootModeDFU) { | ||||||
|  |         LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_DFU); | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										13
									
								
								firmware/targets/f3/api-hal/api-hal-boot.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								firmware/targets/f3/api-hal/api-hal-boot.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | #include <api-hal-boot.h> | ||||||
|  | #include <stm32wbxx_ll_rtc.h> | ||||||
|  | 
 | ||||||
|  | #define BOOT_REQUEST_NONE 0x00000000 | ||||||
|  | #define BOOT_REQUEST_DFU 0xDF00B000 | ||||||
|  | 
 | ||||||
|  | void api_hal_boot_set_mode(ApiHalBootMode mode) { | ||||||
|  |     if (mode == ApiHalBootModeNormal) { | ||||||
|  |         LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_NONE); | ||||||
|  |     } else if (mode == ApiHalBootModeDFU) { | ||||||
|  |         LL_RTC_BAK_SetRegister(RTC, LL_RTC_BKP_DR0, BOOT_REQUEST_DFU); | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -91,7 +91,7 @@ template <class TState, class TEvent> void AppTemplate<TState, TEvent>::release_ | |||||||
| 
 | 
 | ||||||
| template <class TState, class TEvent> | template <class TState, class TEvent> | ||||||
| bool AppTemplate<TState, TEvent>::get_event(TEvent* event, uint32_t timeout) { | bool AppTemplate<TState, TEvent>::get_event(TEvent* event, uint32_t timeout) { | ||||||
|     osStatus_t event_status = osMessageQueueGet(event_queue, &event, NULL, timeout); |     osStatus_t event_status = osMessageQueueGet(event_queue, event, NULL, timeout); | ||||||
| 
 | 
 | ||||||
|     return (event_status == osOK); |     return (event_status == osOK); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 あく
						あく