Recator application build system: cleaner flags naming, set release flag to yes by default, include unit test and debug apps (#443)
This commit is contained in:
		
							parent
							
								
									024ced4672
								
							
						
					
					
						commit
						b90d72fadf
					
				
							
								
								
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/ci.yml
									
									
									
									
										vendored
									
									
								
							@ -52,7 +52,7 @@ jobs:
 | 
				
			|||||||
      - name: Build firmware in docker
 | 
					      - name: Build firmware in docker
 | 
				
			||||||
        uses: ./.github/actions/docker
 | 
					        uses: ./.github/actions/docker
 | 
				
			||||||
        with:
 | 
					        with:
 | 
				
			||||||
          run: make -j$(nproc) -C firmware TARGET=${TARGET_VERSION} APP_RELEASE=1
 | 
					          run: make -j$(nproc) -C firmware TARGET=${TARGET_VERSION}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: Generate dfu file for firmware
 | 
					      - name: Generate dfu file for firmware
 | 
				
			||||||
        uses: ./.github/actions/docker
 | 
					        uses: ./.github/actions/docker
 | 
				
			||||||
 | 
				
			|||||||
@ -58,7 +58,7 @@ One liner: `./flash_core1_main.sh`
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Build from source
 | 
					# Build from source
 | 
				
			||||||
 | 
					
 | 
				
			||||||
`docker-compose exec dev make -C firmware TARGET=f4 APP_RELEASE=1 flash` for build and flash dev board (see `applications/applications.mk` for list of applications/examples)
 | 
					`docker-compose exec dev make -C firmware flash` for build and flash dev board (see `applications/applications.mk` for list of applications/examples)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Links
 | 
					# Links
 | 
				
			||||||
* Task tracker: [Jira](https://flipperzero.atlassian.net/)
 | 
					* Task tracker: [Jira](https://flipperzero.atlassian.net/)
 | 
				
			||||||
 | 
				
			|||||||
@ -121,7 +121,8 @@ int32_t app_loader(void* p) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
            menu_item_add(menu, menu_plugins);
 | 
					            menu_item_add(menu, menu_plugins);
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
#ifdef APP_DEBUG
 | 
					
 | 
				
			||||||
 | 
					    // Debug
 | 
				
			||||||
    with_value_mutex(
 | 
					    with_value_mutex(
 | 
				
			||||||
        menu_mutex, (Menu * menu) {
 | 
					        menu_mutex, (Menu * menu) {
 | 
				
			||||||
            MenuItem* menu_debug =
 | 
					            MenuItem* menu_debug =
 | 
				
			||||||
@ -151,7 +152,6 @@ int32_t app_loader(void* p) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
            menu_item_add(menu, menu_debug);
 | 
					            menu_item_add(menu, menu_debug);
 | 
				
			||||||
        });
 | 
					        });
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    printf("[app loader] start\r\n");
 | 
					    printf("[app loader] start\r\n");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,9 +1,6 @@
 | 
				
			|||||||
#include "applications.h"
 | 
					#include "applications.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_TEST
 | 
					 | 
				
			||||||
int32_t flipper_test_app(void* p);
 | 
					int32_t flipper_test_app(void* p);
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int32_t application_blink(void* p);
 | 
					int32_t application_blink(void* p);
 | 
				
			||||||
int32_t application_uart_write(void* p);
 | 
					int32_t application_uart_write(void* p);
 | 
				
			||||||
int32_t application_input_dump(void* p);
 | 
					int32_t application_input_dump(void* p);
 | 
				
			||||||
@ -38,23 +35,23 @@ int32_t passport(void* p);
 | 
				
			|||||||
int32_t app_accessor(void* p);
 | 
					int32_t app_accessor(void* p);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const FlipperApplication FLIPPER_SERVICES[] = {
 | 
					const FlipperApplication FLIPPER_SERVICES[] = {
 | 
				
			||||||
#ifdef APP_CLI
 | 
					#ifdef SRV_CLI
 | 
				
			||||||
    {.app = cli_task, .name = "cli_task", .stack_size = 2048, .icon = A_Plugins_14},
 | 
					    {.app = cli_task, .name = "cli_task", .stack_size = 2048, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_EXAMPLE_BLINK
 | 
					#ifdef SRV_EXAMPLE_BLINK
 | 
				
			||||||
    {.app = application_blink, .name = "blink", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = application_blink, .name = "blink", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_INPUT
 | 
					#ifdef SRV_INPUT
 | 
				
			||||||
    {.app = input_task, .name = "input_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = input_task, .name = "input_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_EXAMPLE_INPUT_DUMP
 | 
					#ifdef SRV_EXAMPLE_INPUT_DUMP
 | 
				
			||||||
    {.app = application_input_dump, .name = "input dump", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = application_input_dump, .name = "input dump", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_GUI
 | 
					#ifdef SRV_GUI
 | 
				
			||||||
    {.app = backlight_control,
 | 
					    {.app = backlight_control,
 | 
				
			||||||
     .name = "backlight_control",
 | 
					     .name = "backlight_control",
 | 
				
			||||||
     .stack_size = 1024,
 | 
					     .stack_size = 1024,
 | 
				
			||||||
@ -63,54 +60,133 @@ const FlipperApplication FLIPPER_SERVICES[] = {
 | 
				
			|||||||
    {.app = gui_task, .name = "gui_task", .stack_size = 8192, .icon = A_Plugins_14},
 | 
					    {.app = gui_task, .name = "gui_task", .stack_size = 8192, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_MENU
 | 
					#ifdef SRV_MENU
 | 
				
			||||||
    {.app = menu_task, .name = "menu_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = menu_task, .name = "menu_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
    {.app = app_loader, .name = "app_loader", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = app_loader, .name = "app_loader", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_SD_FILESYSTEM
 | 
					#ifdef SRV_SD_FILESYSTEM
 | 
				
			||||||
    {.app = sd_filesystem, .name = "sd_filesystem", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					    {.app = sd_filesystem, .name = "sd_filesystem", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_DOLPHIN
 | 
					#ifdef SRV_DOLPHIN
 | 
				
			||||||
    {.app = dolphin_task, .name = "dolphin_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = dolphin_task, .name = "dolphin_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_POWER
 | 
					#ifdef SRV_POWER
 | 
				
			||||||
    {.app = power_task, .name = "power_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = power_task, .name = "power_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_BT
 | 
					#ifdef SRV_BT
 | 
				
			||||||
    {.app = bt_task, .name = "bt_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = bt_task, .name = "bt_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_LF_RFID
 | 
					#ifdef SRV_LF_RFID
 | 
				
			||||||
    {.app = lf_rfid_workaround,
 | 
					    {.app = lf_rfid_workaround,
 | 
				
			||||||
     .name = "lf rfid workaround",
 | 
					     .name = "lf rfid workaround",
 | 
				
			||||||
     .stack_size = 1024,
 | 
					     .stack_size = 1024,
 | 
				
			||||||
     .icon = A_Plugins_14},
 | 
					     .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_IRDA
 | 
					#ifdef SRV_IRDA
 | 
				
			||||||
    {.app = irda, .name = "irda", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = irda, .name = "irda", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_NFC
 | 
					#ifdef SRV_NFC
 | 
				
			||||||
    {.app = nfc_task, .name = "nfc_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = nfc_task, .name = "nfc_task", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_TEST
 | 
					#ifdef SRV_EXAMPLE_QRCODE
 | 
				
			||||||
    {.app = flipper_test_app, .name = "test app", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef APP_EXAMPLE_QRCODE
 | 
					 | 
				
			||||||
    {.app = u8g2_qrcode, .name = "u8g2_qrcode", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = u8g2_qrcode, .name = "u8g2_qrcode", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_EXAMPLE_DISPLAY
 | 
					#ifdef SRV_EXAMPLE_DISPLAY
 | 
				
			||||||
    {.app = u8g2_example, .name = "u8g2_example", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = u8g2_example, .name = "u8g2_example", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_SPEAKER_DEMO
 | 
				
			||||||
 | 
					    {.app = coreglitch_demo_0,
 | 
				
			||||||
 | 
					     .name = "coreglitch_demo_0",
 | 
				
			||||||
 | 
					     .stack_size = 1024,
 | 
				
			||||||
 | 
					     .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_SD_TEST
 | 
				
			||||||
 | 
					    {.app = sd_card_test, .name = "sd_card_test", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_MUSIC_PLAYER
 | 
				
			||||||
 | 
					    {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_IBUTTON
 | 
				
			||||||
 | 
					    {.app = app_ibutton, .name = "ibutton", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_GPIO_DEMO
 | 
				
			||||||
 | 
					    {.app = app_gpio_test, .name = "gpio test", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_FLOOPPER_BLOOPPER
 | 
				
			||||||
 | 
					    {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_SDNFC
 | 
				
			||||||
 | 
					    {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_GUI_TEST
 | 
				
			||||||
 | 
					    {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_KEYPAD_TEST
 | 
				
			||||||
 | 
					    {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef SRV_ACCESSOR
 | 
				
			||||||
 | 
					    {.app = app_accessor, .name = "accessor", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const size_t FLIPPER_SERVICES_COUNT = sizeof(FLIPPER_SERVICES) / sizeof(FlipperApplication);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Main menu APP
 | 
				
			||||||
 | 
					const FlipperApplication FLIPPER_APPS[] = {
 | 
				
			||||||
 | 
					#ifdef APP_SUBGHZ
 | 
				
			||||||
 | 
					    {.app = subghz_app, .name = "Sub-1 GHz", .stack_size = 1024, .icon = A_Sub1ghz_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_LF_RFID
 | 
				
			||||||
 | 
					    {.app = lf_rfid_workaround, .name = "125 kHz RFID", .stack_size = 1024, .icon = A_125khz_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_IRDA
 | 
				
			||||||
 | 
					    {.app = irda, .name = "Infrared", .stack_size = 1024, .icon = A_Infrared_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_IBUTTON
 | 
				
			||||||
 | 
					    {.app = app_ibutton, .name = "iButton", .stack_size = 4096, .icon = A_iButton_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_GPIO_DEMO
 | 
				
			||||||
 | 
					    {.app = app_gpio_test, .name = "GPIO", .stack_size = 1024, .icon = A_GPIO_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const size_t FLIPPER_APPS_COUNT = sizeof(FLIPPER_APPS) / sizeof(FlipperApplication);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Plugin menu
 | 
				
			||||||
 | 
					const FlipperApplication FLIPPER_PLUGINS[] = {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_MUSIC_PLAYER
 | 
				
			||||||
 | 
					    {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_FLOOPPER_BLOOPPER
 | 
				
			||||||
 | 
					    {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_SPEAKER_DEMO
 | 
					#ifdef APP_SPEAKER_DEMO
 | 
				
			||||||
    {.app = coreglitch_demo_0,
 | 
					    {.app = coreglitch_demo_0,
 | 
				
			||||||
     .name = "coreglitch_demo_0",
 | 
					     .name = "coreglitch_demo_0",
 | 
				
			||||||
@ -118,24 +194,26 @@ const FlipperApplication FLIPPER_SERVICES[] = {
 | 
				
			|||||||
     .icon = A_Plugins_14},
 | 
					     .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const size_t FLIPPER_PLUGINS_COUNT = sizeof(FLIPPER_PLUGINS) / sizeof(FlipperApplication);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// Plugin menu
 | 
				
			||||||
 | 
					const FlipperApplication FLIPPER_DEBUG_APPS[] = {
 | 
				
			||||||
 | 
					#ifdef APP_EXAMPLE_BLINK
 | 
				
			||||||
 | 
					    {.app = application_blink, .name = "blink", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifdef APP_EXAMPLE_INPUT_DUMP
 | 
				
			||||||
 | 
					    {.app = application_input_dump, .name = "input dump", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_SD_TEST
 | 
					#ifdef APP_SD_TEST
 | 
				
			||||||
    {.app = sd_card_test, .name = "sd_card_test", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					    {.app = sd_card_test, .name = "sd_card_test", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_MUSIC_PLAYER
 | 
					#ifdef APP_VIBRO_DEMO
 | 
				
			||||||
    {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					    {.app = application_vibro, .name = "vibro", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef APP_IBUTTON
 | 
					 | 
				
			||||||
    {.app = app_ibutton, .name = "ibutton", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef APP_GPIO_DEMO
 | 
					 | 
				
			||||||
    {.app = app_gpio_test, .name = "gpio test", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef APP_FLOOPPER_BLOOPPER
 | 
					 | 
				
			||||||
    {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_SDNFC
 | 
					#ifdef APP_SDNFC
 | 
				
			||||||
@ -154,96 +232,15 @@ const FlipperApplication FLIPPER_SERVICES[] = {
 | 
				
			|||||||
    {.app = app_accessor, .name = "accessor", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					    {.app = app_accessor, .name = "accessor", .stack_size = 4096, .icon = A_Plugins_14},
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
};
 | 
					#ifdef APP_UNIT_TESTS
 | 
				
			||||||
 | 
					    {.app = flipper_test_app, .name = "Unit Tests", .stack_size = 1024, .icon = A_Plugins_14},
 | 
				
			||||||
const size_t FLIPPER_SERVICES_COUNT = sizeof(FLIPPER_SERVICES) / sizeof(FlipperApplication);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Main menu APP
 | 
					 | 
				
			||||||
const FlipperApplication FLIPPER_APPS[] = {
 | 
					 | 
				
			||||||
#ifdef BUILD_SUBGHZ
 | 
					 | 
				
			||||||
    {.app = subghz_app, .name = "Sub-1 GHz", .stack_size = 1024, .icon = A_Sub1ghz_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_LF_RFID
 | 
					 | 
				
			||||||
    {.app = lf_rfid_workaround, .name = "125 kHz RFID", .stack_size = 1024, .icon = A_125khz_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_IRDA
 | 
					 | 
				
			||||||
    {.app = irda, .name = "Infrared", .stack_size = 1024, .icon = A_Infrared_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_IBUTTON
 | 
					 | 
				
			||||||
    {.app = app_ibutton, .name = "iButton", .stack_size = 4096, .icon = A_iButton_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_GPIO_DEMO
 | 
					 | 
				
			||||||
    {.app = app_gpio_test, .name = "GPIO", .stack_size = 1024, .icon = A_GPIO_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const size_t FLIPPER_APPS_COUNT = sizeof(FLIPPER_APPS) / sizeof(FlipperApplication);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Plugin menu
 | 
					 | 
				
			||||||
const FlipperApplication FLIPPER_PLUGINS[] = {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_MUSIC_PLAYER
 | 
					 | 
				
			||||||
    {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_FLOOPPER_BLOOPPER
 | 
					 | 
				
			||||||
    {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_SPEAKER_DEMO
 | 
					 | 
				
			||||||
    {.app = coreglitch_demo_0,
 | 
					 | 
				
			||||||
     .name = "coreglitch_demo_0",
 | 
					 | 
				
			||||||
     .stack_size = 1024,
 | 
					 | 
				
			||||||
     .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
};
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const size_t FLIPPER_PLUGINS_COUNT = sizeof(FLIPPER_PLUGINS) / sizeof(FlipperApplication);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Plugin menu
 | 
					 | 
				
			||||||
const FlipperApplication FLIPPER_DEBUG_APPS[] = {
 | 
					 | 
				
			||||||
#ifdef BUILD_EXAMPLE_BLINK
 | 
					 | 
				
			||||||
    {.app = application_blink, .name = "blink", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_EXAMPLE_INPUT_DUMP
 | 
					 | 
				
			||||||
    {.app = application_input_dump, .name = "input dump", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_SD_TEST
 | 
					 | 
				
			||||||
    {.app = sd_card_test, .name = "sd_card_test", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_VIBRO_DEMO
 | 
					 | 
				
			||||||
    {.app = application_vibro, .name = "vibro", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_SDNFC
 | 
					 | 
				
			||||||
    {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_GUI_TEST
 | 
					 | 
				
			||||||
    {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_KEYPAD_TEST
 | 
					 | 
				
			||||||
    {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#ifdef BUILD_ACCESSOR
 | 
					 | 
				
			||||||
    {.app = app_accessor, .name = "accessor", .stack_size = 4096, .icon = A_Plugins_14},
 | 
					 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const size_t FLIPPER_DEBUG_APPS_COUNT = sizeof(FLIPPER_DEBUG_APPS) / sizeof(FlipperApplication);
 | 
					const size_t FLIPPER_DEBUG_APPS_COUNT = sizeof(FLIPPER_DEBUG_APPS) / sizeof(FlipperApplication);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifdef APP_DOLPHIN
 | 
					#ifdef SRV_DOLPHIN
 | 
				
			||||||
const FlipperApplication FLIPPER_SCENE =
 | 
					const FlipperApplication FLIPPER_SCENE =
 | 
				
			||||||
    {.app = scene_app, .name = "Scenes", .stack_size = 1024, .icon = A_Games_14};
 | 
					    {.app = scene_app, .name = "Scenes", .stack_size = 1024, .icon = A_Games_14};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -6,300 +6,298 @@ C_SOURCES   += $(shell find $(APP_DIR) -name *.c)
 | 
				
			|||||||
CPP_SOURCES += $(shell find $(APP_DIR) -name *.cpp)
 | 
					CPP_SOURCES += $(shell find $(APP_DIR) -name *.cpp)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Use APP_* for autostart app
 | 
					# Use SRV_* for autostart app
 | 
				
			||||||
# Use BUILD_* for add app to build
 | 
					# Use APP_* for add app to build
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_RELEASE ?= 0
 | 
					APP_RELEASE ?= 1
 | 
				
			||||||
ifeq ($(APP_RELEASE), 1)
 | 
					ifeq ($(APP_RELEASE), 1)
 | 
				
			||||||
 | 
					# Main services
 | 
				
			||||||
 | 
					SRV_MENU = 1
 | 
				
			||||||
 | 
					SRV_NFC  = 1
 | 
				
			||||||
 | 
					SRV_POWER = 1
 | 
				
			||||||
 | 
					SRV_BT = 1
 | 
				
			||||||
 | 
					SRV_CLI = 1
 | 
				
			||||||
 | 
					SRV_SD_FILESYSTEM = 1
 | 
				
			||||||
 | 
					SRV_DOLPHIN = 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Main Apps
 | 
				
			||||||
 | 
					APP_IRDA  = 1
 | 
				
			||||||
 | 
					APP_SUBGHZ = 1
 | 
				
			||||||
 | 
					APP_LF_RFID = 1
 | 
				
			||||||
 | 
					APP_GPIO_DEMO = 1
 | 
				
			||||||
 | 
					APP_MUSIC_PLAYER = 1
 | 
				
			||||||
 | 
					APP_FLOOPPER_BLOOPPER = 1
 | 
				
			||||||
 | 
					APP_IBUTTON = 1
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Debug and misc
 | 
				
			||||||
 | 
					APP_GUI_TEST = 1
 | 
				
			||||||
 | 
					APP_KEYPAD_TEST = 1
 | 
				
			||||||
 | 
					APP_ACCESSOR = 1
 | 
				
			||||||
 | 
					APP_SD_TEST = 1
 | 
				
			||||||
 | 
					APP_VIBRO_DEMO = 1
 | 
				
			||||||
 | 
					APP_SPEAKER_DEMO = 1
 | 
				
			||||||
 | 
					APP_EXAMPLE_BLINK = 1
 | 
				
			||||||
 | 
					APP_EXAMPLE_UART_WRITE = 1
 | 
				
			||||||
 | 
					APP_EXAMPLE_INPUT_DUMP = 1
 | 
				
			||||||
 | 
					APP_UNIT_TESTS = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_NFC ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_NFC), 1)
 | 
				
			||||||
 | 
					SRV_MENU	= 1
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_NFC
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_DOLPHIN ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_DOLPHIN), 1)
 | 
				
			||||||
 | 
					SRV_MENU	= 1
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_DOLPHIN
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_POWER ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_POWER), 1)
 | 
				
			||||||
 | 
					SRV_GUI		= 1
 | 
				
			||||||
 | 
					SRV_CLI		= 1
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_POWER
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_BT ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_BT), 1)
 | 
				
			||||||
 | 
					SRV_CLI		= 1
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_BT
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_MENU ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_MENU), 1)
 | 
				
			||||||
 | 
					CFLAGS += -DSRV_MENU
 | 
				
			||||||
APP_MENU = 1
 | 
					APP_MENU = 1
 | 
				
			||||||
APP_NFC  = 1
 | 
					 | 
				
			||||||
APP_POWER = 1
 | 
					 | 
				
			||||||
APP_BT = 1
 | 
					 | 
				
			||||||
APP_CLI = 1
 | 
					 | 
				
			||||||
APP_SD_FILESYSTEM = 1
 | 
					 | 
				
			||||||
BUILD_IRDA  = 1
 | 
					 | 
				
			||||||
APP_DOLPHIN = 1
 | 
					 | 
				
			||||||
BUILD_SUBGHZ = 1
 | 
					 | 
				
			||||||
BUILD_LF_RFID = 1
 | 
					 | 
				
			||||||
BUILD_GPIO_DEMO = 1
 | 
					 | 
				
			||||||
BUILD_MUSIC_PLAYER = 1
 | 
					 | 
				
			||||||
BUILD_FLOOPPER_BLOOPPER = 1
 | 
					 | 
				
			||||||
BUILD_IBUTTON = 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_DEBUG ?=0
 | 
					 | 
				
			||||||
ifeq ($(APP_DEBUG), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DAPP_DEBUG
 | 
					 | 
				
			||||||
BUILD_GUI_TEST = 1
 | 
					 | 
				
			||||||
BUILD_KEYPAD_TEST = 1
 | 
					 | 
				
			||||||
BUILD_ACCESSOR = 1
 | 
					 | 
				
			||||||
BUILD_SD_TEST = 1
 | 
					 | 
				
			||||||
BUILD_VIBRO_DEMO = 1
 | 
					 | 
				
			||||||
BUILD_SPEAKER_DEMO = 1
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_BLINK = 1
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_UART_WRITE = 1
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_INPUT_DUMP = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_NFC ?= 0
 | 
					 | 
				
			||||||
ifeq ($(APP_NFC), 1)
 | 
					 | 
				
			||||||
APP_MENU	= 1
 | 
					 | 
				
			||||||
CFLAGS		+= -DAPP_NFC
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_DOLPHIN ?= 0
 | 
					 | 
				
			||||||
ifeq ($(APP_DOLPHIN), 1)
 | 
					 | 
				
			||||||
APP_MENU	= 1
 | 
					 | 
				
			||||||
CFLAGS		+= -DAPP_DOLPHIN
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_POWER ?= 0
 | 
					 | 
				
			||||||
ifeq ($(APP_POWER), 1)
 | 
					 | 
				
			||||||
APP_GUI		= 1
 | 
					 | 
				
			||||||
APP_CLI		= 1
 | 
					 | 
				
			||||||
CFLAGS		+= -DAPP_POWER
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_BT ?= 0
 | 
					 | 
				
			||||||
ifeq ($(APP_BT), 1)
 | 
					 | 
				
			||||||
APP_CLI		= 1
 | 
					 | 
				
			||||||
CFLAGS		+= -DAPP_BT
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
APP_MENU ?= 0
 | 
					APP_MENU ?= 0
 | 
				
			||||||
ifeq ($(APP_MENU), 1)
 | 
					ifeq ($(APP_MENU), 1)
 | 
				
			||||||
 | 
					SRV_INPUT	= 1
 | 
				
			||||||
 | 
					SRV_GUI		= 1
 | 
				
			||||||
CFLAGS		+= -DAPP_MENU
 | 
					CFLAGS		+= -DAPP_MENU
 | 
				
			||||||
BUILD_MENU = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_MENU ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_MENU), 1)
 | 
					 | 
				
			||||||
APP_INPUT	= 1
 | 
					 | 
				
			||||||
APP_GUI		= 1
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_MENU
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_TEST	?= 0
 | 
					APP_UNIT_TESTS	?= 0
 | 
				
			||||||
ifeq ($(APP_TEST), 1)
 | 
					ifeq ($(APP_UNIT_TESTS), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_TEST
 | 
					CFLAGS		+= -DAPP_UNIT_TESTS
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_EXAMPLE_BLINK ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_EXAMPLE_BLINK), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_EXAMPLE_BLINK
 | 
				
			||||||
 | 
					APP_EXAMPLE_BLINK = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_EXAMPLE_BLINK ?= 0
 | 
					APP_EXAMPLE_BLINK ?= 0
 | 
				
			||||||
ifeq ($(APP_EXAMPLE_BLINK), 1)
 | 
					ifeq ($(APP_EXAMPLE_BLINK), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_EXAMPLE_BLINK
 | 
					CFLAGS		+= -DAPP_EXAMPLE_BLINK
 | 
				
			||||||
BUILD_EXAMPLE_BLINK = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_BLINK ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_EXAMPLE_BLINK), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_EXAMPLE_BLINK
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_EXAMPLE_UART_WRITE ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_EXAMPLE_UART_WRITE), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_EXAMPLE_UART_WRITE
 | 
				
			||||||
 | 
					APP_EXAMPLE_UART_WRITE = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_EXAMPLE_UART_WRITE ?= 0
 | 
					APP_EXAMPLE_UART_WRITE ?= 0
 | 
				
			||||||
ifeq ($(APP_EXAMPLE_UART_WRITE), 1)
 | 
					ifeq ($(APP_EXAMPLE_UART_WRITE), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_EXAMPLE_UART_WRITE
 | 
					CFLAGS		+= -DAPP_EXAMPLE_UART_WRITE
 | 
				
			||||||
BUILD_EXAMPLE_UART_WRITE = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_UART_WRITE ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_EXAMPLE_UART_WRITE), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_EXAMPLE_UART_WRITE
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_EXAMPLE_IPC ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_EXAMPLE_IPC), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_EXAMPLE_IPC
 | 
				
			||||||
 | 
					APP_EXAMPLE_IPC = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_EXAMPLE_IPC ?= 0
 | 
					APP_EXAMPLE_IPC ?= 0
 | 
				
			||||||
ifeq ($(APP_EXAMPLE_IPC), 1)
 | 
					ifeq ($(APP_EXAMPLE_IPC), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_EXAMPLE_IPC
 | 
					CFLAGS		+= -DAPP_EXAMPLE_IPC
 | 
				
			||||||
BUILD_EXAMPLE_IPC = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_IPC ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_EXAMPLE_IPC), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_EXAMPLE_IPC
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_EXAMPLE_INPUT_DUMP ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_EXAMPLE_INPUT_DUMP), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_EXAMPLE_INPUT_DUMP
 | 
				
			||||||
 | 
					APP_EXAMPLE_INPUT_DUMP = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_EXAMPLE_INPUT_DUMP ?= 0
 | 
					APP_EXAMPLE_INPUT_DUMP ?= 0
 | 
				
			||||||
ifeq ($(APP_EXAMPLE_INPUT_DUMP), 1)
 | 
					ifeq ($(APP_EXAMPLE_INPUT_DUMP), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_EXAMPLE_INPUT_DUMP
 | 
					CFLAGS		+= -DAPP_EXAMPLE_INPUT_DUMP
 | 
				
			||||||
BUILD_EXAMPLE_INPUT_DUMP = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_INPUT_DUMP ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_EXAMPLE_INPUT_DUMP), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_EXAMPLE_INPUT_DUMP
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_EXAMPLE_QRCODE ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_EXAMPLE_QRCODE), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_EXAMPLE_QRCODE
 | 
				
			||||||
 | 
					APP_EXAMPLE_QRCODE = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_EXAMPLE_QRCODE ?= 0
 | 
					APP_EXAMPLE_QRCODE ?= 0
 | 
				
			||||||
ifeq ($(APP_EXAMPLE_QRCODE), 1)
 | 
					ifeq ($(APP_EXAMPLE_QRCODE), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_EXAMPLE_QRCODE
 | 
					CFLAGS		+= -DAPP_EXAMPLE_QRCODE
 | 
				
			||||||
BUILD_EXAMPLE_QRCODE = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_EXAMPLE_QRCODE ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_EXAMPLE_QRCODE), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_EXAMPLE_QRCODE
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(BUILD_SUBGHZ), 1)
 | 
					ifeq ($(APP_SUBGHZ), 1)
 | 
				
			||||||
CFLAGS		+= -DBUILD_SUBGHZ
 | 
					CFLAGS		+= -DAPP_SUBGHZ
 | 
				
			||||||
APP_INPUT = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
APP_GUI = 1
 | 
					SRV_GUI = 1
 | 
				
			||||||
APP_CLI = 1
 | 
					SRV_CLI = 1
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_LF_RFID ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_LF_RFID), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_LF_RFID
 | 
				
			||||||
 | 
					APP_LF_RFID = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_LF_RFID ?= 0
 | 
					APP_LF_RFID ?= 0
 | 
				
			||||||
ifeq ($(APP_LF_RFID), 1)
 | 
					ifeq ($(APP_LF_RFID), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_LF_RFID
 | 
					CFLAGS		+= -DAPP_LF_RFID
 | 
				
			||||||
BUILD_LF_RFID = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					SRV_GUI = 1
 | 
				
			||||||
BUILD_LF_RFID ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_LF_RFID), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_LF_RFID
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
APP_GUI = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_IRDA ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_IRDA), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_IRDA
 | 
				
			||||||
 | 
					APP_IRDA = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_IRDA ?= 0
 | 
					APP_IRDA ?= 0
 | 
				
			||||||
ifeq ($(APP_IRDA), 1)
 | 
					ifeq ($(APP_IRDA), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_IRDA
 | 
					CFLAGS		+= -DAPP_IRDA
 | 
				
			||||||
BUILD_IRDA = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					SRV_GUI = 1
 | 
				
			||||||
BUILD_IRDA ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_IRDA), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_IRDA
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
APP_GUI = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_SD_TEST ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_SD_TEST), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_SD_TEST
 | 
				
			||||||
 | 
					APP_SD_TEST = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_SD_TEST ?= 0
 | 
					APP_SD_TEST ?= 0
 | 
				
			||||||
ifeq ($(APP_SD_TEST), 1)
 | 
					ifeq ($(APP_SD_TEST), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_SD_TEST
 | 
					CFLAGS		+= -DAPP_SD_TEST
 | 
				
			||||||
BUILD_SD_TEST = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					SRV_GUI = 1
 | 
				
			||||||
BUILD_SD_TEST ?= 0
 | 
					SRV_SD_FILESYSTEM = 1
 | 
				
			||||||
ifeq ($(BUILD_SD_TEST), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_SD_TEST
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
APP_GUI = 1
 | 
					 | 
				
			||||||
APP_SD_FILESYSTEM = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_SPEAKER_DEMO ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_SPEAKER_DEMO), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_SPEAKER_DEMO
 | 
				
			||||||
 | 
					APP_SPEAKER_DEMO = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_SPEAKER_DEMO ?= 0
 | 
					APP_SPEAKER_DEMO ?= 0
 | 
				
			||||||
ifeq ($(APP_SPEAKER_DEMO), 1)
 | 
					ifeq ($(APP_SPEAKER_DEMO), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_SPEAKER_DEMO
 | 
					CFLAGS		+= -DAPP_SPEAKER_DEMO
 | 
				
			||||||
BUILD_SPEAKER_DEMO = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					SRV_GUI = 1
 | 
				
			||||||
BUILD_SPEAKER_DEMO ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_SPEAKER_DEMO), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_SPEAKER_DEMO
 | 
					 | 
				
			||||||
APP_INPUT = 1
 | 
					 | 
				
			||||||
APP_GUI = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
BUILD_VIBRO_DEMO ?= 0
 | 
					APP_VIBRO_DEMO ?= 0
 | 
				
			||||||
ifeq ($(BUILD_VIBRO_DEMO), 1)
 | 
					ifeq ($(APP_VIBRO_DEMO), 1)
 | 
				
			||||||
CFLAGS		+= -DBUILD_VIBRO_DEMO
 | 
					CFLAGS		+= -DAPP_VIBRO_DEMO
 | 
				
			||||||
APP_INPUT = 1
 | 
					SRV_INPUT = 1
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_KEYPAD_TEST ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_KEYPAD_TEST), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_KEYPAD_TEST
 | 
				
			||||||
 | 
					APP_KEYPAD_TEST = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_KEYPAD_TEST ?= 0
 | 
					APP_KEYPAD_TEST ?= 0
 | 
				
			||||||
ifeq ($(APP_KEYPAD_TEST), 1)
 | 
					ifeq ($(APP_KEYPAD_TEST), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_KEYPAD_TEST
 | 
					CFLAGS		+= -DAPP_KEYPAD_TEST
 | 
				
			||||||
BUILD_KEYPAD_TEST = 1
 | 
					APP_KEYPAD_TEST = 1
 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_KEYPAD_TEST ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_KEYPAD_TEST), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_KEYPAD_TEST
 | 
					 | 
				
			||||||
BUILD_KEYPAD_TEST = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_ACCESSOR ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_ACCESSOR), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_ACCESSOR
 | 
				
			||||||
 | 
					APP_ACCESSOR = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_ACCESSOR ?= 0
 | 
					APP_ACCESSOR ?= 0
 | 
				
			||||||
ifeq ($(APP_ACCESSOR), 1)
 | 
					ifeq ($(APP_ACCESSOR), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_ACCESSOR
 | 
					CFLAGS		+= -DAPP_ACCESSOR
 | 
				
			||||||
BUILD_ACCESSOR = 1
 | 
					APP_ACCESSOR = 1
 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_ACCESSOR ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_ACCESSOR), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_ACCESSOR
 | 
					 | 
				
			||||||
BUILD_ACCESSOR = 1
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_GPIO_DEMO ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_GPIO_DEMO), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_GPIO_DEMO
 | 
				
			||||||
 | 
					APP_GPIO_DEMO = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_GPIO_DEMO ?= 0
 | 
					APP_GPIO_DEMO ?= 0
 | 
				
			||||||
ifeq ($(APP_GPIO_DEMO), 1)
 | 
					ifeq ($(APP_GPIO_DEMO), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_GPIO_DEMO
 | 
					CFLAGS		+= -DAPP_GPIO_DEMO
 | 
				
			||||||
BUILD_GPIO_DEMO = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_GPIO_DEMO ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_GPIO_DEMO), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_GPIO_DEMO
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_MUSIC_PLAYER ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_MUSIC_PLAYER), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_MUSIC_PLAYER
 | 
				
			||||||
 | 
					APP_MUSIC_PLAYER = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_MUSIC_PLAYER ?= 0
 | 
					APP_MUSIC_PLAYER ?= 0
 | 
				
			||||||
ifeq ($(APP_MUSIC_PLAYER), 1)
 | 
					ifeq ($(APP_MUSIC_PLAYER), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_MUSIC_PLAYER
 | 
					CFLAGS		+= -DAPP_MUSIC_PLAYER
 | 
				
			||||||
BUILD_MUSIC_PLAYER = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_MUSIC_PLAYER ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_MUSIC_PLAYER), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_MUSIC_PLAYER
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_FLOOPPER_BLOOPPER ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_FLOOPPER_BLOOPPER), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_FLOOPPER_BLOOPPER
 | 
				
			||||||
 | 
					APP_FLOOPPER_BLOOPPER = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_FLOOPPER_BLOOPPER ?= 0
 | 
					APP_FLOOPPER_BLOOPPER ?= 0
 | 
				
			||||||
ifeq ($(APP_FLOOPPER_BLOOPPER), 1)
 | 
					ifeq ($(APP_FLOOPPER_BLOOPPER), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_FLOOPPER_BLOOPPER
 | 
					CFLAGS		+= -DAPP_FLOOPPER_BLOOPPER
 | 
				
			||||||
BUILD_FLOOPPER_BLOOPPER = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_FLOOPPER_BLOOPPER ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_FLOOPPER_BLOOPPER), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_FLOOPPER_BLOOPPER
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_IBUTTON ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_IBUTTON), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_IBUTTON
 | 
				
			||||||
 | 
					APP_IBUTTON = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_IBUTTON ?= 0
 | 
					APP_IBUTTON ?= 0
 | 
				
			||||||
ifeq ($(APP_IBUTTON), 1)
 | 
					ifeq ($(APP_IBUTTON), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_IBUTTON
 | 
					CFLAGS		+= -DAPP_IBUTTON
 | 
				
			||||||
BUILD_IBUTTON = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_IBUTTON ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_IBUTTON), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_IBUTTON
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_GUI_TEST ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_GUI_TEST), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_GUI_TEST
 | 
				
			||||||
 | 
					APP_GUI_TEST = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_GUI_TEST ?= 0
 | 
					APP_GUI_TEST ?= 0
 | 
				
			||||||
ifeq ($(APP_GUI_TEST), 1)
 | 
					ifeq ($(APP_GUI_TEST), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_GUI_TEST
 | 
					CFLAGS		+= -DAPP_GUI_TEST
 | 
				
			||||||
BUILD_GUI_TEST = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_GUI_TEST ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_GUI_TEST), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_GUI_TEST
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					SRV_SDNFC ?= 0
 | 
				
			||||||
 | 
					ifeq ($(SRV_SDNFC), 1)
 | 
				
			||||||
 | 
					CFLAGS		+= -DSRV_SDNFC
 | 
				
			||||||
 | 
					APP_SDNFC = 1
 | 
				
			||||||
 | 
					endif
 | 
				
			||||||
APP_SDNFC ?= 0
 | 
					APP_SDNFC ?= 0
 | 
				
			||||||
ifeq ($(APP_SDNFC), 1)
 | 
					ifeq ($(APP_SDNFC), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_SDNFC
 | 
					CFLAGS		+= -DAPP_SDNFC
 | 
				
			||||||
BUILD_SDNFC = 1
 | 
					 | 
				
			||||||
endif
 | 
					 | 
				
			||||||
BUILD_SDNFC ?= 0
 | 
					 | 
				
			||||||
ifeq ($(BUILD_SDNFC), 1)
 | 
					 | 
				
			||||||
CFLAGS		+= -DBUILD_SDNFC
 | 
					 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
# device drivers
 | 
					# device drivers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_GUI	?= 0
 | 
					SRV_GUI	?= 0
 | 
				
			||||||
ifeq ($(APP_GUI), 1)
 | 
					ifeq ($(SRV_GUI), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_GUI
 | 
					CFLAGS		+= -DSRV_GUI
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_SD_FILESYSTEM	?= 0
 | 
					SRV_SD_FILESYSTEM	?= 0
 | 
				
			||||||
ifeq ($(APP_SD_FILESYSTEM), 1)
 | 
					ifeq ($(SRV_SD_FILESYSTEM), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_SD_FILESYSTEM
 | 
					CFLAGS		+= -DSRV_SD_FILESYSTEM
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_INPUT	?= 0
 | 
					SRV_INPUT	?= 0
 | 
				
			||||||
ifeq ($(APP_INPUT), 1)
 | 
					ifeq ($(SRV_INPUT), 1)
 | 
				
			||||||
CFLAGS		+= -DAPP_INPUT
 | 
					CFLAGS		+= -DSRV_INPUT
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
APP_CLI ?= 0
 | 
					SRV_CLI ?= 0
 | 
				
			||||||
ifeq ($(APP_CLI), 1)
 | 
					ifeq ($(SRV_CLI), 1)
 | 
				
			||||||
APP_GUI		= 1
 | 
					SRV_GUI		= 1
 | 
				
			||||||
CFLAGS		+= -DAPP_CLI
 | 
					CFLAGS		+= -DSRV_CLI
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
				
			|||||||
@ -6,4 +6,4 @@ rm bootloader/.obj/f*/flash || true
 | 
				
			|||||||
make -C bootloader -j9 flash
 | 
					make -C bootloader -j9 flash
 | 
				
			||||||
 | 
					
 | 
				
			||||||
rm firmware/.obj/f*/flash || true
 | 
					rm firmware/.obj/f*/flash || true
 | 
				
			||||||
make -C firmware -j9 APP_RELEASE=1 APP_DEBUG=1 flash
 | 
					make -C firmware -j9 flash
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										10
									
								
								lib/lib.mk
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								lib/lib.mk
									
									
									
									
									
								
							@ -36,7 +36,7 @@ C_SOURCES		+= $(FATFS_DIR)/ff_gen_drv.c
 | 
				
			|||||||
C_SOURCES		+= $(FATFS_DIR)/diskio.c
 | 
					C_SOURCES		+= $(FATFS_DIR)/diskio.c
 | 
				
			||||||
C_SOURCES		+= $(FATFS_DIR)/option/unicode.c
 | 
					C_SOURCES		+= $(FATFS_DIR)/option/unicode.c
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ifeq ($(APP_NFC), 1)
 | 
					ifeq ($(SRV_NFC), 1)
 | 
				
			||||||
ST25RFAL002_DIR	= $(LIB_DIR)/ST25RFAL002
 | 
					ST25RFAL002_DIR	= $(LIB_DIR)/ST25RFAL002
 | 
				
			||||||
CFLAGS			+= -I$(ST25RFAL002_DIR)
 | 
					CFLAGS			+= -I$(ST25RFAL002_DIR)
 | 
				
			||||||
CFLAGS			+= -I$(ST25RFAL002_DIR)/include
 | 
					CFLAGS			+= -I$(ST25RFAL002_DIR)/include
 | 
				
			||||||
@ -58,13 +58,13 @@ C_SOURCES		+= $(LIB_DIR)/fnv1a-hash/fnv1a-hash.c
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# build onewire/cyfral library only if
 | 
					# build onewire/cyfral library only if
 | 
				
			||||||
# we build iButton application
 | 
					# we build iButton application
 | 
				
			||||||
ifeq ($(BUILD_IBUTTON), 1)
 | 
					ifeq ($(APP_IBUTTON), 1)
 | 
				
			||||||
# onewire library
 | 
					# onewire library
 | 
				
			||||||
BUILD_ONEWIRE	= 1
 | 
					APP_ONEWIRE	= 1
 | 
				
			||||||
endif
 | 
					endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
BUILD_ONEWIRE ?= 0
 | 
					APP_ONEWIRE ?= 0
 | 
				
			||||||
ifeq ($(BUILD_ONEWIRE), 1)
 | 
					ifeq ($(APP_ONEWIRE), 1)
 | 
				
			||||||
# onewire library
 | 
					# onewire library
 | 
				
			||||||
ONEWIRE_DIR		= $(LIB_DIR)/onewire
 | 
					ONEWIRE_DIR		= $(LIB_DIR)/onewire
 | 
				
			||||||
CFLAGS			+= -I$(ONEWIRE_DIR)
 | 
					CFLAGS			+= -I$(ONEWIRE_DIR)
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user