Merge pull request #213 from rust-lang/fix/bitcast-wrong-size

Fix bitcast to a type of a different size
This commit is contained in:
antoyo 2022-08-29 17:35:50 -04:00 committed by GitHub
commit 2342414f49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1364,22 +1364,17 @@ impl<'a, 'gcc, 'tcx> Builder<'a, 'gcc, 'tcx> {
vector_elements.push(self.context.new_rvalue_zero(mask_element_type)); vector_elements.push(self.context.new_rvalue_zero(mask_element_type));
} }
let array_type = self.context.new_array_type(None, element_type, vec_num_units as i32);
let result_type = self.context.new_vector_type(element_type, mask_num_units as u64); let result_type = self.context.new_vector_type(element_type, mask_num_units as u64);
let (v1, v2) = let (v1, v2) =
if vec_num_units < mask_num_units { if vec_num_units < mask_num_units {
// NOTE: the mask needs to be the same length as the input vectors, so join the 2 // NOTE: the mask needs to be the same length as the input vectors, so join the 2
// vectors and create a dummy second vector. // vectors and create a dummy second vector.
// TODO(antoyo): switch to using new_vector_access.
let array = self.context.new_bitcast(None, v1, array_type);
let mut elements = vec![]; let mut elements = vec![];
for i in 0..vec_num_units { for i in 0..vec_num_units {
elements.push(self.context.new_array_access(None, array, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue()); elements.push(self.context.new_vector_access(None, v1, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue());
} }
// TODO(antoyo): switch to using new_vector_access.
let array = self.context.new_bitcast(None, v2, array_type);
for i in 0..(mask_num_units - vec_num_units) { for i in 0..(mask_num_units - vec_num_units) {
elements.push(self.context.new_array_access(None, array, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue()); elements.push(self.context.new_vector_access(None, v2, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue());
} }
let v1 = self.context.new_rvalue_from_vector(None, result_type, &elements); let v1 = self.context.new_rvalue_from_vector(None, result_type, &elements);
let zero = self.context.new_rvalue_zero(element_type); let zero = self.context.new_rvalue_zero(element_type);
@ -1399,10 +1394,8 @@ impl<'a, 'gcc, 'tcx> Builder<'a, 'gcc, 'tcx> {
// NOTE: if padding was added, only select the number of elements of the masks to // NOTE: if padding was added, only select the number of elements of the masks to
// remove that padding in the result. // remove that padding in the result.
let mut elements = vec![]; let mut elements = vec![];
// TODO(antoyo): switch to using new_vector_access.
let array = self.context.new_bitcast(None, result, array_type);
for i in 0..mask_num_units { for i in 0..mask_num_units {
elements.push(self.context.new_array_access(None, array, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue()); elements.push(self.context.new_vector_access(None, result, self.context.new_rvalue_from_int(self.int_type, i as i32)).to_rvalue());
} }
self.context.new_rvalue_from_vector(None, result_type, &elements) self.context.new_rvalue_from_vector(None, result_type, &elements)
} }