import os
Import ( ' env ' , ' arch ' , ' cereal ' , ' messaging ' , ' common ' , ' gpucommon ' , ' visionipc ' , ' transformations ' )
lenv = env . Clone ( )
libs = [ cereal , messaging , common , visionipc , gpucommon ,
' OpenCL ' , ' SNPE ' , ' capnp ' , ' zmq ' , ' kj ' , ' yuv ' ]
def get_dlsym_offset ( ) :
""" Returns the offset between dlopen and dlsym in libdl.so """
import ctypes
libdl = ctypes . PyDLL ( ' libdl.so ' )
dlopen = ctypes . cast ( libdl . dlopen , ctypes . c_void_p ) . value
dlsym = ctypes . cast ( libdl . dlsym , ctypes . c_void_p ) . value
return dlsym - dlopen
common_src = [
" models/commonmodel.cc " ,
" runners/snpemodel.cc " ,
" transforms/loadyuv.cc " ,
" transforms/transform.cc "
]
thneed_src = [
" thneed/thneed_common.cc " ,
" thneed/thneed_qcom2.cc " ,
" thneed/serialize.cc " ,
" runners/thneedmodel.cc " ,
]
use_thneed = not GetOption ( ' no_thneed ' )
if arch == " larch64 " :
libs + = [ ' gsl ' , ' CB ' , ' pthread ' , ' dl ' ]
if use_thneed :
common_src + = thneed_src
dlsym_offset = get_dlsym_offset ( )
lenv [ ' CXXFLAGS ' ] . append ( " -DUSE_THNEED " )
lenv [ ' CXXFLAGS ' ] . append ( f " -DDLSYM_OFFSET= { dlsym_offset } " )
else :
libs + = [ ' pthread ' ]
if not GetOption ( ' snpe ' ) :
# for onnx support
common_src + = [ ' runners/onnxmodel.cc ' ]
# tell runners to use onnx
lenv [ ' CFLAGS ' ] . append ( " -DUSE_ONNX_MODEL " )
lenv [ ' CXXFLAGS ' ] . append ( " -DUSE_ONNX_MODEL " )
if arch == " Darwin " :
# fix OpenCL
del libs [ libs . index ( ' OpenCL ' ) ]
lenv [ ' FRAMEWORKS ' ] = [ ' OpenCL ' ]
if arch == " Darwin " or arch == " aarch64 " :
# no SNPE on Mac and ARM Linux
del libs [ libs . index ( ' SNPE ' ) ]
del common_src [ common_src . index ( ' runners/snpemodel.cc ' ) ]
onnxrunner_path = File ( " runners/onnx_runner.py " ) . abspath
transform_path = File ( " transforms/transform.cl " ) . abspath
loadyuv_path = File ( " transforms/loadyuv.cl " ) . abspath
lenv [ ' CXXFLAGS ' ] . append ( f ' -DTRANSFORM_PATH= \\ " { transform_path } \\ " ' )
lenv [ ' CXXFLAGS ' ] . append ( f ' -DLOADYUV_PATH= \\ " { loadyuv_path } \\ " ' )
lenv [ ' CXXFLAGS ' ] . append ( f ' -DONNXRUNNER_PATH= \\ " { onnxrunner_path } \\ " ' )
common_model = lenv . Object ( common_src )
lenv . Program ( ' _dmonitoringmodeld ' , [
" dmonitoringmodeld.cc " ,
" models/dmonitoring.cc " ,
] + common_model , LIBS = libs )
# build thneed model
if use_thneed and arch == " larch64 " or GetOption ( ' pc_thneed ' ) :
fn = File ( " models/supercombo " ) . abspath
tinygrad_opts = [ " NATIVE_EXPLOG=1 " , " VALIDHACKS=1 " , " OPTLOCAL=1 " , " IMAGE=2 " , " GPU=1 " , " ENABLE_METHOD_CACHE=1 " ]
if not GetOption ( ' pc_thneed ' ) :
# use FLOAT16 on device for speed + don't cache the CL kernels for space
tinygrad_opts + = [ " FLOAT16=1 " , " PYOPENCL_NO_CACHE=1 " ]
cmd = f " cd { Dir ( ' # ' ) . abspath } /tinygrad_repo && " + ' ' . join ( tinygrad_opts ) + f " python3 openpilot/compile.py { fn } .onnx { fn } .thneed "
tinygrad_files = sum ( [ lenv . Glob ( " # " + x ) for x in open ( File ( " #release/files_common " ) . abspath ) . read ( ) . split ( " \n " ) if x . startswith ( " tinygrad_repo/ " ) ] , [ ] )
lenv . Command ( fn + " .thneed " , [ fn + " .onnx " ] + tinygrad_files , cmd )
llenv = lenv . Clone ( )
if GetOption ( ' pc_thneed ' ) :
pc_thneed_src = [
" thneed/thneed_common.cc " ,
" thneed/thneed_pc.cc " ,
" thneed/serialize.cc " ,
" runners/thneedmodel.cc " ,
]
llenv [ ' CFLAGS ' ] . append ( " -DUSE_THNEED " )
llenv [ ' CXXFLAGS ' ] . append ( " -DUSE_THNEED " )
common_model + = llenv . Object ( pc_thneed_src )
libs + = [ ' dl ' ]
llenv . Program ( ' _modeld ' , [
" modeld.cc " ,
" models/driving.cc " ,
] + common_model , LIBS = libs + transformations )
lenv . Program ( ' _navmodeld ' , [
" navmodeld.cc " ,
" models/nav.cc " ,
] + common_model , LIBS = libs + transformations )