SmartAudio/package/security/secure-storage/Makefile

127 lines
4.1 KiB
Makefile
Executable File

##############################################
# OpenWrt Makefile for helloworld program
#
#
# Most of the variables used here are defined in
# the include directives below. We just need to
# specify a basic description of the package,
# where to build our program, where to find
# the source files, and where to install the
# compiled program on the router.
#
# Be very careful of spacing in this file.
# Indents should be tabs, not spaces, and
# there should be no trailing whitespace in
# lines that are not commented.
#
##############################################
include $(TOPDIR)/rules.mk
include $(BUILD_DIR)/kernel.mk
# Name and release number of this package
PKG_NAME:=secure-storage
PKG_VERSION:=0.0.1
PKG_RELEASE:=1
# This specifies the directory where we're going to build the program.
# The root build directory, $(BUILD_DIR), is by default the build_mipsel
# directory in your OpenWrt SDK directory
PKG_BUILD_DIR := $(COMPILE_DIR)/$(PKG_NAME)
include $(BUILD_DIR)/package.mk
# Specify package information for this program.
# The variables defined here should be self explanatory.
# If you are running Kamikaze, delete the DESCRIPTION
# variable below and uncomment the Kamikaze define
# directive for the description below
define Package/$(PKG_NAME)
SECTION:=utils
CATEGORY:=Security
TITLE:=secure-storage(TA) and libstorage
DEPENDS:= +liballwinner-base +optee-client
endef
define Package/$(PKG_NAME)-demo
SECTION:=utils
CATEGORY:=Security
TITLE:=secure-storage demo
DEPENDS:= +liballwinner-base +optee-client +$(PKG_NAME)
endef
# Uncomment portion below for Kamikaze and delete DESCRIPTION variable above
define Package/$(PKG_NAME)/description
This package contains secure-storage(TA) and libstorage!
endef
define Package/$(PKG_NAME)-demo/description
Secure storage demo(NA).
endef
# Specify what needs to be done to prepare for building the package.
# In our case, we need to copy the source files to the build directory.
# This is NOT the default. The default uses the PKG_SOURCE_URL and the
# PKG_SOURCE which is not defined here to download the source from the web.
# In order to just build a simple program that we have just written, it is
# much easier to do it this way.
define Build/Prepare
mkdir -p $(PKG_BUILD_DIR)
$(CP) -r ./src/* $(PKG_BUILD_DIR)/
endef
define Build/Configure
endef
define Build/Compile
# build libstorage
$(MAKE) -C $(PKG_BUILD_DIR)/libstorage \
CC="$(TARGET_CC)" \
CFLAGS="$(TARGET_CFLAGS)"\
LDFLAGS="$(TARGET_LDFLAGS)"
endef
define Build/InstallDev
$(INSTALL_DIR) $(1)/usr
$(INSTALL_DIR) $(1)/usr/lib
$(INSTALL_DIR) $(1)/usr/include
$(CP) $(PKG_BUILD_DIR)/ta/lib/* $(1)/lib
$(CP) $(PKG_BUILD_DIR)/ta/include/ta_storage.h $(1)/usr/include
$(CP) $(PKG_BUILD_DIR)/libstorage/libstorage.so $(1)/usr/lib
$(CP) $(PKG_BUILD_DIR)/libstorage/libstorage.h $(1)/usr/include
endef
# Specify where and how to install the program. Since we only have one file,
# the helloworld executable, install it by copying it to the /bin directory on
# the router. The $(1) variable represents the root directory on the router running
# OpenWrt. The $(INSTALL_DIR) variable contains a command to prepare the install
# directory if it does not already exist. Likewise $(INSTALL_BIN) contains the
# command to copy the binary file from its current location (in our case the build
# directory) to the install directory.
define Package/$(PKG_NAME)/install
$(INSTALL_DIR) $(1)/bin
$(INSTALL_DIR) $(1)/lib
$(INSTALL_DIR) $(1)/lib/optee_armtz
$(INSTALL_DIR) $(1)/usr
$(INSTALL_DIR) $(1)/usr/lib
$(INSTALL_DIR) $(1)/data
$(INSTALL_DIR) $(1)/data/tee
$(CP) $(PKG_BUILD_DIR)/ta/lib/* $(1)/lib
$(CP) $(PKG_BUILD_DIR)/libstorage/libstorage.so $(1)/usr/lib
endef
define Package/$(PKG_NAME)-demo/install
$(INSTALL_DIR) $(1)/usr/sbin
$(CP) $(PKG_BUILD_DIR)/libstorage/ss_demo $(1)/usr/sbin
endef
# This line executes the necessary commands to compile our program.
# The above define directives specify all the information needed, but this
# line calls BuildPackage which in turn actually uses this information to
# build a package.
$(eval $(call BuildPackage,$(PKG_NAME)))
$(eval $(call BuildPackage,$(PKG_NAME)-demo))