You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							114 lines
						
					
					
						
							3.4 KiB
						
					
					
				
			
		
		
	
	
							114 lines
						
					
					
						
							3.4 KiB
						
					
					
				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']
 | 
						|
 | 
						|
    # no SNPE on Mac
 | 
						|
    del libs[libs.index('SNPE')]
 | 
						|
    del common_src[common_src.index('runners/snpemodel.cc')]
 | 
						|
 | 
						|
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
 | 
						|
 | 
						|
  if GetOption('pc_thneed'):
 | 
						|
    cmd = f"cd {Dir('#').abspath}/tinygrad_repo && GPU=1 NATIVE_EXPLOG=1 OPTWG=1 UNSAFE_FLOAT4=1 DEBUGCL=1 python3 openpilot/compile.py {fn}.onnx {fn}.thneed"
 | 
						|
  else:
 | 
						|
    cmd = f"cd {Dir('#').abspath}/tinygrad_repo && FLOAT16=1 MATMUL=1 PYOPENCL_NO_CACHE=1 NATIVE_EXPLOG=1 OPTWG=1 UNSAFE_FLOAT4=1 DEBUGCL=1 python3 openpilot/compile.py {fn}.onnx {fn}.thneed"
 | 
						|
 | 
						|
  # is there a better way then listing all of tinygrad?
 | 
						|
  lenv.Command(fn + ".thneed", [fn + ".onnx",
 | 
						|
    "#tinygrad_repo/openpilot/compile.py",
 | 
						|
    "#tinygrad_repo/accel/opencl/conv.cl",
 | 
						|
    "#tinygrad_repo/accel/opencl/matmul.cl",
 | 
						|
    "#tinygrad_repo/accel/opencl/ops_opencl.py",
 | 
						|
    "#tinygrad_repo/accel/opencl/preprocessing.py",
 | 
						|
    "#tinygrad_repo/extra/onnx.py",
 | 
						|
    "#tinygrad_repo/extra/thneed.py",
 | 
						|
    "#tinygrad_repo/extra/utils.py",
 | 
						|
    "#tinygrad_repo/tinygrad/llops/ops_gpu.py",
 | 
						|
    "#tinygrad_repo/tinygrad/llops/ops_opencl.py",
 | 
						|
    "#tinygrad_repo/tinygrad/helpers.py",
 | 
						|
    "#tinygrad_repo/tinygrad/mlops.py",
 | 
						|
    "#tinygrad_repo/tinygrad/ops.py",
 | 
						|
    "#tinygrad_repo/tinygrad/shapetracker.py",
 | 
						|
    "#tinygrad_repo/tinygrad/tensor.py",
 | 
						|
    "#tinygrad_repo/tinygrad/nn/__init__.py"
 | 
						|
  ], 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)
 | 
						|
 |