Commit 29162ec9 authored by Giovanni Bajo's avatar Giovanni Bajo

cmd/compile: in prove, infer unsigned relations while branching

When a branch is followed, we apply the relation as described
in the domain relation table. In case the relation is in the
positive domain, we can also infer an unsigned relation if,
by that point, we know that both operands are non-negative.

Fixes #20393

Change-Id: Ieaf0c81558b36d96616abae3eb834c788dd278d5
Reviewed-on: https://go-review.googlesource.com/100278
Run-TryBot: Giovanni Bajo <rasky@develer.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarGiovanni Bajo <rasky@develer.com>
Reviewed-by: default avatarDavid Chase <drchase@google.com>
parent 5c402109
...@@ -704,6 +704,9 @@ func addBranchRestrictions(ft *factsTable, b *Block, br branch) { ...@@ -704,6 +704,9 @@ func addBranchRestrictions(ft *factsTable, b *Block, br branch) {
// When we branched from parent we learned a new set of // When we branched from parent we learned a new set of
// restrictions. Update the factsTable accordingly. // restrictions. Update the factsTable accordingly.
d := tr.d d := tr.d
if d == signed && ft.isNonNegative(c.Args[0]) && ft.isNonNegative(c.Args[1]) {
d |= unsigned
}
switch br { switch br {
case negative: case negative:
switch b.Control.Op { // Special cases switch b.Control.Op { // Special cases
......
...@@ -605,6 +605,15 @@ func trans2(a, b []int, i int) { ...@@ -605,6 +605,15 @@ func trans2(a, b []int, i int) {
_ = b[i] // ERROR "Proved IsInBounds$" _ = b[i] // ERROR "Proved IsInBounds$"
} }
func trans3(a, b []int, i int) {
if len(a) > len(b) {
return
}
_ = a[i]
_ = b[i] // ERROR "Proved IsInBounds$"
}
//go:noinline //go:noinline
func useInt(a int) { func useInt(a int) {
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment