1
0
forked from M-Labs/artiq

firmware: fix crash on exception with host message (#2017)

This commit is contained in:
Egor Savkin 2022-12-07 10:41:43 +08:00 committed by GitHub
parent 3c7a394eff
commit 454ae39c5d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -452,7 +452,10 @@ fn process_kern_message(io: &Io, aux_mutex: &Mutex,
let exceptions_with_channel: Vec<Option<eh::eh_artiq::Exception>> = exceptions.iter() let exceptions_with_channel: Vec<Option<eh::eh_artiq::Exception>> = exceptions.iter()
.map(|exception| { .map(|exception| {
if let Some(exn) = exception { if let Some(exn) = exception {
let msg = str::from_utf8(unsafe{slice::from_raw_parts(exn.message.as_ptr(), exn.message.len())}) if exn.message.len() == usize::MAX { // host string
Some(exn.clone())
} else {
let msg = str::from_utf8(unsafe { slice::from_raw_parts(exn.message.as_ptr(), exn.message.len()) })
.unwrap() .unwrap()
.replace("{rtio_channel_info:0}", &format!("{}:{}", exn.param[0], resolve_channel_name(exn.param[0] as u32))); .replace("{rtio_channel_info:0}", &format!("{}:{}", exn.param[0], resolve_channel_name(exn.param[0] as u32)));
Some(eh::eh_artiq::Exception { Some(eh::eh_artiq::Exception {
@ -461,9 +464,10 @@ fn process_kern_message(io: &Io, aux_mutex: &Mutex,
line: exn.line, line: exn.line,
column: exn.column, column: exn.column,
function: exn.function, function: exn.function,
message: unsafe {CSlice::new(msg.as_ptr(), msg.len())}, message: unsafe { CSlice::new(msg.as_ptr(), msg.len()) },
param: exn.param param: exn.param,
}) })
}
} else { None } } else { None }
}) })
.collect(); .collect();