Don't load the same allocation twice when reading a scalar pair from it

This commit is contained in:
Oliver Scherer 2020-04-14 18:05:47 +02:00
parent ba72b15666
commit 2b25c0cd81

View File

@ -242,13 +242,11 @@ fn try_read_immediate_from_mplace(
} }
}; };
let alloc = self.memory.get_raw(ptr.alloc_id)?;
match mplace.layout.abi { match mplace.layout.abi {
Abi::Scalar(..) => { Abi::Scalar(..) => {
let scalar = self.memory.get_raw(ptr.alloc_id)?.read_scalar( let scalar = alloc.read_scalar(self, ptr, mplace.layout.size)?;
self,
ptr,
mplace.layout.size,
)?;
Ok(Some(ImmTy { imm: scalar.into(), layout: mplace.layout })) Ok(Some(ImmTy { imm: scalar.into(), layout: mplace.layout }))
} }
Abi::ScalarPair(ref a, ref b) => { Abi::ScalarPair(ref a, ref b) => {
@ -261,8 +259,8 @@ fn try_read_immediate_from_mplace(
let b_offset = a_size.align_to(b.align(self).abi); let b_offset = a_size.align_to(b.align(self).abi);
assert!(b_offset.bytes() > 0); // we later use the offset to tell apart the fields assert!(b_offset.bytes() > 0); // we later use the offset to tell apart the fields
let b_ptr = ptr.offset(b_offset, self)?; let b_ptr = ptr.offset(b_offset, self)?;
let a_val = self.memory.get_raw(ptr.alloc_id)?.read_scalar(self, a_ptr, a_size)?; let a_val = alloc.read_scalar(self, a_ptr, a_size)?;
let b_val = self.memory.get_raw(ptr.alloc_id)?.read_scalar(self, b_ptr, b_size)?; let b_val = alloc.read_scalar(self, b_ptr, b_size)?;
Ok(Some(ImmTy { imm: Immediate::ScalarPair(a_val, b_val), layout: mplace.layout })) Ok(Some(ImmTy { imm: Immediate::ScalarPair(a_val, b_val), layout: mplace.layout }))
} }
_ => Ok(None), _ => Ok(None),