Fixed gap write handling when additional reads are required

pull/7/head
ko1N 3 years ago
parent 80de329158
commit 1f77842086

@ -308,17 +308,25 @@ impl PhysicalMemory for PciLeech {
// dispatch necessary reads to fill the gaps // dispatch necessary reads to fill the gaps
if !gaps.is_empty() { if !gaps.is_empty() {
let iter = gaps.iter().map(|g| { let mut vec = gaps
MemData( .iter()
g.gap_addr, .map(|g| {
unsafe { slice::from_raw_parts_mut(g.gap_buffer, g.gap_buffer_len) }.into(), MemData(
) g.gap_addr,
}); unsafe { slice::from_raw_parts_mut(g.gap_buffer, g.gap_buffer_len) }.into(),
)
})
.collect::<Vec<_>>();
let mut iter = vec
.iter_mut()
.map(|MemData(a, d): &mut PhysicalReadData| MemData(*a, d.into()));
let out_fail = &mut |_| true; let out_fail = &mut |_| true;
self.phys_read_raw_iter((&mut iter.clone()).into(), &mut out_fail.into())?;
for (gap, mut read) in gaps.iter().zip(iter) { self.phys_read_raw_iter((&mut iter).into(), &mut out_fail.into())?;
for (gap, mut read) in gaps.iter().zip(vec) {
let in_buffer = let in_buffer =
unsafe { slice::from_raw_parts(gap.in_buffer, gap.in_end - gap.in_start) }; unsafe { slice::from_raw_parts(gap.in_buffer, gap.in_end - gap.in_start) };
read.1[gap.in_start..gap.in_end].copy_from_slice(in_buffer); read.1[gap.in_start..gap.in_end].copy_from_slice(in_buffer);

Loading…
Cancel
Save