mirror of
https://github.com/github/codeql.git
synced 2025-12-19 18:33:16 +01:00
25 lines
696 B
Plaintext
25 lines
696 B
Plaintext
/**
|
|
* @name SSA dominance property test
|
|
* @description SSA dominance property test. SSA definitions *must* dominate all uses
|
|
* @kind test
|
|
*/
|
|
|
|
import cpp
|
|
import semmle.code.cpp.rangeanalysis.RangeSSA
|
|
|
|
/*
|
|
* Count of number of SSA def-use pairs where the defn does not dominate the use.
|
|
* Should always be zero *regardless* of the input
|
|
*/
|
|
|
|
select count(RangeSsaDefinition d, StackVariable v, Expr u |
|
|
d.getAUse(v) = u and
|
|
not exists(BasicBlock bd, BasicBlock bu | bd.contains(mkElement(d)) and bu.contains(u) |
|
|
bbStrictlyDominates(bd, bu)
|
|
or
|
|
exists(int i, int j |
|
|
bd = bu and bd.getNode(i) = mkElement(d) and bu.getNode(j) = u and i <= j
|
|
)
|
|
)
|
|
)
|