Commit 46ffb026 authored by Keith Randall's avatar Keith Randall

[dev.ssa] cmd/compile/internal/ssa: OCHECKNIL is a statement, not an expression

Change-Id: I5a683f532a5a0b2bc862d80c871e8dc6721016fc
Reviewed-on: https://go-review.googlesource.com/14534Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 7e390724
......@@ -772,6 +772,10 @@ func (s *state) stmt(n *Node) {
b.AddEdgeTo(bNext)
s.startBlock(bNext)
case OCHECKNIL:
p := s.expr(n.Left)
s.nilCheck(p)
default:
s.Unimplementedf("unhandled stmt %s", opnames[n.Op])
}
......@@ -1661,11 +1665,6 @@ func (s *state) expr(n *Node) *ssa.Value {
case OADDR:
return s.addr(n.Left)
case OCHECKNIL:
p := s.expr(n.Left)
s.nilCheck(p)
return p
case OINDREG:
if int(n.Reg) != Thearch.REGSP {
s.Unimplementedf("OINDREG of non-SP register %s in expr: %v", obj.Rconv(int(n.Reg)), n)
......
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