debug apps: made runnable as .faps; sdk: resolved additional APIs in use by faps (#2333)
* sdk: resolve additional APIs in use by faps * debug tools: fixed battery_test, bt_debug, display_test, rpc_debug Co-authored-by: hedger <hedger@nanode.su> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
		
							parent
							
								
									126a9efd09
								
							
						
					
					
						commit
						24a23e5dc7
					
				| @ -11,4 +11,5 @@ App( | ||||
|     stack_size=1 * 1024, | ||||
|     order=130, | ||||
|     fap_category="Debug", | ||||
|     fap_libs=["assets"], | ||||
| ) | ||||
|  | ||||
							
								
								
									
										148
									
								
								applications/debug/battery_test_app/views/battery_info.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										148
									
								
								applications/debug/battery_test_app/views/battery_info.c
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,148 @@ | ||||
| #include "battery_info.h" | ||||
| #include <furi.h> | ||||
| #include <gui/elements.h> | ||||
| #include <assets_icons.h> | ||||
| 
 | ||||
| #define LOW_CHARGE_THRESHOLD 10 | ||||
| #define HIGH_DRAIN_CURRENT_THRESHOLD 100 | ||||
| 
 | ||||
| struct BatteryInfo { | ||||
|     View* view; | ||||
| }; | ||||
| 
 | ||||
| static void draw_stat(Canvas* canvas, int x, int y, const Icon* icon, char* val) { | ||||
|     canvas_draw_frame(canvas, x - 7, y + 7, 30, 13); | ||||
|     canvas_draw_icon(canvas, x, y, icon); | ||||
|     canvas_set_color(canvas, ColorWhite); | ||||
|     canvas_draw_box(canvas, x - 4, y + 16, 24, 6); | ||||
|     canvas_set_color(canvas, ColorBlack); | ||||
|     canvas_draw_str_aligned(canvas, x + 8, y + 22, AlignCenter, AlignBottom, val); | ||||
| }; | ||||
| 
 | ||||
| static void draw_battery(Canvas* canvas, BatteryInfoModel* data, int x, int y) { | ||||
|     char emote[20] = {}; | ||||
|     char header[20] = {}; | ||||
|     char value[20] = {}; | ||||
| 
 | ||||
|     int32_t drain_current = data->gauge_current * (-1000); | ||||
|     uint32_t charge_current = data->gauge_current * 1000; | ||||
| 
 | ||||
|     // Draw battery
 | ||||
|     canvas_draw_icon(canvas, x, y, &I_BatteryBody_52x28); | ||||
|     if(charge_current > 0) { | ||||
|         canvas_draw_icon(canvas, x + 16, y + 7, &I_FaceCharging_29x14); | ||||
|     } else if(drain_current > HIGH_DRAIN_CURRENT_THRESHOLD) { | ||||
|         canvas_draw_icon(canvas, x + 16, y + 7, &I_FaceConfused_29x14); | ||||
|     } else if(data->charge < LOW_CHARGE_THRESHOLD) { | ||||
|         canvas_draw_icon(canvas, x + 16, y + 7, &I_FaceNopower_29x14); | ||||
|     } else { | ||||
|         canvas_draw_icon(canvas, x + 16, y + 7, &I_FaceNormal_29x14); | ||||
|     } | ||||
| 
 | ||||
|     // Draw bubble
 | ||||
|     elements_bubble(canvas, 53, 0, 71, 39); | ||||
| 
 | ||||
|     // Set text
 | ||||
|     if(charge_current > 0) { | ||||
|         snprintf(emote, sizeof(emote), "%s", "Yummy!"); | ||||
|         snprintf(header, sizeof(header), "%s", "Charging at"); | ||||
|         snprintf( | ||||
|             value, | ||||
|             sizeof(value), | ||||
|             "%lu.%luV   %lumA", | ||||
|             (uint32_t)(data->vbus_voltage), | ||||
|             (uint32_t)(data->vbus_voltage * 10) % 10, | ||||
|             charge_current); | ||||
|     } else if(drain_current > 0) { | ||||
|         snprintf( | ||||
|             emote, | ||||
|             sizeof(emote), | ||||
|             "%s", | ||||
|             drain_current > HIGH_DRAIN_CURRENT_THRESHOLD ? "Oh no!" : "Om-nom-nom!"); | ||||
|         snprintf(header, sizeof(header), "%s", "Consumption is"); | ||||
|         snprintf( | ||||
|             value, | ||||
|             sizeof(value), | ||||
|             "%ld %s", | ||||
|             drain_current, | ||||
|             drain_current > HIGH_DRAIN_CURRENT_THRESHOLD ? "mA!" : "mA"); | ||||
|     } else if(drain_current != 0) { | ||||
|         snprintf(header, 20, "..."); | ||||
|     } else if(data->charging_voltage < 4.2) { | ||||
|         // Non-default battery charging limit, mention it
 | ||||
|         snprintf(emote, sizeof(emote), "Charged!"); | ||||
|         snprintf(header, sizeof(header), "Limited to"); | ||||
|         snprintf( | ||||
|             value, | ||||
|             sizeof(value), | ||||
|             "%lu.%luV", | ||||
|             (uint32_t)(data->charging_voltage), | ||||
|             (uint32_t)(data->charging_voltage * 10) % 10); | ||||
|     } else { | ||||
|         snprintf(header, sizeof(header), "Charged!"); | ||||
|     } | ||||
| 
 | ||||
|     canvas_draw_str_aligned(canvas, 92, y + 3, AlignCenter, AlignCenter, emote); | ||||
|     canvas_draw_str_aligned(canvas, 92, y + 15, AlignCenter, AlignCenter, header); | ||||
|     canvas_draw_str_aligned(canvas, 92, y + 27, AlignCenter, AlignCenter, value); | ||||
| }; | ||||
| 
 | ||||
| static void battery_info_draw_callback(Canvas* canvas, void* context) { | ||||
|     furi_assert(context); | ||||
|     BatteryInfoModel* model = context; | ||||
| 
 | ||||
|     canvas_clear(canvas); | ||||
|     canvas_set_color(canvas, ColorBlack); | ||||
|     draw_battery(canvas, model, 0, 5); | ||||
| 
 | ||||
|     char batt_level[10]; | ||||
|     char temperature[10]; | ||||
|     char voltage[10]; | ||||
|     char health[10]; | ||||
| 
 | ||||
|     snprintf(batt_level, sizeof(batt_level), "%lu%%", (uint32_t)model->charge); | ||||
|     snprintf(temperature, sizeof(temperature), "%lu C", (uint32_t)model->gauge_temperature); | ||||
|     snprintf( | ||||
|         voltage, | ||||
|         sizeof(voltage), | ||||
|         "%lu.%01lu V", | ||||
|         (uint32_t)model->gauge_voltage, | ||||
|         (uint32_t)(model->gauge_voltage * 10) % 10UL); | ||||
|     snprintf(health, sizeof(health), "%d%%", model->health); | ||||
| 
 | ||||
|     draw_stat(canvas, 8, 42, &I_Battery_16x16, batt_level); | ||||
|     draw_stat(canvas, 40, 42, &I_Temperature_16x16, temperature); | ||||
|     draw_stat(canvas, 72, 42, &I_Voltage_16x16, voltage); | ||||
|     draw_stat(canvas, 104, 42, &I_Health_16x16, health); | ||||
| } | ||||
| 
 | ||||
| BatteryInfo* battery_info_alloc() { | ||||
|     BatteryInfo* battery_info = malloc(sizeof(BatteryInfo)); | ||||
|     battery_info->view = view_alloc(); | ||||
|     view_set_context(battery_info->view, battery_info); | ||||
|     view_allocate_model(battery_info->view, ViewModelTypeLocking, sizeof(BatteryInfoModel)); | ||||
|     view_set_draw_callback(battery_info->view, battery_info_draw_callback); | ||||
| 
 | ||||
|     return battery_info; | ||||
| } | ||||
| 
 | ||||
| void battery_info_free(BatteryInfo* battery_info) { | ||||
|     furi_assert(battery_info); | ||||
|     view_free(battery_info->view); | ||||
|     free(battery_info); | ||||
| } | ||||
| 
 | ||||
| View* battery_info_get_view(BatteryInfo* battery_info) { | ||||
|     furi_assert(battery_info); | ||||
|     return battery_info->view; | ||||
| } | ||||
| 
 | ||||
| void battery_info_set_data(BatteryInfo* battery_info, BatteryInfoModel* data) { | ||||
|     furi_assert(battery_info); | ||||
|     furi_assert(data); | ||||
|     with_view_model( | ||||
|         battery_info->view, | ||||
|         BatteryInfoModel * model, | ||||
|         { memcpy(model, data, sizeof(BatteryInfoModel)); }, | ||||
|         true); | ||||
| } | ||||
							
								
								
									
										23
									
								
								applications/debug/battery_test_app/views/battery_info.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								applications/debug/battery_test_app/views/battery_info.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | ||||
| #pragma once | ||||
| 
 | ||||
| #include <gui/view.h> | ||||
| 
 | ||||
| typedef struct BatteryInfo BatteryInfo; | ||||
| 
 | ||||
| typedef struct { | ||||
|     float vbus_voltage; | ||||
|     float gauge_voltage; | ||||
|     float gauge_current; | ||||
|     float gauge_temperature; | ||||
|     float charging_voltage; | ||||
|     uint8_t charge; | ||||
|     uint8_t health; | ||||
| } BatteryInfoModel; | ||||
| 
 | ||||
| BatteryInfo* battery_info_alloc(); | ||||
| 
 | ||||
| void battery_info_free(BatteryInfo* battery_info); | ||||
| 
 | ||||
| View* battery_info_get_view(BatteryInfo* battery_info); | ||||
| 
 | ||||
| void battery_info_set_data(BatteryInfo* battery_info, BatteryInfoModel* data); | ||||
| @ -31,9 +31,6 @@ uint32_t bt_debug_start_view(void* context) { | ||||
| BtDebugApp* bt_debug_app_alloc() { | ||||
|     BtDebugApp* app = malloc(sizeof(BtDebugApp)); | ||||
| 
 | ||||
|     // Load settings
 | ||||
|     bt_settings_load(&app->settings); | ||||
| 
 | ||||
|     // Gui
 | ||||
|     app->gui = furi_record_open(RECORD_GUI); | ||||
| 
 | ||||
| @ -105,13 +102,15 @@ int32_t bt_debug_app(void* p) { | ||||
|     } | ||||
| 
 | ||||
|     BtDebugApp* app = bt_debug_app_alloc(); | ||||
|     // Was bt active?
 | ||||
|     const bool was_active = furi_hal_bt_is_active(); | ||||
|     // Stop advertising
 | ||||
|     furi_hal_bt_stop_advertising(); | ||||
| 
 | ||||
|     view_dispatcher_run(app->view_dispatcher); | ||||
| 
 | ||||
|     // Restart advertising
 | ||||
|     if(app->settings.enabled) { | ||||
|     if(was_active) { | ||||
|         furi_hal_bt_start_advertising(); | ||||
|     } | ||||
|     bt_debug_app_free(app); | ||||
|  | ||||
| @ -4,15 +4,14 @@ | ||||
| #include <gui/gui.h> | ||||
| #include <gui/view.h> | ||||
| #include <gui/view_dispatcher.h> | ||||
| #include <gui/modules/submenu.h> | ||||
| 
 | ||||
| #include <dialogs/dialogs.h> | ||||
| 
 | ||||
| #include <gui/modules/submenu.h> | ||||
| #include "views/bt_carrier_test.h" | ||||
| #include "views/bt_packet_test.h" | ||||
| #include <bt/bt_settings.h> | ||||
| 
 | ||||
| typedef struct { | ||||
|     BtSettings settings; | ||||
|     Gui* gui; | ||||
|     ViewDispatcher* view_dispatcher; | ||||
|     Submenu* submenu; | ||||
|  | ||||
| @ -5,6 +5,7 @@ App( | ||||
|     entry_point="display_test_app", | ||||
|     cdefines=["APP_DISPLAY_TEST"], | ||||
|     requires=["gui"], | ||||
|     fap_libs=["misc"], | ||||
|     stack_size=1 * 1024, | ||||
|     order=120, | ||||
|     fap_category="Debug", | ||||
|  | ||||
| @ -91,7 +91,6 @@ static void display_test_reload_config(DisplayTest* instance) { | ||||
|         instance->config_contrast, | ||||
|         instance->config_regulation_ratio, | ||||
|         instance->config_bias); | ||||
|     gui_update(instance->gui); | ||||
| } | ||||
| 
 | ||||
| static void display_config_set_bias(VariableItem* item) { | ||||
|  | ||||
| @ -44,7 +44,11 @@ bool rpc_debug_app_scene_input_error_code_on_event(void* context, SceneManagerEv | ||||
| 
 | ||||
|     if(event.type == SceneManagerEventTypeCustom) { | ||||
|         if(event.event == RpcDebugAppCustomEventInputErrorCode) { | ||||
|             rpc_system_app_set_error_code(app->rpc, (uint32_t)atol(app->text_store)); | ||||
|             char* end; | ||||
|             int error_code = strtol(app->text_store, &end, 10); | ||||
|             if(!*end) { | ||||
|                 rpc_system_app_set_error_code(app->rpc, error_code); | ||||
|             } | ||||
|             scene_manager_previous_scene(app->scene_manager); | ||||
|             consumed = true; | ||||
|         } | ||||
|  | ||||
| @ -5,6 +5,10 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdbool.h> | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
| 
 | ||||
| typedef struct { | ||||
|     bool enabled; | ||||
| } BtSettings; | ||||
| @ -12,3 +16,7 @@ typedef struct { | ||||
| bool bt_settings_load(BtSettings* bt_settings); | ||||
| 
 | ||||
| bool bt_settings_save(BtSettings* bt_settings); | ||||
| 
 | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
| @ -1,5 +1,5 @@ | ||||
| entry,status,name,type,params | ||||
| Version,+,11.7,, | ||||
| Version,+,11.8,, | ||||
| Header,+,applications/services/bt/bt_service/bt.h,, | ||||
| Header,+,applications/services/cli/cli.h,, | ||||
| Header,+,applications/services/cli/cli_vcp.h,, | ||||
| @ -188,6 +188,7 @@ Header,+,lib/toolbox/stream/file_stream.h,, | ||||
| Header,+,lib/toolbox/stream/stream.h,, | ||||
| Header,+,lib/toolbox/stream/string_stream.h,, | ||||
| Header,+,lib/toolbox/tar/tar_archive.h,, | ||||
| Header,+,lib/toolbox/value_index.h,, | ||||
| Header,+,lib/toolbox/version.h,, | ||||
| Function,-,LL_ADC_CommonDeInit,ErrorStatus,ADC_Common_TypeDef* | ||||
| Function,-,LL_ADC_CommonInit,ErrorStatus,"ADC_Common_TypeDef*, LL_ADC_CommonInitTypeDef*" | ||||
| @ -2066,7 +2067,7 @@ Function,-,posix_memalign,int,"void**, size_t, size_t" | ||||
| Function,-,pow,double,"double, double" | ||||
| Function,-,pow10,double,double | ||||
| Function,-,pow10f,float,float | ||||
| Function,-,power_enable_low_battery_level_notification,void,"Power*, _Bool" | ||||
| Function,+,power_enable_low_battery_level_notification,void,"Power*, _Bool" | ||||
| Function,+,power_get_info,void,"Power*, PowerInfo*" | ||||
| Function,+,power_get_pubsub,FuriPubSub*,Power* | ||||
| Function,+,power_is_battery_healthy,_Bool,Power* | ||||
| @ -2804,6 +2805,9 @@ Function,-,vTimerSetTimerNumber,void,"TimerHandle_t, UBaseType_t" | ||||
| Function,+,validator_is_file_alloc_init,ValidatorIsFile*,"const char*, const char*, const char*" | ||||
| Function,+,validator_is_file_callback,_Bool,"const char*, FuriString*, void*" | ||||
| Function,+,validator_is_file_free,void,ValidatorIsFile* | ||||
| Function,+,value_index_bool,uint8_t,"const _Bool, const _Bool[], uint8_t" | ||||
| Function,+,value_index_float,uint8_t,"const float, const float[], uint8_t" | ||||
| Function,+,value_index_uint32,uint8_t,"const uint32_t, const uint32_t[], uint8_t" | ||||
| Function,+,variable_item_get_context,void*,VariableItem* | ||||
| Function,+,variable_item_get_current_value_index,uint8_t,VariableItem* | ||||
| Function,+,variable_item_list_add,VariableItem*,"VariableItemList*, const char*, uint8_t, VariableItemChangeCallback, void*" | ||||
|  | ||||
| 
 | 
| @ -20,6 +20,7 @@ env.Append( | ||||
|         File("saved_struct.h"), | ||||
|         File("version.h"), | ||||
|         File("float_tools.h"), | ||||
|         File("value_index.h"), | ||||
|         File("tar/tar_archive.h"), | ||||
|         File("stream/stream.h"), | ||||
|         File("stream/file_stream.h"), | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Emily Trau
						Emily Trau