diff --git a/components/utilities/logtrace/log_trace.c b/components/utilities/logtrace/log_trace.c index cc55b1dd44faf751054dc441c56282aebd68f477..1d0a42725e47695061a3565d9b8d71db19f43e55 100644 --- a/components/utilities/logtrace/log_trace.c +++ b/components/utilities/logtrace/log_trace.c @@ -93,6 +93,9 @@ static struct log_trace_session* _lg_lookup_session(log_trace_idnum_t num) last = _the_sess_nr; do { unsigned int i = (first + last)/2; + + RT_ASSERT(_the_sessions[i]); + if (_the_sessions[i]->id.num == num) { /* there is no need to protect the _cache because write a pointer @@ -135,7 +138,8 @@ rt_err_t log_trace_register_session(struct log_trace_session *session) { if (_the_sessions[i]->id.num > session->id.num) { - rt_memmove(_the_sessions+i, _the_sessions+i+1, _the_sess_nr-i); + rt_memmove(_the_sessions+i+1, _the_sessions+i, + (_the_sess_nr-i)*sizeof(&_the_sessions[0])); _the_sessions[i] = session; break; }