Commit Graph

20 Commits (21be78c4f8397a4567a42f4bd3cfaeff8748d880)

Author SHA1 Message Date
Jean-François Nguyen 692e8ec7c4 checks.insn: add checks for compare instructions.
Jean-François Nguyen a413025fcb Update SPR interface and split consistency check.
* Use bitmasks to describe SPR accesses at the field granularity.

* Use separate checks for each SPR, instead of covering them all at
  once. Users may run them in the same batch, and know which SPR passes
  or fails its check.
Jean-François Nguyen 2ffff6196b checks.insn: add check for MCRF instruction.
Jean-François Nguyen 4c16035a70 checks.insn._cr: fix order of spec_cr_w_data bits.
Jean-François Nguyen fee59d2257 checks.insn: add checks for CR logical instructions.
Jean-François Nguyen bc06e67fe8 checks.insn._branch: add missing PowerFVCheck name.
Jean-François Nguyen 9ea58a47a9 Refactor to facilitate integration with CLIs and config files.
* Checks are now split in two modules: checks.cons for consistency
  checks, checks.insn for instructions.

* Checks are derived from PowerFVCheck and have a shorthand (e.g.
  "insn_b"). PowerFVCheck holds a mapping between its subclasses and
  their shorthands.

* Instruction checks definitions have been simplified to one-liners,
  and grouped into a single file.

* A Trigger class has been added to define testbench triggers.
Jean-François Nguyen 5c097b9474 checks._branch: fix branches to LR/CTR/TAR.
- remove check for undefined mnemonics (afaiu, their BO value isn't illegal).
- add check for illegal bcctr/bcctrl forms (with BO(2) = 0).
- fix target offset for branches to LR/CTR/TAR.
- use MSR.SF to check the upper bits of target addresses.
Jean-François Nguyen 5649f60c78 checks.insn_bcctrl: fix typo.
Jean-François Nguyen 0ca97a8d6a checks.{cr,gpr}: add support for interrupts.
Also, rephrase gpr.Check docstring.
Jean-François Nguyen 25500cd680 checks.spr: refactor.
Jean-François Nguyen 58bef1a741 checks: add checks for branch instructions.
Jean-François Nguyen 5c9bc3e68c cores/microwatt: add support for concurrent execution of formal checks.
Jean-François Nguyen 6ae4978f0c pfv: expose CR as a flat 32-bit value.
Jean-François Nguyen 2988ffc617 checks.spr: add SPRCheck.
Jean-François Nguyen e7e9bb08f0 checks.cr: add CRCheck.
Jean-François Nguyen b84a23877a checks.gpr: add GPRCheck.
Jean-François Nguyen e0e434204b checks.ia_fwd: add check.
Jean-François Nguyen fc9feb58cb checks.unique: add check.
Jean-François Nguyen 25c629af16 tb: add top-level testbench.