Merge pull request #737 from stffrdhrn/or1k-linux-insns

mor1kx: Enable rotate, fpu and sign extensions under linux
This commit is contained in:
Tim Ansell 2020-12-22 09:40:53 -08:00 committed by GitHub
commit b3a0b4b60d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -15,7 +15,7 @@ from litex import get_data_mod
from litex.soc.interconnect import wishbone
from litex.soc.cores.cpu import CPU
CPU_VARIANTS = ["standard", "linux"]
CPU_VARIANTS = ["standard", "standard+fpu", "linux", "linux+fpu"]
class MOR1KX(CPU):
@ -50,7 +50,13 @@ class MOR1KX(CPU):
def gcc_flags(self):
flags = "-mhard-mul "
flags += "-mhard-div "
flags += "-mcmov "
flags += "-D__mor1kx__ "
if "linux" in self.variant:
flags += "-mror "
flags += "-msext "
return flags
@property
@ -77,7 +83,7 @@ class MOR1KX(CPU):
self.memory_buses = []
if variant == "linux":
if "linux" in variant:
self.mem_map = self.mem_map_linux
# # #
@ -107,7 +113,12 @@ class MOR1KX(CPU):
p_DBUS_WB_TYPE = "B3_REGISTERED_FEEDBACK",
)
if variant == "linux":
if "fpu" in variant:
cpu_args.update(
p_FEATURE_FPU = "ENABLED",
)
if "linux" in variant:
cpu_args.update(
# Linux needs the memory management units.
p_FEATURE_IMMU = "ENABLED",
@ -115,6 +126,8 @@ class MOR1KX(CPU):
# FIXME: Currently we need the or1k timer when we should be
# using the litex timer.
p_FEATURE_TIMER = "ENABLED",
p_FEATURE_ROR = "ENABLED",
p_FEATURE_EXT = "ENABLED",
)
# FIXME: Check if these are needed?
use_defaults = (