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
dd930a3b5c
commit
a897864150
42
src/type_.rs
42
src/type_.rs
@ -201,6 +201,27 @@ fn int_width(&self, typ: Type<'gcc>) -> u64 {
|
|||||||
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,25 +248,8 @@ pub fn type_named_struct(&self, name: &str) -> Struct<'gcc> {
|
|||||||
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> {
|
pub fn type_bool(&self) -> Type<'gcc> {
|
||||||
if let Some(struct_type) = ty.is_struct() {
|
self.context.new_type::<bool>()
|
||||||
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)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user