Просмотр исходного кода

Recator application build system: cleaner flags naming, set release flag to yes by default, include unit test and debug apps (#443)

あく 4 лет назад
Родитель
Сommit
b90d72fadf
7 измененных файлов с 244 добавлено и 249 удалено
  1. 1 1
      .github/workflows/ci.yml
  2. 1 1
      ReadMe.md
  3. 2 2
      applications/app-loader/app-loader.c
  4. 46 49
      applications/applications.c
  5. 188 190
      applications/applications.mk
  6. 1 1
      flash_core1_main.sh
  7. 5 5
      lib/lib.mk

+ 1 - 1
.github/workflows/ci.yml

@@ -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

+ 1 - 1
ReadMe.md

@@ -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/)

+ 2 - 2
applications/app-loader/app-loader.c

@@ -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");
 
 

+ 46 - 49
applications/applications.c

@@ -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,94 +60,90 @@ 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
-    {.app = flipper_test_app, .name = "test app", .stack_size = 1024, .icon = A_Plugins_14},
-#endif
-
-#ifdef APP_EXAMPLE_QRCODE
+#ifdef SRV_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 APP_SPEAKER_DEMO
+#ifdef SRV_SPEAKER_DEMO
     {.app = coreglitch_demo_0,
     {.app = coreglitch_demo_0,
      .name = "coreglitch_demo_0",
      .name = "coreglitch_demo_0",
      .stack_size = 1024,
      .stack_size = 1024,
      .icon = A_Plugins_14},
      .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_SD_TEST
+#ifdef SRV_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 SRV_MUSIC_PLAYER
     {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_IBUTTON
+#ifdef SRV_IBUTTON
     {.app = app_ibutton, .name = "ibutton", .stack_size = 4096, .icon = A_Plugins_14},
     {.app = app_ibutton, .name = "ibutton", .stack_size = 4096, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_GPIO_DEMO
+#ifdef SRV_GPIO_DEMO
     {.app = app_gpio_test, .name = "gpio test", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = app_gpio_test, .name = "gpio test", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_FLOOPPER_BLOOPPER
+#ifdef SRV_FLOOPPER_BLOOPPER
     {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
     {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 #endif
 #endif
 
 
-#ifdef APP_SDNFC
+#ifdef SRV_SDNFC
     {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_GUI_TEST
+#ifdef SRV_GUI_TEST
     {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_KEYPAD_TEST
+#ifdef SRV_KEYPAD_TEST
     {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
     {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef APP_ACCESSOR
+#ifdef SRV_ACCESSOR
     {.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
 
 
@@ -160,23 +153,23 @@ const size_t FLIPPER_SERVICES_COUNT = sizeof(FLIPPER_SERVICES) / sizeof(FlipperA
 
 
 // Main menu APP
 // Main menu APP
 const FlipperApplication FLIPPER_APPS[] = {
 const FlipperApplication FLIPPER_APPS[] = {
-#ifdef BUILD_SUBGHZ
+#ifdef APP_SUBGHZ
     {.app = subghz_app, .name = "Sub-1 GHz", .stack_size = 1024, .icon = A_Sub1ghz_14},
     {.app = subghz_app, .name = "Sub-1 GHz", .stack_size = 1024, .icon = A_Sub1ghz_14},
 #endif
 #endif
 
 
-#ifdef BUILD_LF_RFID
+#ifdef APP_LF_RFID
     {.app = lf_rfid_workaround, .name = "125 kHz RFID", .stack_size = 1024, .icon = A_125khz_14},
     {.app = lf_rfid_workaround, .name = "125 kHz RFID", .stack_size = 1024, .icon = A_125khz_14},
 #endif
 #endif
 
 
-#ifdef BUILD_IRDA
+#ifdef APP_IRDA
     {.app = irda, .name = "Infrared", .stack_size = 1024, .icon = A_Infrared_14},
     {.app = irda, .name = "Infrared", .stack_size = 1024, .icon = A_Infrared_14},
 #endif
 #endif
 
 
-#ifdef BUILD_IBUTTON
+#ifdef APP_IBUTTON
     {.app = app_ibutton, .name = "iButton", .stack_size = 4096, .icon = A_iButton_14},
     {.app = app_ibutton, .name = "iButton", .stack_size = 4096, .icon = A_iButton_14},
 #endif
 #endif
 
 
-#ifdef BUILD_GPIO_DEMO
+#ifdef APP_GPIO_DEMO
     {.app = app_gpio_test, .name = "GPIO", .stack_size = 1024, .icon = A_GPIO_14},
     {.app = app_gpio_test, .name = "GPIO", .stack_size = 1024, .icon = A_GPIO_14},
 #endif
 #endif
 };
 };
@@ -186,15 +179,15 @@ const size_t FLIPPER_APPS_COUNT = sizeof(FLIPPER_APPS) / sizeof(FlipperApplicati
 // Plugin menu
 // Plugin menu
 const FlipperApplication FLIPPER_PLUGINS[] = {
 const FlipperApplication FLIPPER_PLUGINS[] = {
 
 
-#ifdef BUILD_MUSIC_PLAYER
+#ifdef APP_MUSIC_PLAYER
     {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = music_player, .name = "music player", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef BUILD_FLOOPPER_BLOOPPER
+#ifdef APP_FLOOPPER_BLOOPPER
     {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
     {.app = floopper_bloopper, .name = "Floopper Bloopper", .stack_size = 1024, .icon = A_Games_14},
 #endif
 #endif
 
 
-#ifdef BUILD_SPEAKER_DEMO
+#ifdef APP_SPEAKER_DEMO
     {.app = coreglitch_demo_0,
     {.app = coreglitch_demo_0,
      .name = "coreglitch_demo_0",
      .name = "coreglitch_demo_0",
      .stack_size = 1024,
      .stack_size = 1024,
@@ -207,43 +200,47 @@ const size_t FLIPPER_PLUGINS_COUNT = sizeof(FLIPPER_PLUGINS) / sizeof(FlipperApp
 
 
 // Plugin menu
 // Plugin menu
 const FlipperApplication FLIPPER_DEBUG_APPS[] = {
 const FlipperApplication FLIPPER_DEBUG_APPS[] = {
-#ifdef BUILD_EXAMPLE_BLINK
+#ifdef APP_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 BUILD_EXAMPLE_INPUT_DUMP
+#ifdef APP_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 BUILD_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 BUILD_VIBRO_DEMO
+#ifdef APP_VIBRO_DEMO
     {.app = application_vibro, .name = "vibro", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = application_vibro, .name = "vibro", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef BUILD_SDNFC
+#ifdef APP_SDNFC
     {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = sdnfc, .name = "sdnfc", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef BUILD_GUI_TEST
+#ifdef APP_GUI_TEST
     {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
     {.app = gui_test, .name = "gui_test", .stack_size = 1024, .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef BUILD_KEYPAD_TEST
+#ifdef APP_KEYPAD_TEST
     {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
     {.app = keypad_test, .name = "keypad_test", .icon = A_Plugins_14},
 #endif
 #endif
 
 
-#ifdef BUILD_ACCESSOR
+#ifdef APP_ACCESSOR
     {.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},
+#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};
 
 

+ 188 - 190
applications/applications.mk

@@ -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 BUILD_* for add app to build
+# Use SRV_* for autostart app
+# 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
-
-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
 endif
-
 APP_MENU ?= 0
 APP_MENU ?= 0
 ifeq ($(APP_MENU), 1)
 ifeq ($(APP_MENU), 1)
-CFLAGS += -DAPP_MENU
-BUILD_MENU = 1
-endif
-BUILD_MENU ?= 0
-ifeq ($(BUILD_MENU), 1)
-APP_INPUT	= 1
-APP_GUI		= 1
-CFLAGS		+= -DBUILD_MENU
+SRV_INPUT	= 1
+SRV_GUI		= 1
+CFLAGS		+= -DAPP_MENU
 endif
 endif
 
 
-APP_TEST	?= 0
-ifeq ($(APP_TEST), 1)
-CFLAGS		+= -DAPP_TEST
+APP_UNIT_TESTS	?= 0
+ifeq ($(APP_UNIT_TESTS), 1)
+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
-endif
-BUILD_EXAMPLE_BLINK ?= 0
-ifeq ($(BUILD_EXAMPLE_BLINK), 1)
-CFLAGS		+= -DBUILD_EXAMPLE_BLINK
-APP_INPUT = 1
+SRV_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
-endif
-BUILD_EXAMPLE_INPUT_DUMP ?= 0
-ifeq ($(BUILD_EXAMPLE_INPUT_DUMP), 1)
-CFLAGS		+= -DBUILD_EXAMPLE_INPUT_DUMP
-APP_INPUT = 1
+SRV_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)
-CFLAGS		+= -DBUILD_SUBGHZ
-APP_INPUT = 1
-APP_GUI = 1
-APP_CLI = 1
+ifeq ($(APP_SUBGHZ), 1)
+CFLAGS		+= -DAPP_SUBGHZ
+SRV_INPUT = 1
+SRV_GUI = 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
-endif
-BUILD_LF_RFID ?= 0
-ifeq ($(BUILD_LF_RFID), 1)
-CFLAGS		+= -DBUILD_LF_RFID
-APP_INPUT = 1
-APP_GUI = 1
+SRV_INPUT = 1
+SRV_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
-endif
-BUILD_IRDA ?= 0
-ifeq ($(BUILD_IRDA), 1)
-CFLAGS		+= -DBUILD_IRDA
-APP_INPUT = 1
-APP_GUI = 1
+SRV_INPUT = 1
+SRV_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
-endif
-BUILD_SD_TEST ?= 0
-ifeq ($(BUILD_SD_TEST), 1)
-CFLAGS		+= -DBUILD_SD_TEST
-APP_INPUT = 1
-APP_GUI = 1
-APP_SD_FILESYSTEM = 1
+SRV_INPUT = 1
+SRV_GUI = 1
+SRV_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
-endif
-BUILD_SPEAKER_DEMO ?= 0
-ifeq ($(BUILD_SPEAKER_DEMO), 1)
-CFLAGS		+= -DBUILD_SPEAKER_DEMO
-APP_INPUT = 1
-APP_GUI = 1
+SRV_INPUT = 1
+SRV_GUI = 1
 endif
 endif
 
 
-BUILD_VIBRO_DEMO ?= 0
-ifeq ($(BUILD_VIBRO_DEMO), 1)
-CFLAGS		+= -DBUILD_VIBRO_DEMO
-APP_INPUT = 1
+APP_VIBRO_DEMO ?= 0
+ifeq ($(APP_VIBRO_DEMO), 1)
+CFLAGS		+= -DAPP_VIBRO_DEMO
+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
-endif
-BUILD_KEYPAD_TEST ?= 0
-ifeq ($(BUILD_KEYPAD_TEST), 1)
-CFLAGS		+= -DBUILD_KEYPAD_TEST
-BUILD_KEYPAD_TEST = 1
+APP_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
-endif
-BUILD_ACCESSOR ?= 0
-ifeq ($(BUILD_ACCESSOR), 1)
-CFLAGS		+= -DBUILD_ACCESSOR
-BUILD_ACCESSOR = 1
+APP_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
-ifeq ($(APP_GUI), 1)
-CFLAGS		+= -DAPP_GUI
+SRV_GUI	?= 0
+ifeq ($(SRV_GUI), 1)
+CFLAGS		+= -DSRV_GUI
 endif
 endif
 
 
-APP_SD_FILESYSTEM	?= 0
-ifeq ($(APP_SD_FILESYSTEM), 1)
-CFLAGS		+= -DAPP_SD_FILESYSTEM
+SRV_SD_FILESYSTEM	?= 0
+ifeq ($(SRV_SD_FILESYSTEM), 1)
+CFLAGS		+= -DSRV_SD_FILESYSTEM
 endif
 endif
 
 
-APP_INPUT	?= 0
-ifeq ($(APP_INPUT), 1)
-CFLAGS		+= -DAPP_INPUT
+SRV_INPUT	?= 0
+ifeq ($(SRV_INPUT), 1)
+CFLAGS		+= -DSRV_INPUT
 endif
 endif
 
 
-APP_CLI ?= 0
-ifeq ($(APP_CLI), 1)
-APP_GUI		= 1
-CFLAGS		+= -DAPP_CLI
+SRV_CLI ?= 0
+ifeq ($(SRV_CLI), 1)
+SRV_GUI		= 1
+CFLAGS		+= -DSRV_CLI
 endif
 endif

+ 1 - 1
flash_core1_main.sh

@@ -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

+ 5 - 5
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
-ifeq ($(BUILD_ONEWIRE), 1)
+APP_ONEWIRE ?= 0
+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)