#-------------------------------------------------------------------------------
# Source PATH
#-------------------------------------------------------------------------------
import os
Import('env')
env = env.Clone()

#------------------------------------------------------------------------------
# TUI FUNC
#------------------------------------------------------------------------------
def MPOS_TUI_LOGD(str):
  print("\n\033[0;33;40m" +  "[TUI_DBG] " + str + "\033[0;m\n")

if not hasattr(env, 'IMAGE_ALIASES'):
  aliases = []
  aliases = ['mpostui',]
  env.Replace(OUT_DIR = '${BUILD_ROOT}/apps/bsp/trustzone/qsapps/mpostui/build')
  env.Replace(LIB_OUT_DIR = '${BUILD_ROOT}/apps/bsp/trustzone/qsapps/${LIBNAME}/' + 'mpostui/build' + '/${PROC}' + '/${SHORT_BUILDPATH}')

if env.has_key('USES_NO_CP'):
  env.Append(CCFLAGS = ' -DUSES_NO_CP ')

target_name = 'mpostui'
app_name = 'mpostui'

SCRYPTO_LIB = os.environ['TZ_SCRYPTO_LIB32']

#------------------------------------------------------------------------------
# We need to specify "neon" to generate SIMD instructions in 32-bit mode
#------------------------------------------------------------------------------
if env['PROC'] == 'scorpion':
  env.Append(CCFLAGS = " -mfpu=neon ")

env.Append(CCFLAGS = " -DCONFIG_QSEE")

env.PublishPrivateApi('SECUREMSM', [
   "${INC_ROOT}/core/api/services",
   "${INC_ROOT}/core/api/securemsm/trustzone/qsee",
   "${INC_ROOT}/core/securemsm/secrsa/shared/inc",
   "${INC_ROOT}/core/securemsm/secrsa/shared/src",
   "${INC_ROOT}/core/api/securemsm/crypto",
   "${INC_ROOT}/core/securemsm/secmath/shared/inc",
   #"${INC_ROOT}/core/securemsm/trustzone/qsapps/libs/biometric/inc",
   "${INC_ROOT}/core/securemsm/trustzone/qsapps/tz_spay_platform/tl/QSEE",
   "${INC_ROOT}/core/securemsm/trustzone/qsapps/tz_platform/vendor/QSEE/tl",
   "${INC_ROOT}/core/securemsm/trustzone/qsapps/tz_platform/vendor/ese/header_libs/swd/header/iso7816",
   "${INC_ROOT}/core/securemsm/trustzone/qsapps/tz_platform/public/tl",
   "${INC_ROOT}/core/securemsm/trustzone/qsapps/tz_spay_common/public",
   "${INC_ROOT}/core/securemsm/sse/qsee/SecureUI/inc",
   "${INC_ROOT}/core/securemsm/sse/qsee/SecureUILib/include",
   "${INC_ROOT}/core/securemsm/sse/qsee/SecureTouch/drTs/include",
   "${INC_ROOT}/core/securemsm/sse/qsee/SecureDisplay/libpng/include",
   "${INC_ROOT}/core/securemsm/sse/qsee/SecureDisplay/zlib/include",
])

includes = [
          '#../../core/api/services',
          '#../../core/api/kernel/libstd/stringl',
       #  '#../../core/api/securemsm/crypto',
          '#../../core/api/boot/qfprom',
          '#../../core/kernel/smmu/ACv3.0/common/inc',
          '#../../core/kernel/smmu/smmu500/inc/'
          '#../../ssg/api/securemsm/trustzone/qsee',
          '#../../ssg/securemsm/accesscontrol/api',
          '#../../ssg/securemsm/secrsa/shared/inc',
          '#../../ssg/securemsm/secrsa/shared/src',
          '#../../ssg/securemsm/secmath/shared/inc',
          '#../../ssg/api/securemsm/trustzone/gp',
          '#../../ssg/securemsm/sse/log/inc',
          '#../../ssg/securemsm/sse/common/include',
          '#../../ssg/securemsm/sse/SecureTouch/common/include',
          '#../../ssg/securemsm/sse/SecureTouch/controller/inc',
          '#../../ssg/securemsm/sse/SecureTouch/layout/include',
          '#../../ssg/securemsm/sse/qsee/SecureUI/inc',
          '#../../ssg/securemsm/sse/qsee/SecureUILib/include',
          '#../../ssg/securemsm/sse/qsee/SecureTouch/drTs/include',
          '#../../ssg/securemsm/sse/qsee/SecureDisplay/libgd/include',
          '#../../ssg/securemsm/sse/qsee/SecureDisplay/libpng/include',
          '#../../ssg/securemsm/sse/qsee/SecureDisplay/zlib/include',
          '#../../ssg/securemsm/trustzone/qsapps/mpostui/inc',
          '#../../ssg/securemsm/trustzone/qsapps/mpostui/resource',
          '#../../ssg/securemsm/trustzone/qsapps/tz_mpos_common/public',
          '#../../ssg/securemsm/tz_common/public',
          '#../../ssg/securemsm/tz_iccc_common/public',
          '#../../ssg/securemsm/uclib/usr/legacy/secrsa/shared/src',
          '#../../ssg/securemsm/uclib/usr/legacy/secrsa/shared/inc',
          '#../../ssg/securemsm/uclib/usr/legacy/secmath/shared/inc',
           ]
