"ARM relaxing ppo to accommodate qualcomm behaviors"
include "cos.cat"
let poi = po-loc
let complus = fr|rf|co|(co;rf)|(fr;rf)
irreflexive poi;complus
as scperlocation
let dd = addr | data
let rdw = po-loc & (fre;rfe)
let detour = po-loc & (coe ; rfe)
let addrpo = addr;po
include "armfences.cat"
show isb,ctrlisb
let ci0 = ctrlisb | detour
let ii0 = dd | rfi | rdw
let cc0 = dd | ctrl | addrpo |
( po-loc \ ( rfi | (po-loc;rfi)))
let ic0 =
0
include "ppo.cat"
let WW = W * W
let dmb.st=dmb.st & WW
let dsb.st=dsb.st & WW
show dmb, dsb, dmb.st, dsb.st
let strong = dmb|dsb|dmb.st|dsb.st
let light =
0
include "ppc-checks.cat"