From 9df7d5291a658eda209c9bac5af5022c707bcd4a Mon Sep 17 00:00:00 2001 From: Corey Lewis Date: Mon, 31 Jan 2022 13:54:20 +1100 Subject: [PATCH] arm-hyp haskell+machine: add Exynos5 platform The default ARM_HYP target (build-arm-hyp) now uses Exynos5422 platform. This also updates the platform constants where required. Signed-off-by: Corey Lewis --- spec/haskell/Makefile | 2 +- spec/haskell/SEL4.cabal | 1 + spec/haskell/Setup.hs | 1 + .../SEL4/Machine/Hardware/ARM/Exynos5422.hs | 125 ++++++++++++++++++ spec/machine/ARM_HYP/Platform.thy | 2 +- 5 files changed, 129 insertions(+), 2 deletions(-) create mode 100644 spec/haskell/src/SEL4/Machine/Hardware/ARM/Exynos5422.hs diff --git a/spec/haskell/Makefile b/spec/haskell/Makefile index 39bce7e218..cc77c1ad53 100644 --- a/spec/haskell/Makefile +++ b/spec/haskell/Makefile @@ -48,7 +48,7 @@ build-arm: sandbox $(BOOT_FILES) $(CABAL_BUILD) --builddir="dist/arm" build-arm-hyp: sandbox $(BOOT_FILES) $(CUSTOM_BOOT_FILES) - $(CABAL_CONFIGURE) --configure-option="arm-tk1" \ + $(CABAL_CONFIGURE) --configure-option="arm-exynos5" \ --flags="ArchArmHyp -FFI" \ --builddir="dist/arm-hyp" $(RM_BACKUP) diff --git a/spec/haskell/SEL4.cabal b/spec/haskell/SEL4.cabal index a23531ee62..7b24b6211f 100644 --- a/spec/haskell/SEL4.cabal +++ b/spec/haskell/SEL4.cabal @@ -131,6 +131,7 @@ Library if flag(ArchArmHyp) other-modules: SEL4.Machine.Hardware.ARM.TK1 + SEL4.Machine.Hardware.ARM.Exynos5422 SEL4.Machine.Hardware.ARM.Callbacks SEL4.API.Types.ARM diff --git a/spec/haskell/Setup.hs b/spec/haskell/Setup.hs index 041fed17e3..11d5dc7281 100644 --- a/spec/haskell/Setup.hs +++ b/spec/haskell/Setup.hs @@ -42,6 +42,7 @@ targets = , ("arm-kzm", ("ARM", "KZM", [])) , ("arm-sabre", ("ARM", "Sabre", [])) , ("x64-pc99", ("X64", "PC99", [])) + , ("arm-exynos5", ("ARM", "Exynos5422", ["CONFIG_ARM_HYPERVISOR_SUPPORT"])) , ("arm-tk1-nosmmu",("ARM", "TK1", ["CONFIG_ARM_HYPERVISOR_SUPPORT"])) , ("arm-tk1", ("ARM", "TK1", ["CONFIG_ARM_HYPERVISOR_SUPPORT", "CONFIG_ARM_SMMU"])) diff --git a/spec/haskell/src/SEL4/Machine/Hardware/ARM/Exynos5422.hs b/spec/haskell/src/SEL4/Machine/Hardware/ARM/Exynos5422.hs new file mode 100644 index 0000000000..0a8cafcb3a --- /dev/null +++ b/spec/haskell/src/SEL4/Machine/Hardware/ARM/Exynos5422.hs @@ -0,0 +1,125 @@ +-- +-- Copyright 2014, General Dynamics C4 Systems +-- +-- SPDX-License-Identifier: GPL-2.0-only +-- + +{-# LANGUAGE EmptyDataDecls, ForeignFunctionInterface, GeneralizedNewtypeDeriving #-} + +-- this is mostly a copy of KZM with extra info for virtualisation thrown in +-- FIXME ARMHYP TODO review other constants against C! +module SEL4.Machine.Hardware.ARM.Exynos5422 where + +import Prelude hiding (Word) +import SEL4.Machine.RegisterSet +import Foreign.Ptr +import Data.Bits +import Data.Word(Word8) +import Data.Ix +import SEL4.Machine.Hardware.ARM.Callbacks + +newtype IRQ = IRQ Word8 + deriving (Enum, Ord, Ix, Eq, Show) + +instance Bounded IRQ where + minBound = IRQ 0 + maxBound = IRQ 254 + +physBase :: PAddr +physBase = PAddr 0x60000000 + +pptrBase :: VPtr +pptrBase = VPtr 0xe0000000 + +irqVGICMaintenance = IRQ 25 +irqVTimerEvent = IRQ 27 +irqSMMU = IRQ 109 + +cacheLine :: Int +cacheLine = 64 + +cacheLineBits :: Int +cacheLineBits = 6 + +{- simulator callback stubs - we do not plan to support the simulator on this + platform -} + +pageColourBits :: Int +pageColourBits = error "unimplemented" + +getMemoryRegions :: Ptr CallbackData -> IO [(PAddr, PAddr)] +getMemoryRegions _ = error "unimplemented" + +getDeviceRegions :: Ptr CallbackData -> IO [(PAddr, PAddr)] +getDeviceRegions _ = error "unimplemented" + +getKernelDevices :: Ptr CallbackData -> IO [(PAddr, PPtr Word)] +getKernelDevices _ = error "unimplemented" + +maskInterrupt :: Ptr CallbackData -> Bool -> IRQ -> IO () +maskInterrupt _ _ _ = error "unimplemented" + +ackInterrupt :: Ptr CallbackData -> IRQ -> IO () +ackInterrupt _ _ = error "unimplemented" + +getActiveIRQ :: Ptr CallbackData -> IO (Maybe IRQ) +getActiveIRQ _ = error "unimplemented" + +configureTimer :: Ptr CallbackData -> IO IRQ +configureTimer _ = error "unimplemented" + +initIRQController :: Ptr CallbackData -> IO () +initIRQController _ = error "unimplemented" + +resetTimer :: Ptr CallbackData -> IO () +resetTimer _ = error "unimplemented" + +isbCallback :: Ptr CallbackData -> IO () +isbCallback _ = error "unimplemented" + +dsbCallback :: Ptr CallbackData -> IO () +dsbCallback _ = error "unimplemented" + +dmbCallback :: Ptr CallbackData -> IO () +dmbCallback _ = error "unimplemented" + +cacheCleanByVACallback :: Ptr CallbackData -> VPtr -> PAddr -> IO () +cacheCleanByVACallback _ _ _ = error "unimplemented" + +cacheCleanByVA_PoUCallback :: Ptr CallbackData -> VPtr -> PAddr -> IO () +cacheCleanByVA_PoUCallback _ _ _ = error "unimplemented" + +cacheInvalidateByVACallback :: Ptr CallbackData -> VPtr -> PAddr -> IO () +cacheInvalidateByVACallback _ _ _ = error "unimplemented" + +cacheInvalidateByVA_ICallback :: Ptr CallbackData -> VPtr -> PAddr -> IO () +cacheInvalidateByVA_ICallback _ _ _ = error "unimplemented" + +cacheInvalidate_I_PoUCallback :: Ptr CallbackData -> IO () +cacheInvalidate_I_PoUCallback _ = error "unimplemented" + +cacheCleanInvalidateByVACallback :: + Ptr CallbackData -> VPtr -> PAddr -> IO () +cacheCleanInvalidateByVACallback _ _ _ = error "unimplemented" + +branchFlushCallback :: Ptr CallbackData -> VPtr -> PAddr -> IO () +branchFlushCallback _ _ _ = error "unimplemented" + +cacheClean_D_PoUCallback :: Ptr CallbackData -> IO () +cacheClean_D_PoUCallback _ = error "unimplemented" + +cacheCleanInvalidate_D_PoCCallback :: Ptr CallbackData -> IO () +cacheCleanInvalidate_D_PoCCallback _ = error "unimplemented" + +cacheCleanInvalidate_D_PoUCallback :: Ptr CallbackData -> IO () +cacheCleanInvalidate_D_PoUCallback _ = error "unimplemented" + +cacheCleanInvalidateL2RangeCallback :: + Ptr CallbackData -> PAddr -> PAddr -> IO () +cacheCleanInvalidateL2RangeCallback _ _ _ = error "unimplemented" + +cacheInvalidateL2RangeCallback :: Ptr CallbackData -> PAddr -> PAddr -> IO () +cacheInvalidateL2RangeCallback _ _ _ = error "unimplemented" + +cacheCleanL2RangeCallback :: Ptr CallbackData -> PAddr -> PAddr -> IO () +cacheCleanL2RangeCallback _ _ _ = error "unimplemented" diff --git a/spec/machine/ARM_HYP/Platform.thy b/spec/machine/ARM_HYP/Platform.thy index 6c121747c6..73b7779c85 100644 --- a/spec/machine/ARM_HYP/Platform.thy +++ b/spec/machine/ARM_HYP/Platform.thy @@ -76,7 +76,7 @@ definition minIRQ :: "irq" where "minIRQ \ 0" definition maxIRQ :: "irq" where - "maxIRQ \ 191" + "maxIRQ \ 254" definition irqVGICMaintenance :: "irq" where "irqVGICMaintenance \ 25"