23 #ifndef OTAWA_DCACHE_MUSTPERS_H_
24 #define OTAWA_DCACHE_MUSTPERS_H_
35 namespace otawa {
namespace dcache {
42 inline Domain(
const int _size,
const int _A)
59 const Domain&
bottom(
void)
const;
60 const Domain&
entry(
void)
const;
dtd::RefAttr< BasicBlock * > source("source", dtd::STRICT|dtd::REQUIRED)
void assign(Domain &a, const Domain &b) const
Definition: PERSProblem.h:117
A block access represents a data memory access of an instruction.
Definition: features.h:125
MUSTProblem::Domain must
Definition: MUSTPERS.h:49
void lub(Domain &a, const Domain &b) const
Definition: MUSTPERS.h:61
const Domain & entry(void) const
Definition: dcache_ACSBuilder.cpp:700
void leaveContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: PERSProblem.h:131
void assign(Domain &a, const Domain &b) const
Definition: ACSBuilder.h:105
Domain(const Domain &source)
Definition: MUSTPERS.h:44
MUSTPERS(const BlockCollection *_lbset, WorkSpace *_fw, const hard::Cache *_cache)
Definition: dcache_ACSBuilder.cpp:681
Definition: ACSBuilder.h:37
void inject(Domain &d, const int id) const
Definition: MUSTPERS.h:72
void lub(Domain &a, const Domain &b) const
Definition: PERSProblem.h:116
void ageAll(Domain &d) const
Definition: MUSTPERS.h:71
void setMust(Domain &d, const ACS &acs) const
Definition: MUSTPERS.h:54
MUSTProblem::Domain & getMust(void)
Definition: MUSTPERS.h:45
dtd::Element bb(dtd::make("bb", _BB).attr(id).attr(address).attr(size))
Domain ent
Definition: MUSTPERS.h:86
Domain bot
Definition: MUSTPERS.h:85
PERSProblem::Domain & getPers(void)
Definition: MUSTPERS.h:46
void enterContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: PERSProblem.h:124
bool equals(const Domain &a, const Domain &b) const
Definition: PERSProblem.h:118
ACS of the MUSTPERS problem.
Definition: MUSTPERS.h:39
void leaveContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: ACSBuilder.h:112
MUSTProblem mustProb
Definition: MUSTPERS.h:88
A workspace represents a program, its run-time and all information about WCET computation or any othe...
Definition: WorkSpace.h:67
This class contains the configuration of a level of cache of processor.
Definition: Cache.h:34
bool equals(const Domain &a, const Domain &b) const
Definition: ACSBuilder.h:107
void ageAll(void)
Definition: ACSBuilder.h:83
void inject(MUSTProblem::Domain *must, const int id)
Consider that the designed block is accessed.
Definition: dcache_ACSBuilder.cpp:950
sys::SystemOutStream & out
PERSProblem::Domain pers
Definition: MUSTPERS.h:48
void enterContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: ACSBuilder.h:111
Definition: PERSProblem.h:58
hai_context_t
Definition: HalfAbsInt.h:50
Problem for computing the PERS ACS of L-blocks.
Definition: PERSProblem.h:37
void empty(void)
Empty the domain.
Definition: dcache_ACSBuilder.cpp:924
void lub(Domain &a, const Domain &b) const
Definition: ACSBuilder.h:100
Definition: MUSTPERS.h:37
This is the minimal definition of a basic block.
Definition: BasicBlock.h:43
const Domain & bottom(void) const
Definition: dcache_ACSBuilder.cpp:697
void ageAll(void)
Consider that an unknown access is performed and, therefore, all blocks must be aged.
Definition: dcache_ACSBuilder.cpp:646
void assign(Domain &a, const Domain &b) const
Definition: MUSTPERS.h:63
void update(Domain &out, const Domain &in, BasicBlock *bb)
Definition: dcache_ACSBuilder.cpp:749
bool equals(const Domain &a, const Domain &b) const
Definition: MUSTPERS.h:65
void set(const ACS &w, const genstruct::Table< ACS * > &d)
Definition: PERSProblem.h:88
int set
Definition: MUSTPERS.h:87
Domain(const int _size, const int _A)
Definition: MUSTPERS.h:42
The MUST problem provides the abstract interpretation of L1 data cache for the MUST case...
Definition: ACSBuilder.h:35
void enterContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: MUSTPERS.h:74
Representation of an Abstract Cache State where each data cache block is represented by its age...
Definition: features.h:47
void inject(const int id)
Definition: ACSBuilder.h:67
void leaveContext(Domain &dom, BasicBlock *header, util::hai_context_t ctx)
Definition: MUSTPERS.h:79
void setPers(Domain &d, const ACS &acs, const acs_stack_t &s)
Definition: MUSTPERS.h:56
void emptyPers(Domain &d) const
Definition: MUSTPERS.h:55
A block collections stores the list of data blocks used in a task for a specific line.
Definition: features.h:108
void print(elm::io::Output &output, const Domain &d) const
Print the MUSTPERS ACS.
Definition: dcache_ACSBuilder.cpp:672
PERSProblem persProb
Definition: MUSTPERS.h:89