mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
cmd: use built-in min/max instead of bespoke versions
Now that we're bootstrapping from a toolchain that has min/max builtins. Update #64751 Change-Id: I63eedf3cca00f56f62ca092949cb2dc61db03361 Reviewed-on: https://go-review.googlesource.com/c/go/+/610355 Reviewed-by: Dmitri Shuralyov <dmitshur@google.com> LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Keith Randall <khr@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
820f58a27f
commit
f90f7e90b3
9 changed files with 18 additions and 100 deletions
|
|
@ -1737,13 +1737,13 @@ func (ft *factsTable) flowLimit(v *Value) bool {
|
|||
// AND can only make the value smaller.
|
||||
a := ft.limits[v.Args[0].ID]
|
||||
b := ft.limits[v.Args[1].ID]
|
||||
return ft.unsignedMax(v, minU(a.umax, b.umax))
|
||||
return ft.unsignedMax(v, min(a.umax, b.umax))
|
||||
case OpOr64, OpOr32, OpOr16, OpOr8:
|
||||
// OR can only make the value bigger and can't flip bits proved to be zero in both inputs.
|
||||
a := ft.limits[v.Args[0].ID]
|
||||
b := ft.limits[v.Args[1].ID]
|
||||
return ft.unsignedMinMax(v,
|
||||
maxU(a.umin, b.umin),
|
||||
max(a.umin, b.umin),
|
||||
1<<bits.Len64(a.umax|b.umax)-1)
|
||||
case OpXor64, OpXor32, OpXor16, OpXor8:
|
||||
// XOR can't flip bits that are proved to be zero in both inputs.
|
||||
|
|
@ -1835,7 +1835,7 @@ func (ft *factsTable) flowLimit(v *Value) bool {
|
|||
a := ft.limits[v.Args[0].ID]
|
||||
b := ft.limits[v.Args[1].ID]
|
||||
// Underflow in the arithmetic below is ok, it gives to MaxUint64 which does nothing to the limit.
|
||||
return ft.unsignedMax(v, minU(a.umax, b.umax-1))
|
||||
return ft.unsignedMax(v, min(a.umax, b.umax-1))
|
||||
case OpDiv64, OpDiv32, OpDiv16, OpDiv8:
|
||||
a := ft.limits[v.Args[0].ID]
|
||||
b := ft.limits[v.Args[1].ID]
|
||||
|
|
@ -1871,8 +1871,8 @@ func (ft *factsTable) flowLimit(v *Value) bool {
|
|||
l2 := ft.limits[a.ID]
|
||||
l.min = min(l.min, l2.min)
|
||||
l.max = max(l.max, l2.max)
|
||||
l.umin = minU(l.umin, l2.umin)
|
||||
l.umax = maxU(l.umax, l2.umax)
|
||||
l.umin = min(l.umin, l2.umin)
|
||||
l.umax = max(l.umax, l2.umax)
|
||||
}
|
||||
return ft.newLimit(v, l)
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue