Fix unaligned buffer in async updater
This commit is contained in:
parent
edb3989b57
commit
d77b6a60d2
1 changed files with 14 additions and 5 deletions
|
@ -276,16 +276,25 @@ impl<'d, STATE: NorFlash> FirmwareState<'d, STATE> {
|
||||||
async fn set_magic(&mut self, magic: u8) -> Result<(), FirmwareUpdaterError> {
|
async fn set_magic(&mut self, magic: u8) -> Result<(), FirmwareUpdaterError> {
|
||||||
self.state.read(0, &mut self.aligned).await?;
|
self.state.read(0, &mut self.aligned).await?;
|
||||||
|
|
||||||
if self.aligned.iter().any(|&b| b != magic) {
|
if self.aligned[..STATE::WRITE_SIZE].iter().any(|&b| b != magic) {
|
||||||
// Read progress validity
|
// Read progress validity
|
||||||
|
if STATE::READ_SIZE <= 2 * STATE::WRITE_SIZE {
|
||||||
self.state.read(STATE::WRITE_SIZE as u32, &mut self.aligned).await?;
|
self.state.read(STATE::WRITE_SIZE as u32, &mut self.aligned).await?;
|
||||||
|
} else {
|
||||||
|
self.aligned.rotate_left(STATE::WRITE_SIZE);
|
||||||
|
}
|
||||||
|
|
||||||
if self.aligned.iter().any(|&b| b != STATE_ERASE_VALUE) {
|
if self.aligned[..STATE::WRITE_SIZE]
|
||||||
|
.iter()
|
||||||
|
.any(|&b| b != STATE_ERASE_VALUE)
|
||||||
|
{
|
||||||
// The current progress validity marker is invalid
|
// The current progress validity marker is invalid
|
||||||
} else {
|
} else {
|
||||||
// Invalidate progress
|
// Invalidate progress
|
||||||
self.aligned.fill(!STATE_ERASE_VALUE);
|
self.aligned.fill(!STATE_ERASE_VALUE);
|
||||||
self.state.write(STATE::WRITE_SIZE as u32, &self.aligned).await?;
|
self.state
|
||||||
|
.write(STATE::WRITE_SIZE as u32, &self.aligned[..STATE::WRITE_SIZE])
|
||||||
|
.await?;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clear magic and progress
|
// Clear magic and progress
|
||||||
|
@ -293,7 +302,7 @@ impl<'d, STATE: NorFlash> FirmwareState<'d, STATE> {
|
||||||
|
|
||||||
// Set magic
|
// Set magic
|
||||||
self.aligned.fill(magic);
|
self.aligned.fill(magic);
|
||||||
self.state.write(0, &self.aligned).await?;
|
self.state.write(0, &self.aligned[..STATE::WRITE_SIZE]).await?;
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue