#-------------------------------------------------------------------------------
# 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}/ssg/bsp/trustzone/qsapps/mpostui/build')
  env.Replace(LIB_OUT_DIR = '${BUILD_ROOT}/ssg/bsp/trustzone/qsapps/mpostui/build/${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",
])

env.RequirePrivateApi('SECUREMSM')

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/uclib/usr/legacy/secrsa/shared/inc',
          '#../../ssg/securemsm/uclib/usr/legacy/secrsa/shared/src',
          '#../../ssg/securemsm/uclib/usr/legacy/secmath/shared/inc',
          '#../../ssg/api/securemsm/trustzone/gp',
       #  '#../../ssg/securemsm/trustzone/qsapps/libs/applib/common_applib/inc',	// ssg/bsp/trustzone/qsapps/commonlib/build/YAQAANAA/scorpion/
       #  '#../../ssg/securemsm/trustzone/qsapps/libs/applib/applib/qsee/src',		// ssg/bsp/trustzone/qsapps/applib/build/YAQAANAA/scorpion/
       #  '#../../ssg/securemsm/trustzone/qsapps/libs/biometric/inc',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/log/inc',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/common/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/common/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/layout/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/controller/inc',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureUI/inc',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureUILib/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/drTs/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureDisplay/libgd/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/SecureDisplay/libpng/include',
          '#../../apps/securemsm/trustzone/qsapps/secuilib/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_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 = [
        '../src/process_cmd.c',
        '../src/vendor_interface.c',
        '../src/TuiPinpadScreen.c',
        '../src/TuiPinpadState.c',
        '../src/TuiLayout.c',
        '../src/TuiScreenProperty.c',
        '../src/app_main.c',
        '../src/tui_vendor.c',
        '../src/tui_vendor_impl.c',
        '../src/QSEE_TZ_Vendor.c',
        '../src/layout_1440x2560.c',
        '../../tz_mpos_common/tl/tz_mpos_common_tl.c',
        '../../../../tz_iccc_common/tl/tz_iccc_common_tl.c',
]

#-------------------------------------------------------------------------------
# Add Libraries to image
#-------------------------------------------------------------------------------
libs = env.File(SCRYPTO_LIB.split())

if env['PROC'] == 'scorpion':
  libca = env.SubstRealPath('${MUSL32PATH}/lib/libc.a')
else:
  libca = env.SubstRealPath('${MUSLPATH}/lib/libc.a')

libs.append(env.File(libca))

tui_libs = []
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/secure_ui_lib/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/secure_ui_lib.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/secure_ui/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/secure_ui.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/secure_ui_tui/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/secure_ui_tui.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/sselog/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/sselog.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/libgd/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/libgd.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/libpng/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/libpng.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/zlib/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/zlib.lib')
tui_libs.append('${BUILD_ROOT}/../qtee_tas/apps/bsp/trustzone/qsapps/sklayout/secure_ui_sample/${PROC}/${SHORT_BUILDPATH}/sklayout.lib')

tui_libs.append(env.SConscript('${BUILD_ROOT}/apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/drTs/lib/build/SConscript', exports='env'))
tui_libs.append(env.SConscript('${BUILD_ROOT}/apps/securemsm/trustzone/qsapps/secuilib/SecureTouch/controller/build/SConscript', exports='env'))
tui_libs.append(env.SConscript('${BUILD_ROOT}/apps/securemsm/trustzone/qsapps/secuilib/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}/' + "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'] == 'lahaina':
  env.Append(CPPDEFINES = ["SM8350"])
  md = {
   'appName':    app_name,
   'privileges': ['default',
                  'System',
                  'I2C',
                  'KMHAL',
                  'SecureDisplay',
                  'AppMessage',
                  'OEMBuf',
                  'HwFuse',
                  'PFM',
                  'AccessControl',
                  'MPOS',
                  'ICCCGetDeviceStatus',
                  'ICCCSaveData',
                  'ICCCReadData',
                 ],
  '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'] + 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)
