mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
mibuild: better file organization (create directory for each vendor and move programmers in it)
This commit is contained in:
parent
5bb1c789aa
commit
b3faf5f0da
24 changed files with 73 additions and 59 deletions
|
@ -6,7 +6,7 @@ from migen.genlib.cordic import Cordic
|
||||||
from mibuild.tools import mkdir_noerror
|
from mibuild.tools import mkdir_noerror
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
class CordicImpl(Module):
|
class CordicImpl(Module):
|
||||||
def __init__(self, name, **kwargs):
|
def __init__(self, name, **kwargs):
|
||||||
|
|
0
mibuild/altera/__init__.py
Normal file
0
mibuild/altera/__init__.py
Normal file
10
mibuild/altera/programmer.py
Normal file
10
mibuild/altera/programmer.py
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
from mibuild.generic_programmer import GenericProgrammer
|
||||||
|
|
||||||
|
class USBBlaster(GenericProgrammer):
|
||||||
|
needs_bitreverse = False
|
||||||
|
|
||||||
|
def load_bitstream(self, bitstream_file, port=0):
|
||||||
|
usb_port = "[USB-"+str(port)+"]"
|
||||||
|
subprocess.call(["quartus_pgm", "-m", "jtag", "-c", "USB-Blaster"+usb_port, "-o", "p;"+bitstream_file])
|
30
mibuild/generic_programmer.py
Normal file
30
mibuild/generic_programmer.py
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
import os
|
||||||
|
|
||||||
|
class GenericProgrammer:
|
||||||
|
def __init__(self, flash_proxy_basename=None):
|
||||||
|
self.flash_proxy_basename = flash_proxy_basename
|
||||||
|
self.flash_proxy_dirs = [
|
||||||
|
"~/.migen", "/usr/local/share/migen", "/usr/share/migen",
|
||||||
|
"~/.mlabs", "/usr/local/share/mlabs", "/usr/share/mlabs"]
|
||||||
|
|
||||||
|
def set_flash_proxy_dir(self, flash_proxy_dir):
|
||||||
|
if flash_proxy_dir is not None:
|
||||||
|
self.flash_proxy_dirs = [flash_proxy_dir]
|
||||||
|
|
||||||
|
def find_flash_proxy(self):
|
||||||
|
for d in self.flash_proxy_dirs:
|
||||||
|
fulldir = os.path.abspath(os.path.expanduser(d))
|
||||||
|
fullname = os.path.join(fulldir, self.flash_proxy_basename)
|
||||||
|
if os.path.exists(fullname):
|
||||||
|
return fullname
|
||||||
|
raise OSError("Failed to find flash proxy bitstream")
|
||||||
|
|
||||||
|
# must be overloaded by specific programmer
|
||||||
|
def load_bitstream(self, bitstream_file):
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
# must be overloaded by specific programmer
|
||||||
|
def flash(self, address, data_file):
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_ios = [
|
_ios = [
|
||||||
("clk0", 0, Pins("N9"), IOStandard("LVCMOS18")),
|
("clk0", 0, Pins("N9"), IOStandard("LVCMOS18")),
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_ios = [
|
_ios = [
|
||||||
("clk3", 0, Pins("N8"), IOStandard("LVCMOS33")),
|
("clk3", 0, Pins("N8"), IOStandard("LVCMOS33")),
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
|
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.altera_quartus import AlteraQuartusPlatform
|
from mibuild.altera.quartus import AlteraQuartusPlatform
|
||||||
from mibuild.programmer import USBBlaster
|
from mibuild.altera.programmer import USBBlaster
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("clk50", 0, Pins("R8"), IOStandard("3.3-V LVTTL")),
|
("clk50", 0, Pins("R8"), IOStandard("3.3-V LVTTL")),
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_common import CRG_DS
|
from mibuild.xilinx_common import CRG_DS
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
from mibuild.xilinx_vivado import XilinxVivadoPlatform
|
from mibuild.xilinx.vivado import XilinxVivadoPlatform
|
||||||
from mibuild.programmer import XC3SProg
|
from mibuild.xilinx.programmer import XC3SProg
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_led", 0, Pins("AB8"), IOStandard("LVCMOS15")),
|
("user_led", 0, Pins("AB8"), IOStandard("LVCMOS15")),
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_btn", 0, Pins("V4"), IOStandard("LVCMOS33"),
|
("user_btn", 0, Pins("V4"), IOStandard("LVCMOS33"),
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
from mibuild.programmer import UrJTAG
|
from mibuild.xilinx.programmer import UrJTAG
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_led", 0, Pins("B16"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
("user_led", 0, Pins("B16"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
from mibuild.programmer import UrJTAG
|
from mibuild.xilinx.programmer import UrJTAG
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_led", 0, Pins("V5"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
("user_led", 0, Pins("V5"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.xilinx_common import CRG_DS
|
from mibuild.xilinx_common import CRG_DS
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
# System clock (Differential 200MHz)
|
# System clock (Differential 200MHz)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
from mibuild.programmer import XC3SProg
|
from mibuild.xilinx.programmer import XC3SProg
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_led", 0, Pins("P112"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
("user_led", 0, Pins("P112"), IOStandard("LVCMOS33"), Drive(24), Misc("SLEW=QUIETIO")),
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.xilinx_common import CRG_DS
|
from mibuild.xilinx_common import CRG_DS
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("user_led", 0, Pins("Y3")),
|
("user_led", 0, Pins("Y3")),
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("epb", 0,
|
("epb", 0,
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.xilinx_common import CRG_DS
|
from mibuild.xilinx_common import CRG_DS
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("clk64", 0,
|
("clk64", 0,
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
# Bank 34 and 35 voltage depend on J18 jumper setting
|
# Bank 34 and 35 voltage depend on J18 jumper setting
|
||||||
_io = [
|
_io = [
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild.crg import SimpleCRG
|
from mibuild.crg import SimpleCRG
|
||||||
from mibuild.xilinx_ise import XilinxISEPlatform
|
from mibuild.xilinx.ise import XilinxISEPlatform
|
||||||
|
|
||||||
_io = [
|
_io = [
|
||||||
("clk_fx", 0, Pins("L22"), IOStandard("LVCMOS33")),
|
("clk_fx", 0, Pins("L22"), IOStandard("LVCMOS33")),
|
||||||
|
|
0
mibuild/xilinx/__init__.py
Normal file
0
mibuild/xilinx/__init__.py
Normal file
|
@ -4,7 +4,8 @@ from migen.fhdl.std import *
|
||||||
from migen.fhdl.structure import _Fragment
|
from migen.fhdl.structure import _Fragment
|
||||||
|
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
from mibuild import tools, xilinx_common
|
from mibuild import tools
|
||||||
|
from mibuild.xilinx import common
|
||||||
|
|
||||||
def _format_constraint(c):
|
def _format_constraint(c):
|
||||||
if isinstance(c, Pins):
|
if isinstance(c, Pins):
|
||||||
|
@ -92,7 +93,7 @@ def _run_ise(build_name, ise_path, source, mode, ngdbuild_opt,
|
||||||
source = False
|
source = False
|
||||||
build_script_contents = "# Autogenerated by mibuild\nset -e\n"
|
build_script_contents = "# Autogenerated by mibuild\nset -e\n"
|
||||||
if source:
|
if source:
|
||||||
settings = xilinx_common.settings(ise_path, ver, "ISE_DS")
|
settings = common.settings(ise_path, ver, "ISE_DS")
|
||||||
build_script_contents += "source " + settings + "\n"
|
build_script_contents += "source " + settings + "\n"
|
||||||
if mode == "edif":
|
if mode == "edif":
|
||||||
ext = "edif"
|
ext = "edif"
|
||||||
|
@ -119,7 +120,7 @@ bitgen {bitgen_opt} {build_name}.ncd {build_name}.bit
|
||||||
if r != 0:
|
if r != 0:
|
||||||
raise OSError("Subprocess failed")
|
raise OSError("Subprocess failed")
|
||||||
|
|
||||||
class XilinxISEPlatform(xilinx_common.XilinxGenericPlatform):
|
class XilinxISEPlatform(common.XilinxGenericPlatform):
|
||||||
xst_opt = """-ifmt MIXED
|
xst_opt = """-ifmt MIXED
|
||||||
-opt_mode SPEED
|
-opt_mode SPEED
|
||||||
-register_balancing yes"""
|
-register_balancing yes"""
|
|
@ -1,31 +1,13 @@
|
||||||
import subprocess
|
import subprocess
|
||||||
import os
|
|
||||||
|
|
||||||
class Programmer:
|
from mibuild.generic_programmer import GenericProgrammer
|
||||||
def __init__(self, flash_proxy_basename=None):
|
|
||||||
self.flash_proxy_basename = flash_proxy_basename
|
|
||||||
self.flash_proxy_dirs = [
|
|
||||||
"~/.migen", "/usr/local/share/migen", "/usr/share/migen",
|
|
||||||
"~/.mlabs", "/usr/local/share/mlabs", "/usr/share/mlabs"]
|
|
||||||
|
|
||||||
def set_flash_proxy_dir(self, flash_proxy_dir):
|
|
||||||
if flash_proxy_dir is not None:
|
|
||||||
self.flash_proxy_dirs = [flash_proxy_dir]
|
|
||||||
|
|
||||||
def find_flash_proxy(self):
|
|
||||||
for d in self.flash_proxy_dirs:
|
|
||||||
fulldir = os.path.abspath(os.path.expanduser(d))
|
|
||||||
fullname = os.path.join(fulldir, self.flash_proxy_basename)
|
|
||||||
if os.path.exists(fullname):
|
|
||||||
return fullname
|
|
||||||
raise OSError("Failed to find flash proxy bitstream")
|
|
||||||
|
|
||||||
def _run_urjtag(cmds):
|
def _run_urjtag(cmds):
|
||||||
with subprocess.Popen("jtag", stdin=subprocess.PIPE) as process:
|
with subprocess.Popen("jtag", stdin=subprocess.PIPE) as process:
|
||||||
process.stdin.write(cmds.encode("ASCII"))
|
process.stdin.write(cmds.encode("ASCII"))
|
||||||
process.communicate()
|
process.communicate()
|
||||||
|
|
||||||
class UrJTAG(Programmer):
|
class UrJTAG(GenericProgrammer):
|
||||||
needs_bitreverse = True
|
needs_bitreverse = True
|
||||||
|
|
||||||
def load_bitstream(self, bitstream_file):
|
def load_bitstream(self, bitstream_file):
|
||||||
|
@ -49,7 +31,7 @@ flashmem "{address}" "{data_file}" noverify
|
||||||
""".format(flash_proxy=flash_proxy, address=address, data_file=data_file)
|
""".format(flash_proxy=flash_proxy, address=address, data_file=data_file)
|
||||||
_run_urjtag(cmds)
|
_run_urjtag(cmds)
|
||||||
|
|
||||||
class XC3SProg(Programmer):
|
class XC3SProg(GenericProgrammer):
|
||||||
needs_bitreverse = False
|
needs_bitreverse = False
|
||||||
|
|
||||||
def __init__(self, cable, flash_proxy_basename=None):
|
def __init__(self, cable, flash_proxy_basename=None):
|
||||||
|
@ -62,13 +44,3 @@ class XC3SProg(Programmer):
|
||||||
def flash(self, address, data_file):
|
def flash(self, address, data_file):
|
||||||
flash_proxy = self.find_flash_proxy()
|
flash_proxy = self.find_flash_proxy()
|
||||||
subprocess.call(["xc3sprog", "-v", "-c", self.cable, "-I"+flash_proxy, "{}:w:0x{:x}:BIN".format(data_file, address)])
|
subprocess.call(["xc3sprog", "-v", "-c", self.cable, "-I"+flash_proxy, "{}:w:0x{:x}:BIN".format(data_file, address)])
|
||||||
|
|
||||||
class USBBlaster(Programmer):
|
|
||||||
needs_bitreverse = False
|
|
||||||
|
|
||||||
def load_bitstream(self, bitstream_file, port=0):
|
|
||||||
usb_port = "[USB-"+str(port)+"]"
|
|
||||||
subprocess.call(["quartus_pgm", "-m", "jtag", "-c", "USB-Blaster"+usb_port, "-o", "p;"+bitstream_file])
|
|
||||||
|
|
||||||
def flash(self, address, data_file):
|
|
||||||
raise NotImplementedError
|
|
|
@ -7,7 +7,8 @@ from migen.fhdl.std import *
|
||||||
from migen.fhdl.structure import _Fragment
|
from migen.fhdl.structure import _Fragment
|
||||||
from mibuild.generic_platform import *
|
from mibuild.generic_platform import *
|
||||||
|
|
||||||
from mibuild import tools, xilinx_common
|
from mibuild import tools
|
||||||
|
from mibuild.xilinx import common
|
||||||
|
|
||||||
def _format_constraint(c):
|
def _format_constraint(c):
|
||||||
if isinstance(c, Pins):
|
if isinstance(c, Pins):
|
||||||
|
@ -78,7 +79,7 @@ def _run_vivado(build_name, vivado_path, source, ver=None):
|
||||||
r = subprocess.call([build_script_file])
|
r = subprocess.call([build_script_file])
|
||||||
else:
|
else:
|
||||||
build_script_contents = "# Autogenerated by mibuild\nset -e\n"
|
build_script_contents = "# Autogenerated by mibuild\nset -e\n"
|
||||||
settings = xilinx_common.settings(vivado_path, ver)
|
settings = common.settings(vivado_path, ver)
|
||||||
build_script_contents += "source " + settings + "\n"
|
build_script_contents += "source " + settings + "\n"
|
||||||
build_script_contents += "vivado -mode batch -source " + build_name + ".tcl\n"
|
build_script_contents += "vivado -mode batch -source " + build_name + ".tcl\n"
|
||||||
build_script_file = "build_" + build_name + ".sh"
|
build_script_file = "build_" + build_name + ".sh"
|
||||||
|
@ -88,9 +89,9 @@ def _run_vivado(build_name, vivado_path, source, ver=None):
|
||||||
if r != 0:
|
if r != 0:
|
||||||
raise OSError("Subprocess failed")
|
raise OSError("Subprocess failed")
|
||||||
|
|
||||||
class XilinxVivadoPlatform(xilinx_common.XilinxGenericPlatform):
|
class XilinxVivadoPlatform(common.XilinxGenericPlatform):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
xilinx_common.XilinxGenericPlatform.__init__(self, *args, **kwargs)
|
common.XilinxGenericPlatform.__init__(self, *args, **kwargs)
|
||||||
self.bitstream_commands = []
|
self.bitstream_commands = []
|
||||||
self.additional_commands = []
|
self.additional_commands = []
|
||||||
|
|
Loading…
Reference in a new issue