build/generic_platform build/xxx/platform soc/integration/builder:

generic_platform add a method to return extension for sram/flash
vendor platform: bitstream_ext -> _bitstream_ext and replace by a dict
when extension depends on mode
builder: use `get_bitstream_extension` instead of directly using
bitstream_ext
This commit is contained in:
Gwenhael Goavec-Merou 2023-03-04 11:36:29 +01:00
parent 1ea94ca264
commit c40963531c
11 changed files with 48 additions and 14 deletions

View file

@ -13,7 +13,10 @@ from litex.build.altera import common, quartus
# AlteraPlatform -----------------------------------------------------------------------------------
class AlteraPlatform(GenericPlatform):
bitstream_ext = ".sof"
_bitstream_ext = {
"sram" : ".sof",
"flash" : ".rbf"
}
create_rbf = True
_supported_toolchains = ["quartus"]

View file

@ -13,7 +13,7 @@ from litex.build.anlogic import common, anlogic
# AnlogicPlatform ----------------------------------------------------------------------------------
class AnlogicPlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = ".bit"
_supported_toolchains = ["td"]

View file

@ -16,7 +16,10 @@ from litex.build.efinix import EfinixDbParser
# EfinixPlatform -----------------------------------------------------------------------------------
class EfinixPlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = {
"sram" : ".bit",
"flash" : ".hex"
}
_supported_toolchains = ["efinity"]

View file

@ -323,6 +323,9 @@ class ConstraintManager:
class GenericPlatform:
device_family = None
_bitstream_ext = None # None by default, overridden by vendor platform, may
# be a string when same extension is used for sram and
# flash. A dict must be provided otherwise
def __init__(self, device, io, connectors=[], name=None):
self.toolchain = None
@ -463,6 +466,31 @@ class GenericPlatform:
def build(self, fragment):
raise NotImplementedError("GenericPlatform.build must be overloaded")
def get_bitstream_extension(self, mode="sram"):
"""
Return the bitstream's extension according to mode (sram / flash).
The default (generic) implementation check if `self._bitstream_ext`
is a dict or a string. For former case it return extension using `mode`
parameter, in latter case simply return `self._bitstream_ext`'s value.
When this behaviour is not adapted this method must be overriden by
a specific one at vendor level.
Parameters
----------
mode: str
bitstream destination (must be sram or flash)
Returns
-------
bitstream extension: str
"""
if self._bitstream_ext is None:
return None
elif type(self._bitstream_ext) == dict:
return self._bitstream_ext[mode]
else:
return self._bitstream_ext
def create_programmer(self):
raise NotImplementedError

View file

@ -13,7 +13,7 @@ from litex.build.gowin import common, gowin
# GowinPlatform ------------------------------------------------------------------------------------
class GowinPlatform(GenericPlatform):
bitstream_ext = ".fs"
_bitstream_ext = ".fs"
_supported_toolchains = ["gowin", "apicula"]

View file

@ -11,7 +11,7 @@ from litex.build.lattice import common, diamond, icestorm, trellis, radiant, oxi
# LatticePlatform ----------------------------------------------------------------------------------
class LatticePlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = ".bit"
_supported_toolchains = {
"ice40" : ["icestorm"],
@ -26,7 +26,7 @@ class LatticePlatform(GenericPlatform):
elif toolchain == "trellis":
self.toolchain = trellis.LatticeTrellisToolchain()
elif toolchain == "icestorm":
self.bitstream_ext = ".bin"
self._bitstream_ext = ".bin"
self.toolchain = icestorm.LatticeIceStormToolchain()
elif toolchain == "radiant":
self.toolchain = radiant.LatticeRadiantToolchain()

View file

@ -10,7 +10,7 @@ from litex.build.microsemi import common, libero_soc
# MicrosemiPlatform --------------------------------------------------------------------------------
class MicrosemiPlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = ".bit"
_supported_toolchains = ["libero_soc_polarfire"]

View file

@ -12,7 +12,7 @@ from litex.build.osfpga import common, osfpga
# OSFPGAPlatform -----------------------------------------------------------------------------------
class OSFPGAPlatform(GenericPlatform):
bitstream_ext = ".bin"
_bitstream_ext = ".bin"
_supported_toolchains = ["osfpga"]

View file

@ -12,7 +12,7 @@ from litex.build.quicklogic import common, f4pga
# QuickLogicPlatform -------------------------------------------------------------------------------
class QuickLogicPlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = ".bit"
_supported_toolchains = ["f4pga"]

View file

@ -14,7 +14,10 @@ from litex.build.xilinx import common, vivado, ise, yosys_nextpnr
# XilinxPlatform -----------------------------------------------------------------------------------
class XilinxPlatform(GenericPlatform):
bitstream_ext = ".bit"
_bitstream_ext = {
"sram" : ".bit",
"flash" : ".bin"
}
_supported_toolchains = {
"spartan6" : ["ise"],

View file

@ -382,10 +382,7 @@ class Builder:
def get_bitstream_filename(self, mode="sram", ext=None):
assert mode in ["sram", "flash"]
if ext is None:
ext = {
"sram" : self.soc.platform.bitstream_ext,
"flash" : ".bin" # FIXME.
}[mode]
ext = self.soc.platform.get_bitstream_extension(mode)
return os.path.join(self.gateware_dir, self.soc.get_build_name() + ext)
# Builder Arguments --------------------------------------------------------------------------------