control flow cleanup

This commit is contained in:
Lotte Steenbrink 2020-06-19 11:22:56 +02:00
parent 3fac13606e
commit b65b432762

View file

@ -192,29 +192,30 @@ fn notmain() -> Result<i32, anyhow::Error> {
// run // run
let core = Rc::new(core); let core = Rc::new(core);
let mut num_retries = 5; let rtt_addr_result = rtt_addr.ok_or_else(|| anyhow!("RTT control block not available"))?;
let mut rtt: Result<Rtt, probe_rs_rtt::Error>; let mut rtt: Result<Rtt, probe_rs_rtt::Error>;
let mut num_retries = 3; // picked at random, increase if necessary
loop { loop {
rtt = Rtt::attach_region( rtt = Rtt::attach_region(
core.clone(), core.clone(),
&sess, &sess,
&ScanRegion::Exact(rtt_addr.ok_or_else(|| anyhow!("RTT control block not available"))?), // todo only do this once? &ScanRegion::Exact(rtt_addr_result),
); );
// todo clean up control flow match rtt {
if rtt.is_ok() { Ok(_) => { break; }
log::info!("Successfully attached RTT"); Err(res) => {
break;
}
num_retries -= 1; num_retries -= 1;
if num_retries == 0 { if num_retries == 0 {
break; log::info!("Max number of retries exceeded. Giving up.");
return Err(anyhow!(res));
} }
log::info!("Attaching RTT failed. retrying"); log::info!("Attaching RTT failed. retrying");
} }
}
}
log::info!("Successfully attached RTT");
let channel = rtt let channel = rtt
.unwrap() // using ? instead wouldn't show the user any helpful error message .unwrap() // using ? instead wouldn't show the user any helpful error message