2
0
mirror of https://github.com/m-labs/artiq.git synced 2025-01-28 03:10:19 +08:00

runtime mgmt: avoid passing incomplete message to corelog

This commit is contained in:
occheung 2024-09-19 17:42:03 +08:00
parent 28654501af
commit 6b6bcdb6d6

View File

@ -269,14 +269,20 @@ mod remote_coremgmt {
ddma_mutex: &Mutex, subkernel_mutex: &Mutex, ddma_mutex: &Mutex, subkernel_mutex: &Mutex,
routing_table: &RoutingTable, linkno: u8, routing_table: &RoutingTable, linkno: u8,
destination: u8, stream: &mut TcpStream) -> Result<(), Error<SchedError>> { destination: u8, stream: &mut TcpStream) -> Result<(), Error<SchedError>> {
let mut buffer = Vec::new();
loop { loop {
let reply = drtio::aux_transact(io, aux_mutex, ddma_mutex, subkernel_mutex, routing_table, linkno, let reply = drtio::aux_transact(io, aux_mutex, ddma_mutex, subkernel_mutex, routing_table, linkno,
&Packet::CoreMgmtGetLogRequest { destination, clear: true } &Packet::CoreMgmtGetLogRequest { destination, clear: true }
); );
match reply { match reply {
Ok(Packet::CoreMgmtGetLogReply { last: _, length, data }) => { Ok(Packet::CoreMgmtGetLogReply { last, length, data }) => {
stream.write_bytes(&data[..length as usize])?; buffer.extend(&data[..length as usize]);
if last {
stream.write_bytes(&buffer[..length as usize])?;
buffer.clear();
}
} }
Ok(packet) => { Ok(packet) => {
error!("received unexpected aux packet: {:?}", packet); error!("received unexpected aux packet: {:?}", packet);