includes += [os.environ['TZ_SCRYPTO_HEADER_PATH']]

#----------------------------------------------------------------------------
# App core Objects
#----------------------------------------------------------------------------
sources = [
        env.Glob('../src/*.c'),
        '../../tz_mpos_common/tl/tz_mpos_common_tl.c',
        '../../../../tz_iccc_common/tl/tz_iccc_common_tl.c',
]
sources.append('../layouts/src/layout_1440x2560.c')

#----------------------------------------------------------------------------
# libstd Objects
#----------------------------------------------------------------------------
sources += Glob ('../libstd/*.c')

#-------------------------------------------------------------------------------
# Add Libraries to image
#-------------------------------------------------------------------------------
libs = env.File(SCRYPTO_LIB.split())

libca = env.SubstRealPath('${MUSL32PATH}/lib/libc.a')
libs.append(env.File(libca))

tui_libs = [
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureUILib/lib/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureUI/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/log/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureDisplay/libgd/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureDisplay/libpng/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureDisplay/zlib/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureTouch/drTs/lib/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/SecureTouch/layout/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/SecureTouch/controller/build/SConscript', exports='env'),
  env.SConscript('${BUILD_ROOT}/ssg/securemsm/sse/qsee/SecureTouch/drTs/controller/build/SConscript', exports='env'),
]

#------------------------------------------------------------------------------
# Add build option to deterministic build
#------------------------------------------------------------------------------
if os.getenv('SUPPORT_NEW_TA_BUILD', 'false') == 'true':
  env.Append(LINKFLAGS=' -no-threads ')

#------------------------------------------------------------------------------
# Add command to Imprint HMAC
#------------------------------------------------------------------------------
MPOS_TUI_ELF_PATH = env.subst('${OUT_DIR}/' + '${SHORT_BUILDPATH}/' + "mpostui.elf")
MPOS_TUI_RUN_FIPS_TOOLS_COMMAND =  os.environ['TZ_SCRYPTO_TOOLS_IMPRINT'] + " " + MPOS_TUI_ELF_PATH
MPOS_TUI_LOGD("MPOS_TUI_RUN_FIPS_TOOLS_COMMAND:" + MPOS_TUI_RUN_FIPS_TOOLS_COMMAND)
env.Append(LINKCOM = " && ")
env.Append(LINKCOM = MPOS_TUI_RUN_FIPS_TOOLS_COMMAND)

#-------------------------------------------------------------------------------
# Add metadata to image
#-------------------------------------------------------------------------------
if env['CHIPSET'] == 'sdm670':
  env.Append(CPPDEFINES = ["SDM670"])
  md = {
   'appName':    app_name,
   'privileges': ['default',
                  'System',
                  'I2C',
                  'SecureDisplay',
                  'AppMessage',
                  'OEMBuf',
                  'HwFuse',
                  'AccessControl',
                  'MPOS',
                 ],
  'stackSize': 0x40000,
  'heapSize': 0x200000,
  }
else:
  md = {
   'appName':    app_name,
   'privileges': ['default',
                  'WhitelistBypass',
                  'OEMBuf', 'WhitelistBypass' # to use ICCC feature
                 ],
  'heapSize': 0x10000,
  }

deploy_header_files = env.Glob('../inc/*')

mpostui_units = env.SecureAppBuilder(
  sources = sources,
  includes = includes,
  metadata = md,
  image = target_name,
  user_libs = [ libs, tui_libs ], 
  deploy_sources = [sources,
                    'SConscript',
                    env.Glob('../libstd/*.h'),
                    deploy_header_files]
)

if hasattr(env, 'IMAGE_ALIASES'):
  for image in env['IMAGE_ALIASES']:
    env.Alias(image, mpostui_units)
else:
  env.Alias(aliases, mpostui_units)
