diff --git a/src/cmd/compile/internal/gc/ssa.go b/src/cmd/compile/internal/gc/ssa.go index 7da49fc6f0..70350e0e2c 100644 --- a/src/cmd/compile/internal/gc/ssa.go +++ b/src/cmd/compile/internal/gc/ssa.go @@ -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)