miri: helper methods for max values of machine's usize/isize
This commit is contained in:
parent
5e380b797b
commit
6c9ba97d23
1 changed files with 13 additions and 0 deletions
|
@ -1,4 +1,5 @@
|
|||
use std::fmt::{self, Display};
|
||||
use std::convert::TryFrom;
|
||||
|
||||
use crate::mir;
|
||||
use crate::ty::layout::{self, HasDataLayout, Size};
|
||||
|
@ -40,6 +41,18 @@ pub trait PointerArithmetic: layout::HasDataLayout {
|
|||
self.data_layout().pointer_size
|
||||
}
|
||||
|
||||
#[inline]
|
||||
fn usize_max(&self) -> u64 {
|
||||
let max_usize_plus_1 = 1u128 << self.pointer_size().bits();
|
||||
u64::try_from(max_usize_plus_1-1).unwrap()
|
||||
}
|
||||
|
||||
#[inline]
|
||||
fn isize_max(&self) -> i64 {
|
||||
let max_isize_plus_1 = 1u128 << (self.pointer_size().bits()-1);
|
||||
i64::try_from(max_isize_plus_1-1).unwrap()
|
||||
}
|
||||
|
||||
/// Helper function: truncate given value-"overflowed flag" pair to pointer size and
|
||||
/// update "overflowed flag" if there was an overflow.
|
||||
/// This should be called by all the other methods before returning!
|
||||
|
|
Loading…
Add table
Reference in a new issue