remove box derefs from codgen
This commit is contained in:
parent
3e9d3d917a
commit
cb417881a9
16 changed files with 385 additions and 146 deletions
|
@ -118,22 +118,20 @@ impl<'a, 'tcx, V: CodegenObject> OperandRef<'tcx, V> {
|
|||
}
|
||||
|
||||
pub fn deref<Cx: LayoutTypeMethods<'tcx>>(self, cx: &Cx) -> PlaceRef<'tcx, V> {
|
||||
if self.layout.ty.is_box() && !self.layout.abi.is_scalar() {
|
||||
bug!("dereferencing non-scalar box ({:?}) in codegen", self.layout.ty);
|
||||
}
|
||||
|
||||
let projected_ty = self
|
||||
.layout
|
||||
.ty
|
||||
.builtin_deref(true)
|
||||
.unwrap_or_else(|| bug!("deref of non-pointer {:?}", self))
|
||||
.ty;
|
||||
|
||||
let (llptr, llextra) = match self.val {
|
||||
OperandValue::Immediate(llptr) => (llptr, None),
|
||||
OperandValue::Pair(llptr, llextra) => {
|
||||
// if the box's allocator isn't a ZST, then "llextra" is actually the allocator
|
||||
if self.layout.ty.is_box() && !self.layout.field(cx, 1).is_zst() {
|
||||
(llptr, None)
|
||||
} else {
|
||||
(llptr, Some(llextra))
|
||||
}
|
||||
}
|
||||
OperandValue::Pair(llptr, llextra) => (llptr, Some(llextra)),
|
||||
OperandValue::Ref(..) => bug!("Deref of by-Ref operand {:?}", self),
|
||||
};
|
||||
let layout = cx.layout_of(projected_ty);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue