Skip to content

Commit

Permalink
Merge pull request #72 from rems-project/isla-litmus-dump
Browse files Browse the repository at this point in the history
Initial isla-litmus-dump commits
  • Loading branch information
Alasdair authored Apr 17, 2024
2 parents a9b68f3 + 3f71721 commit bdd2369
Show file tree
Hide file tree
Showing 9 changed files with 1,402 additions and 27 deletions.
43 changes: 37 additions & 6 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

6 changes: 6 additions & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,11 @@ name = "isla-client"
path = "src/client.rs"
doc = false

[[bin]]
name = "isla-litmus-dump"
path = "src/litmus-dump.rs"
doc = false

[[bin]]
name = "isla-preprocess"
path = "src/preprocess.rs"
Expand Down Expand Up @@ -75,6 +80,7 @@ doc = false
crossbeam = "0.8.1"
getopts = "0.2.21"
toml = "0.5.5"
pretty = "0.11.3"
serde = "1.0.104"
bincode = "1.2.1"
sha2 = "0.8.1"
Expand Down
14 changes: 14 additions & 0 deletions configs/armv9p4.toml
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,12 @@ ignore = [
"FEAT_SHA3_IMPLEMENTED" = false
"FEAT_LS64_V_IMPLEMENTED" = true
"FEAT_LS64_ACCDATA_IMPLEMENTED" = true
"FEAT_DoPD_IMPLEMENTED" = false

# External debug registers that don't appear to be fully initialised in the current model (or at all on AArch64)
"EDESR" = "{ bits = 0x00000000 }"
"EDECR" = "{ bits = 0x00000000 }"


# Avoid some extra complication
"FEAT_TME_IMPLEMENTED" = false
Expand All @@ -200,6 +206,14 @@ ignore = [
# Bit 26 being set allows cache-maintenance ops in EL0
"SCTLR_EL1" = "{ bits = 0x0000000004000000 }"
"CNTCR" = "{ bits = 0x00000000 }"
# Set above, but ENABLE might be reset to UNKNOWN
"CNTHP_CTL_EL2" = "{ bits = 0x0000000000000000 }"

# Monitor Debug Configuration Register (EL2)
# Turn HPME off to avoid even thinking about PMU events
# (it's set to UNKNOWN on reset)
"MDCR_EL2" = "{ bits = 0x00000000 }"


# A map from register names that may appear in litmus files to Sail
# register names
Expand Down
24 changes: 12 additions & 12 deletions isla-axiomatic/src/footprint_analysis.rs
Original file line number Diff line number Diff line change
Expand Up @@ -61,36 +61,36 @@ use isla_lib::zencode;
pub struct Footprint {
/// Tracks which (symbolic) registers / memory reads can feed into
/// a memory write within an instruction
write_data_taints: Taints,
pub write_data_taints: Taints,
/// Tracks with (symbolic) registers / memory reads can feed into
/// a memory operator (read/write) address within an instruction
mem_addr_taints: Taints,
pub mem_addr_taints: Taints,
/// Tracks which (symbolic) registers / memory reads can feed into
/// the address of a branch
branch_addr_taints: Taints,
pub branch_addr_taints: Taints,
/// The set of register reads (with subfield granularity)
register_reads: HashSet<RegisterField>,
pub register_reads: HashSet<RegisterField>,
/// The set of register writes (also with subfield granularity)
register_writes: HashSet<RegisterField>,
pub register_writes: HashSet<RegisterField>,
/// The set of register writes where the value was tainted by a memory read
register_writes_tainted: HashSet<RegisterField>,
pub register_writes_tainted: HashSet<RegisterField>,
/// All register read-write pairs to the following registers are
/// ignored for tracking dependencies within an instruction. If
/// the first element of the tuple is None then all writes are
/// ignored
register_writes_ignored: HashSet<(Option<Name>, Name)>,
pub register_writes_ignored: HashSet<(Option<Name>, Name)>,
/// If we see `mark_register(R, "pick")` then we have internal
/// pick dependencies from all registers affecting the intrinsic
/// control order from R
register_pick_deps: HashMap<Name, HashSet<RegisterField>>,
pub register_pick_deps: HashMap<Name, HashSet<RegisterField>>,
/// A store is any instruction with a WriteMem event
is_store: bool,
pub is_store: bool,
/// A load is any instruction with a ReadMem event
is_load: bool,
pub is_load: bool,
/// A branch is any instruction with a Branch event
is_branch: bool,
pub is_branch: bool,
/// An exclusive is any event with an exclusive read or write kind.
is_exclusive: bool,
pub is_exclusive: bool,
}

pub struct Footprintkey {
Expand Down
10 changes: 6 additions & 4 deletions isla-lib/src/bitvector/b129.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,20 +49,22 @@ pub struct B129 {

impl fmt::LowerHex for B129 {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
let prefix = if f.alternate() { "0x" } else { "" };
if self.len <= 128 || !self.tag {
write!(f, "{:x}", self.bits)
write!(f, "{}{:x}", prefix, self.bits)
} else {
write!(f, "1{:0>32x}", self.bits)
write!(f, "{}1{:0>32x}", prefix, self.bits)
}
}
}

impl fmt::UpperHex for B129 {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
let prefix = if f.alternate() { "0X" } else { "" };
if self.len <= 128 || !self.tag {
write!(f, "{:X}", self.bits)
write!(f, "{}{:X}", prefix, self.bits)
} else {
write!(f, "1{:0>32X}", self.bits)
write!(f, "{}1{:0>32X}", prefix, self.bits)
}
}
}
Expand Down
4 changes: 2 additions & 2 deletions isla-lib/src/bitvector/b64.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,13 +47,13 @@ pub struct B64 {

impl fmt::LowerHex for B64 {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{:x}", self.bits)
fmt::LowerHex::fmt(&self.bits, f)
}
}

impl fmt::UpperHex for B64 {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "{:x}", self.bits)
fmt::UpperHex::fmt(&self.bits, f)
}
}

Expand Down
6 changes: 5 additions & 1 deletion isla-lib/src/memory.rs
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ impl<B> Region<B> {
}
}

fn region_range(&self) -> &Range<Address> {
pub fn region_range(&self) -> &Range<Address> {
match self {
Region::Constrained(r, _) => r,
Region::Symbolic(r) => r,
Expand Down Expand Up @@ -246,6 +246,10 @@ impl<B: BV> Memory<B> {
Memory { regions: Vec::new(), client_info: None }
}

pub fn regions(&self) -> &[Region<B>] {
&self.regions
}

pub fn region_name_at(&self, addr: Address) -> &'static str {
for region in &self.regions {
if region.region_range().contains(&addr) {
Expand Down
4 changes: 2 additions & 2 deletions isla-lib/src/simplify.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1051,8 +1051,8 @@ fn accessor_to_string(acc: &[Accessor], symtab: &Symtab) -> String {
pub struct EventTree<B> {
fork_id: Option<u32>,
source_loc: SourceLoc,
prefix: Vec<Event<B>>,
forks: Vec<EventTree<B>>,
pub prefix: Vec<Event<B>>,
pub forks: Vec<EventTree<B>>,
}

/// When used with a stable sort, will push declare-const events
Expand Down
Loading

0 comments on commit bdd2369

Please sign in to comment.