Add type_array to BaseTypeMethods
Moved type_array function to rustc_codegen_ssa::BaseTypeMethods trait. This allows using normal alloca function to create arrays as suggested in https://github.com/rust-lang/rust/pull/104022. Signed-off-by: Ayush Singh <ayushsingh1325@gmail.com>
This commit is contained in:
parent
5a1c8e8e5c
commit
87237cb699
42
src/type_.rs
42
src/type_.rs
@ -201,6 +201,27 @@ impl<'gcc, 'tcx> BaseTypeMethods<'tcx> for CodegenCx<'gcc, 'tcx> {
|
|||||||
fn val_ty(&self, value: RValue<'gcc>) -> Type<'gcc> {
|
fn val_ty(&self, value: RValue<'gcc>) -> Type<'gcc> {
|
||||||
value.get_type()
|
value.get_type()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn type_array(&self, ty: Type<'gcc>, mut len: u64) -> Type<'gcc> {
|
||||||
|
if let Some(struct_type) = ty.is_struct() {
|
||||||
|
if struct_type.get_field_count() == 0 {
|
||||||
|
// NOTE: since gccjit only supports i32 for the array size and libcore's tests uses a
|
||||||
|
// size of usize::MAX in test_binary_search, we workaround this by setting the size to
|
||||||
|
// zero for ZSTs.
|
||||||
|
// FIXME(antoyo): fix gccjit API.
|
||||||
|
len = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// NOTE: see note above. Some other test uses usize::MAX.
|
||||||
|
if len == u64::MAX {
|
||||||
|
len = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
let len: i32 = len.try_into().expect("array len");
|
||||||
|
|
||||||
|
self.context.new_array_type(None, ty, len)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'gcc, 'tcx> CodegenCx<'gcc, 'tcx> {
|
impl<'gcc, 'tcx> CodegenCx<'gcc, 'tcx> {
|
||||||
@ -227,27 +248,6 @@ impl<'gcc, 'tcx> CodegenCx<'gcc, 'tcx> {
|
|||||||
self.context.new_opaque_struct_type(None, name)
|
self.context.new_opaque_struct_type(None, name)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn type_array(&self, ty: Type<'gcc>, mut len: u64) -> Type<'gcc> {
|
|
||||||
if let Some(struct_type) = ty.is_struct() {
|
|
||||||
if struct_type.get_field_count() == 0 {
|
|
||||||
// NOTE: since gccjit only supports i32 for the array size and libcore's tests uses a
|
|
||||||
// size of usize::MAX in test_binary_search, we workaround this by setting the size to
|
|
||||||
// zero for ZSTs.
|
|
||||||
// FIXME(antoyo): fix gccjit API.
|
|
||||||
len = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// NOTE: see note above. Some other test uses usize::MAX.
|
|
||||||
if len == u64::MAX {
|
|
||||||
len = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
let len: i32 = len.try_into().expect("array len");
|
|
||||||
|
|
||||||
self.context.new_array_type(None, ty, len)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn type_bool(&self) -> Type<'gcc> {
|
pub fn type_bool(&self) -> Type<'gcc> {
|
||||||
self.context.new_type::<bool>()
|
self.context.new_type::<bool>()
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user