diff --git a/opendbc_repo b/opendbc_repo index fd8471dc0d6fbd..9556fcf55a1891 160000 --- a/opendbc_repo +++ b/opendbc_repo @@ -1 +1 @@ -Subproject commit fd8471dc0d6fbd7ae009ab6d75036667c5b576a5 +Subproject commit 9556fcf55a189175ff779be96d33df51bf13cef4 diff --git a/selfdrive/pandad/pandad_api_impl.pyx b/selfdrive/pandad/pandad_api_impl.pyx index 787968f53e7db3..2a97e5952b629a 100644 --- a/selfdrive/pandad/pandad_api_impl.pyx +++ b/selfdrive/pandad/pandad_api_impl.pyx @@ -4,7 +4,7 @@ from cython.operator cimport dereference as deref, preincrement as preinc from libcpp.vector cimport vector from libcpp.string cimport string from libcpp cimport bool -from libc.stdint cimport uint8_t, uint32_t, uint64_t +from libc.stdint cimport uint8_t, uint32_t, uint64_t, uintptr_t cdef extern from "panda.h": cdef struct can_frame: @@ -41,16 +41,21 @@ def can_list_to_can_capnp(can_msgs, msgtype='can', valid=True): can_list_to_can_capnp_cpp(can_list, out, msgtype == 'sendcan', valid) return out + +cdef class ParsedCanData: + cdef vector[CanData] *data + + def __cinit__(self): + self.data = new vector[CanData]() + + def __dealloc__(self): + del self.data + + def get_data_pointer(self): + return self.data + + def can_capnp_to_list(strings, msgtype='can'): - cdef vector[CanData] data - can_capnp_to_can_list_cpp(strings, data, msgtype == 'sendcan') - - result = [] - cdef CanData *d - cdef vector[CanData].iterator it = data.begin() - while it != data.end(): - d = &deref(it) - frames = [(f.address, (&f.dat[0])[:f.dat.size()], f.src) for f in d.frames] - result.append((d.nanos, frames)) - preinc(it) + cdef ParsedCanData result = ParsedCanData() + can_capnp_to_can_list_cpp(strings, result.data[0], msgtype == 'sendcan') return result