{-# LANGUAGE CPP #-}
module Mate.Types where
-import Data.Word
import Data.Int
import qualified Data.Map as M
import qualified Data.ByteString.Lazy as B
import JVM.ClassFile
import JVM.Assembler
+import Mate.NativeSizes
+
type BlockID = Int
-- Represents a CFG node
successor :: BBEnd }
-- describes (leaving) edges of a CFG node
-data BBEnd = Return | FallThrough BlockID | OneTarget BlockID | TwoTarget BlockID BlockID deriving Show
+data BBEnd
+ = Return
+ | FallThrough BlockID
+ | OneTarget BlockID
+ | TwoTarget BlockID BlockID
+ deriving Show
type MapBB = M.Map BlockID BasicBlock
rawMapBB :: MapBB,
rawLocals :: Int,
rawStackSize :: Int,
- rawArgCount :: Word32 }
+ rawArgCount :: NativeWord,
+ rawCodeLength :: NativeWord }
--- Word32 = point of method call in generated code
+-- NativeWord = point of method call in generated code
-- MethodInfo = relevant information about callee
-type TrapMap = M.Map Word32 TrapCause
+type TrapMap = M.Map NativeWord TrapCause
-data TrapCause =
- StaticMethod MethodInfo | -- for static calls
- VirtualMethod Bool MethodInfo | -- for virtual calls
- InterfaceMethod Bool MethodInfo | -- for interface calls
- InstanceOf B.ByteString | -- class name
- StaticField StaticFieldInfo deriving Show
+data TrapCause
+ = StaticMethod MethodInfo -- for static calls
+ | VirtualCall Bool MethodInfo (IO NativeWord) -- for invoke{interface,virtual}
+ | InstanceOf B.ByteString -- class name
+ | NewObject B.ByteString -- class name
+ | StaticField StaticFieldInfo
data StaticFieldInfo = StaticFieldInfo {
sfiClassName :: B.ByteString,
-- B.ByteString = name of method
--- Word32 = entrypoint of method
-type MethodMap = M.Map MethodInfo Word32
+-- NativeWord = entrypoint of method
+type MethodMap = M.Map MethodInfo NativeWord
data MethodInfo = MethodInfo {
methName :: B.ByteString,
ciStaticMap :: FieldMap,
ciFieldMap :: FieldMap,
ciMethodMap :: FieldMap,
- ciMethodBase :: Word32,
+ ciMethodBase :: NativeWord,
ciInitDone :: Bool }
-- java strings are allocated only once, therefore we
-- use a hashmap to store the address for a String
-type StringMap = M.Map B.ByteString Word32
+type StringMap = M.Map B.ByteString NativeWord
-- map "methodtable addr" to "classname"
-- we need that to identify the actual type
-- on the invokevirtual insn
-type VirtualMap = M.Map Word32 B.ByteString
+type VirtualMap = M.Map NativeWord B.ByteString
-- store each parsed Interface upon first loading
type InterfaceMap = M.Map B.ByteString (Class Direct)
-- store offset for each <Interface><Method><Signature> pair
-type InterfaceMethodMap = M.Map B.ByteString Word32
+type InterfaceMethodMap = M.Map B.ByteString NativeWord
{-