From: Matthijs Kooijman Date: Thu, 22 Jan 2009 19:28:34 +0000 (+0100) Subject: Generate a HWFunction for the function that is being generated. X-Git-Url: https://git.stderr.nl/gitweb?a=commitdiff_plain;h=b4bfa93f7ca80deec8bef96dd4bb26c3c70c53ef;p=matthijs%2Fmaster-project%2Fc%CE%BBash.git Generate a HWFunction for the function that is being generated. --- diff --git a/Translator.hs b/Translator.hs index f16f40f..94f99f8 100644 --- a/Translator.hs +++ b/Translator.hs @@ -43,6 +43,8 @@ main = let bind = findBind "half_adder" (cm_binds core) let NonRec var expr = bind let sess = VHDLSession 0 builtin_funcs + let (sess', name, f) = mkHWFunction sess bind + let sess = addFunc sess' name f liftIO $ putStr $ showSDoc $ ppr expr liftIO $ putStr "\n\n" liftIO $ putStr $ render $ ForSyDe.Backend.Ppr.ppr $ getArchitecture sess bind @@ -245,11 +247,40 @@ data HWFunction = HWFunction { -- A function that is available in hardware --entity :: AST.EntityDec } +-- Turns a CoreExpr describing a function into a description of its input and +-- output ports. +mkHWFunction :: + VHDLSession + -> CoreBind -- The core binder to generate the interface for + -> (VHDLSession, String, HWFunction) -- The name of the function and its interface + +mkHWFunction sess (NonRec var expr) = + (sess, name, HWFunction (Args inports) outport) + where + name = (getOccString var) + ty = CoreUtils.exprType expr + (fargs, res) = Type.splitFunTys ty + args = if length fargs == 1 then fargs else (init fargs) + --state = if length fargs == 1 then () else (last fargs) + inports = case args of + -- Handle a single port specially, to prevent an extra 0 in the name + [port] -> [getPortNameMapForTy "portin" port] + ps -> getPortNameMapForTys "portin" 0 ps + outport = getPortNameMapForTy "portout" res + +mkHWFunction sess (Rec _) = + error "Recursive binders not supported" + data VHDLSession = VHDLSession { nameCount :: Int, -- A counter that can be used to generate unique names funcs :: [(String, HWFunction)] -- All functions available, indexed by name } +-- Add the function to the session +addFunc :: VHDLSession -> String -> HWFunction -> VHDLSession +addFunc sess name f = + sess {funcs = (name, f) : (funcs sess) } + builtin_funcs = [ ("hwxor", HWFunction (Args [Port "a", Port "b"]) (Port "o")),