diff options
| author | Ralf Jung <post@ralfj.de> | 2022-07-17 11:36:37 -0400 |
|---|---|---|
| committer | Ralf Jung <post@ralfj.de> | 2022-07-20 16:57:31 -0400 |
| commit | 8f290184d2bb3ea238843484a858bcd85e71de6a (patch) | |
| tree | 5481ee786b2be76b6daf7c3fc72c9e2059e552fc | |
| parent | bca7b0279f02a64ba758a8092cdb400dea26f9b7 (diff) | |
| download | rust-8f290184d2bb3ea238843484a858bcd85e71de6a.tar.gz rust-8f290184d2bb3ea238843484a858bcd85e71de6a.zip | |
add a Vtable kind of symbolic allocations
| -rw-r--r-- | src/common.rs | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/src/common.rs b/src/common.rs index fc391f53f18..3868f2f7a49 100644 --- a/src/common.rs +++ b/src/common.rs @@ -183,6 +183,13 @@ impl<'gcc, 'tcx> ConstMethods<'tcx> for CodegenCx<'gcc, 'tcx> { } Scalar::Ptr(ptr, _size) => { let (alloc_id, offset) = ptr.into_parts(); + // For vtables, get the underlying data allocation. + let alloc_id = match self.tcx.global_alloc(alloc_id) { + GlobalAlloc::Vtable(ty, trait_ref) => { + self.tcx.vtable_allocation((ty, trait_ref)) + } + _ => alloc_id, + }; let base_addr = match self.tcx.global_alloc(alloc_id) { GlobalAlloc::Memory(alloc) => { @@ -201,6 +208,7 @@ impl<'gcc, 'tcx> ConstMethods<'tcx> for CodegenCx<'gcc, 'tcx> { GlobalAlloc::Function(fn_instance) => { self.get_fn_addr(fn_instance) }, + GlobalAlloc::Vtable(..) => panic!("vtables are already handled"), GlobalAlloc::Static(def_id) => { assert!(self.tcx.is_static(def_id)); self.get_static(def_id).get_address(None) |
