diff options
-rw-r--r-- | erebos-tester.cabal | 3 | ||||
-rw-r--r-- | src/GDB.hs | 36 | ||||
-rw-r--r-- | src/Main.hs | 25 | ||||
-rw-r--r-- | src/Process.hs | 7 |
4 files changed, 49 insertions, 22 deletions
diff --git a/erebos-tester.cabal b/erebos-tester.cabal index bae7d1e..4964b6f 100644 --- a/erebos-tester.cabal +++ b/erebos-tester.cabal @@ -33,7 +33,8 @@ executable erebos-tester executable erebos-tester-core ghc-options: -Wall -threaded main-is: Main.hs - other-modules: Output + other-modules: GDB + Output Parser Process Test diff --git a/src/GDB.hs b/src/GDB.hs new file mode 100644 index 0000000..40a4e8f --- /dev/null +++ b/src/GDB.hs @@ -0,0 +1,36 @@ +module GDB ( + gdbCmd, gdbInit, + addInferior, + gdbSession, +) where + +import Data.Text qualified as T +import Data.Text.IO qualified as T + +import System.IO.Error +import System.Process + +import Process + +gdbCmd :: String +gdbCmd = "gdb --quiet --interpreter=mi3" + +gdbInit :: Process -> IO () +gdbInit gdb = do + send gdb $ T.pack "-gdb-set schedule-multiple on" + send gdb $ T.pack "-gdb-set mi-async on" + send gdb $ T.pack "-gdb-set print symbol-loading off" + +addInferior :: Process -> Int -> Pid -> IO () +addInferior gdb i pid = do + send gdb $ T.pack $ "-add-inferior" + send gdb $ T.pack $ "-target-attach --thread-group i" ++ show i ++ " " ++ show pid + send gdb $ T.pack $ "-exec-continue --thread-group i" ++ show i + +gdbSession :: Process -> IO () +gdbSession gdb = do + catchIOError (Just <$> T.getLine) (\e -> if isEOFError e then return Nothing else ioError e) >>= \case + Just line -> do + send gdb (T.pack "-interpreter-exec console \"" `T.append` line `T.append` T.pack "\"") + gdbSession gdb + Nothing -> return () diff --git a/src/Main.hs b/src/Main.hs index 6444058..20e01e6 100644 --- a/src/Main.hs +++ b/src/Main.hs @@ -27,6 +27,7 @@ import System.Posix.Process import System.Posix.Signals import System.Process +import GDB import Output import Parser import Process @@ -78,11 +79,7 @@ initNetwork out useGDB = do "tcpdump -i br0 -w '" ++ testDir ++ "/br0.pcap' -U -Z root" when useGDB $ do - gdb <- spawnOn out (Left net) (ProcNameGDB) Nothing $ - "gdb --quiet --interpreter=mi3" - send gdb $ T.pack "-gdb-set schedule-multiple on" - send gdb $ T.pack "-gdb-set mi-async on" - send gdb $ T.pack "-gdb-set print symbol-loading off" + gdbInit =<< spawnOn out (Left net) ProcNameGDB Nothing gdbCmd return net @@ -100,15 +97,8 @@ exitNetwork out net okTest = do forM_ processes $ \p -> do when (procName p == ProcNameGDB) $ do - let gdbSession = do - catchIOError (Just <$> T.getLine) (\e -> if isEOFError e then return Nothing else ioError e) >>= \case - Just line -> do - send p (T.pack "-interpreter-exec console \"" `T.append` line `T.append` T.pack "\"") - gdbSession - Nothing -> return () - outPrompt out $ T.pack "gdb> " - gdbSession + gdbSession p outClearPrompt out hClose (procStdin p) @@ -194,9 +184,7 @@ spawnOn out target pname killWith cmd = do ps <- readMVar (netProcesses net) forM_ ps $ \gdb -> do when (procName gdb == ProcNameGDB) $ do - send gdb $ T.pack $ "-add-inferior" - send gdb $ T.pack $ "-target-attach --thread-group i" ++ show (length ps) ++ " " ++ show pid - send gdb $ T.pack $ "-exec-continue --thread-group i" ++ show (length ps) + addInferior gdb (length ps) pid Nothing -> return () modifyMVar_ (netProcesses net) $ return . (process:) @@ -230,11 +218,6 @@ expect out opts p re pat = do outLine out OutputMatchFail (Just $ procName p) $ T.pack "expect failed /" `T.append` pat `T.append` T.pack "/" return False -send :: Process -> Text -> IO () -send p line = do - T.hPutStrLn (procStdin p) line - hFlush (procStdin p) - allM :: Monad m => [a] -> (a -> m Bool) -> m Bool allM (x:xs) p = p x >>= \case True -> allM xs p; False -> return False allM [] _ = return True diff --git a/src/Process.hs b/src/Process.hs index f409720..9943d30 100644 --- a/src/Process.hs +++ b/src/Process.hs @@ -2,12 +2,14 @@ module Process ( Process(..), ProcName(..), textProcName, unpackProcName, + send, ) where import Control.Concurrent.STM import Data.Text (Text) import qualified Data.Text as T +import qualified Data.Text.IO as T import System.IO import System.Posix.Signals @@ -33,3 +35,8 @@ textProcName ProcNameGDB = T.pack "gdb" unpackProcName :: ProcName -> String unpackProcName = T.unpack . textProcName + +send :: Process -> Text -> IO () +send p line = do + T.hPutStrLn (procStdin p) line + hFlush (procStdin p) |