check that the argument to CmmCondBranch is really a conditional
authorSimon Marlow <simonmar@microsoft.com>
Tue, 20 Jun 2006 14:12:04 +0000 (14:12 +0000)
committerSimon Marlow <simonmar@microsoft.com>
Tue, 20 Jun 2006 14:12:04 +0000 (14:12 +0000)
compiler/cmm/CmmLint.hs

index fbfb14c..83444e5 100644 (file)
@@ -118,11 +118,15 @@ lintCmmStmt (CmmStore l r) = do
   lintCmmExpr r
   return ()
 lintCmmStmt (CmmCall _target _res args _vols) = mapM_ (lintCmmExpr.fst) args
-lintCmmStmt (CmmCondBranch e _id)   = lintCmmExpr e >> return ()
+lintCmmStmt (CmmCondBranch e _id)   = lintCmmExpr e >> checkCond e >> return ()
 lintCmmStmt (CmmSwitch e _branches) = lintCmmExpr e >> return ()
 lintCmmStmt (CmmJump e _args)       = lintCmmExpr e >> return ()
 lintCmmStmt _other                 = return ()
 
+checkCond (CmmMachOp mop _) | isComparisonMachOp mop = return ()
+checkCond expr = cmmLintErr (hang (text "expression is not a conditional:") 2
+                                   (ppr expr))
+
 -- -----------------------------------------------------------------------------
 -- CmmLint monad