Application Development
Overview
Here will describe how to develop an HummingBird SDK application.
To develop a HummingBird SDK application from scratch, you can do the following steps:
Create a directory to place your application code.
Create Makefile in the new created directory, the minimal Makefile should look like this
1 TARGET = your_target_name 2 3 HBIRD_SDK_ROOT = path/to/your_hbird_sdk_root 4 5 SRCDIRS = . 6 7 INCDIRS = . 8 9 include $(HBIRD_SDK_ROOT)/Build/Makefile.base
Copy or create your application code in new created directory.
Note
If you just want to SoC related resource, you can include header file
hbird_sdk_soc.h
in your application code.If you just want to SoC and Board related resource, you can include header file
hbird_sdk_hal.h
in your application code.For simplity, we recomment you to use
hbird_sdk_hal.h
header file
Follow Build System based on Makefile to change your application Makefile.
Add Extra Source Code
If you want to add extra source code, you can use these makefile variables:
- To add all the source code in directories, recursive search is not supported.
SRCDIRS: Add C/CPP/ASM source code located in the directories defined by this variable.
C_SRCDIRS: Add C only source code located in the directories defined by this variable.
CXX_SRCDIRS: Add CPP only source code located in the directories defined by this variable.
ASM_SRCDIRS: Add ASM only source code located in the directories defined by this variable.
- To add only selected source code in directory
Add Extra Include Directory
If you want to add extra include directories, you can use these makefile variables:
INCDIRS: Include the directories defined by this variable for C/ASM/CPP code during compiling.
C_INCDIRS: Include the directories defined by this variable for C only code during compiling.
CXX_INCDIRS: Include the directories defined by this variable for CPP only code during compiling.
ASM_INCDIRS: Include the directories defined by this variable for ASM only code during compiling.
Add Extra Build Options
If you want to add extra build options, you can use these makefile variables:
COMMON_FLAGS: This will add compiling flags for C/CPP/ASM source code.
CFLAGS: This will add compiling flags for C source code.
CXXFLAGS: This will add compiling flags for CPP source code.
ASMFLAGS: This will add compiling flags for ASM source code.
LDFLAGS: This will add linker flags when linking.
LDLIBS: This will add extra libraries need to be linked.
LIBDIRS: This will add extra library directories to be searched by linker.
Optimize For Code Size
If you want to optimize your application for code size, you set COMMON_FLAGS
in your application Makefile like this:
COMMON_FLAGS := -Os
If you want to optimize code size even more, you use this link time optimization(LTO) as below:
COMMON_FLAGS := -Os -flto
see demo_plic for example usage of optimize for code size.
For more details about gcc optimization, please refer to Options That Control Optimization in GCC.
Change Link Script
If you want to change the default link script defined by your make configuration(SOC, BOARD, DOWNLOAD). You can use LINKER_SCRIPT variable to set your linker script.
Set Default Make Options
Set Default Global Make Options For HummingBird SDK
If you want to change the global Make options for the HummingBird SDK, you can add the Makefile.global.
Set Local Make Options For Your Application
If you want to change the application level Make options, you can add the Makefile.local.