X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=resource%2Fcsdk%2Fsecurity%2FSConscript;h=964cdd14b875dc2440694b3d4a3194803a325645;hb=c315c87e07c4080ecd0ef488e7a1047bc3c509b2;hp=f5d26169cc799ec0483bdd635a0d23e6a323f943;hpb=19d62d6a8a53f556e3a91ef9b4f63c3e5f89c1b9;p=platform%2Fupstream%2Fiotivity.git diff --git a/resource/csdk/security/SConscript b/resource/csdk/security/SConscript index f5d2616..964cdd1 100644 --- a/resource/csdk/security/SConscript +++ b/resource/csdk/security/SConscript @@ -22,31 +22,38 @@ ## Import('env') +import os lib_env = env.Clone() -SConscript(env.get('SRC_DIR') + '/resource/third_party_libs.scons', 'lib_env') +SConscript('#resource/third_party_libs.scons', 'lib_env') libocsrm_env = lib_env.Clone() -target_os = env.get('TARGET_OS') +target_os = libocsrm_env.get('TARGET_OS') # As in the source code, it includes arduino Time library (C++) # It requires compile the .c with g++ if target_os == 'arduino': - libocsrm_env.Replace(CC = env.get('CXX')) - libocsrm_env.Replace(CFLAGS = env.get('CXXFLAGS')) + libocsrm_env.Replace(CC = libocsrm_env.get('CXX')) + libocsrm_env.Replace(CFLAGS = libocsrm_env.get('CXXFLAGS')) ###################################################################### # Build flags ###################################################################### +with_upstream_libcoap = libocsrm_env.get('WITH_UPSTREAM_LIBCOAP') +if with_upstream_libcoap == '1': + # For bring up purposes only, we manually copy the forked version to where the unforked version is downloaded. + libocsrm_env.AppendUnique(CPPPATH = ['#extlibs/libcoap/libcoap/include']) +else: + # For bring up purposes only, the forked version will live here. + libocsrm_env.AppendUnique(CPPPATH = ['../connectivity/lib/libcoap-4.1.1/include']) + libocsrm_env.PrependUnique(CPPPATH = [ '../../../extlibs/cjson/', - '../../../extlibs/tinydtls/', '../logger/include', '../../c_common/ocrandom/include', '../stack/include', '../stack/include/internal', '../../oc_logger/include', - '../connectivity/lib/libcoap-4.1.1', '../connectivity/external/inc', '../connectivity/common/inc', '../connectivity/inc', @@ -56,95 +63,86 @@ libocsrm_env.PrependUnique(CPPPATH = [ '../security/provisioning/include' ]) -if target_os not in ['arduino', 'windows', 'winrt']: - libocsrm_env.AppendUnique(CPPDEFINES = ['WITH_POSIX']) - libocsrm_env.AppendUnique(CFLAGS = ['-std=c99']) - libocsrm_env.AppendUnique(CPPDEFINES = ['HAVE_STRINGS_H']) - -if target_os not in ['windows', 'winrt']: - libocsrm_env.AppendUnique(CFLAGS = ['-Wall']) +if target_os not in ['arduino', 'windows']: + libocsrm_env.AppendUnique(CPPDEFINES = ['WITH_POSIX', '_GNU_SOURCE']) + libocsrm_env.AppendUnique(CFLAGS = ['-std=c99', '-Wall']) -libocsrm_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')]) -libocsrm_env.AppendUnique(LIBS = ['coap', 'm']) +libocsrm_env.AppendUnique(LIBPATH = [libocsrm_env.get('BUILD_DIR')]) +libocsrm_env.AppendUnique(LIBS = ['coap']) if target_os == 'arduino': libocsrm_env.AppendUnique(CPPDEFINES = ['NDEBUG', 'WITH_ARDUINO']) -else: +elif target_os not in ['windows', 'msys_nt']: libocsrm_env.AppendUnique(CFLAGS = ['-fPIC']) + libocsrm_env.AppendUnique(LIBS = ['m']) + +if target_os in ['windows', 'msys_nt']: + libocsrm_env.AppendUnique(LIBPATH = [os.path.join(libocsrm_env.get('BUILD_DIR'), 'resource', 'oc_logger')]) if target_os in ['darwin', 'ios']: libocsrm_env.AppendUnique(CPPDEFINES = ['_DARWIN_C_SOURCE']) - libocsrm_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')]) + libocsrm_env.AppendUnique(LIBPATH = [libocsrm_env.get('BUILD_DIR')]) libocsrm_env.AppendUnique(LIBS = ['coap']) -if not env.get('RELEASE'): +if env.get('LOGGING'): libocsrm_env.AppendUnique(CPPDEFINES = ['TB_LOG']) -if env.get('DTLS_WITH_X509') == '1': - libocsrm_env.AppendUnique(CPPDEFINES = ['__WITH_X509__']) +if env.get('MULTIPLE_OWNER') == '1': + libocsrm_env.AppendUnique(CPPDEFINES=['MULTIPLE_OWNER']) ###################################################################### # Source files and Targets ###################################################################### OCSRM_SRC = 'src/' -if env.get('SECURED') == '1': - libocsrm_src = [ - OCSRM_SRC + 'secureresourcemanager.c', - OCSRM_SRC + 'resourcemanager.c', - OCSRM_SRC + 'aclresource.c', - OCSRM_SRC + 'amaclresource.c', - OCSRM_SRC + 'amsmgr.c', - OCSRM_SRC + 'pstatresource.c', - OCSRM_SRC + 'doxmresource.c', - OCSRM_SRC + 'credresource.c', - OCSRM_SRC + 'svcresource.c', - OCSRM_SRC + 'pconfresource.c', - OCSRM_SRC + 'dpairingresource.c', - OCSRM_SRC + 'policyengine.c', - OCSRM_SRC + 'psinterface.c', - OCSRM_SRC + 'srmresourcestrings.c', - OCSRM_SRC + 'srmutility.c', - OCSRM_SRC + 'iotvticalendar.c', - OCSRM_SRC + 'oxmpincommon.c', - OCSRM_SRC + 'base64.c', - #pbkdf2.c is required to PIN based OxM only. - #But we did not use a separate build options to prevent the build command becomes complicated. - OCSRM_SRC + 'pbkdf2.c', - OCSRM_SRC + 'directpairing.c' - ] -else: - libocsrm_src = [ - OCSRM_SRC + 'secureresourcemanager.c', - OCSRM_SRC + 'resourcemanager.c', - OCSRM_SRC + 'aclresource.c', - OCSRM_SRC + 'amaclresource.c', - OCSRM_SRC + 'amsmgr.c', - OCSRM_SRC + 'pstatresource.c', - OCSRM_SRC + 'doxmresource.c', - OCSRM_SRC + 'credresource.c', - OCSRM_SRC + 'svcresource.c', - OCSRM_SRC + 'pconfresource.c', - OCSRM_SRC + 'dpairingresource.c', - OCSRM_SRC + 'policyengine.c', - OCSRM_SRC + 'psinterface.c', - OCSRM_SRC + 'srmresourcestrings.c', - OCSRM_SRC + 'srmutility.c', - OCSRM_SRC + 'iotvticalendar.c', - OCSRM_SRC + 'base64.c', - OCSRM_SRC + 'directpairing.c' - ] - -if env.get('DTLS_WITH_X509') == '1' and env.get('SECURED') == '1': - crl_src = [OCSRM_SRC + 'crlresource.c'] - libocsrm_src = libocsrm_src + crl_src - - -libocsrm = libocsrm_env.StaticLibrary('libocsrm', libocsrm_src) - -libocsrm_env.InstallTarget(libocsrm, 'libocsrm') - -if target_os in ['linux', 'android', 'tizen'] and env.get('SECURED') == '1': +libocsrm_src = [ + OCSRM_SRC + 'secureresourcemanager.c', + OCSRM_SRC + 'resourcemanager.c', + OCSRM_SRC + 'aclresource.c', + OCSRM_SRC + 'verresource.c', + OCSRM_SRC + 'amaclresource.c', + OCSRM_SRC + 'amsmgr.c', + OCSRM_SRC + 'pstatresource.c', + OCSRM_SRC + 'doxmresource.c', + OCSRM_SRC + 'credresource.c', + OCSRM_SRC + 'pconfresource.c', + OCSRM_SRC + 'dpairingresource.c', + OCSRM_SRC + 'policyengine.c', + OCSRM_SRC + 'psinterface.c', + OCSRM_SRC + 'srmresourcestrings.c', + OCSRM_SRC + 'srmutility.c', + OCSRM_SRC + 'iotvticalendar.c', + OCSRM_SRC + 'base64.c', + OCSRM_SRC + 'directpairing.c' + ] + +if libocsrm_env.get('SECURED') == '1': + libocsrm_src = libocsrm_src + [OCSRM_SRC + 'oxmpincommon.c', OCSRM_SRC + 'pbkdf2.c'] + libocsrm_src = libocsrm_src + [OCSRM_SRC + 'crlresource.c', OCSRM_SRC + 'pkix_interface.c'] + libocsrm_src = libocsrm_src + [OCSRM_SRC + 'oxmverifycommon.c'] + libocsrm_src = libocsrm_src + [OCSRM_SRC + 'psiutils.c'] # TODO : need for secure psi + +if target_os in ['windows', 'msys_nt']: + libocsrm_src = libocsrm_src + [OCSRM_SRC + 'strptime.c'] + + +libocsrm_src.extend(env['cbor_files']) + +# Insert a hack for Arduino, whose compiler may not support all defines expected +# by tinycbor +if target_os in ['arduino']: + libocsrm_env.AppendUnique(CPPDEFINES = ['INT64_MAX=0x7FFFFFFFFFFFFFFF']) + +libocsrm_conf = Configure(libocsrm_env) +if libocsrm_conf.CheckFunc('strptime'): + libocsrm_conf.env.AppendUnique(CPPDEFINES = ['HAVE_STRPTIME']) +libocsrm_env = libocsrm_conf.Finish() + +libocsrm = libocsrm_env.StaticLibrary('ocsrm', libocsrm_src) + +libocsrm_env.InstallTarget(libocsrm, 'ocsrm') + +if target_os in ['linux', 'android', 'tizen', 'msys_nt', 'windows', 'ios'] and libocsrm_env.get('SECURED') == '1': SConscript('provisioning/SConscript') -if target_os in ['linux'] and env.get('SECURED') == '1': +if target_os in ['linux'] and libocsrm_env.get('SECURED') == '1': SConscript('tool/SConscript')