global: pep8 (E302)

This commit is contained in:
Florent Kermarrec 2015-04-13 16:47:22 +02:00
parent d9e09707ae
commit f68423f423
73 changed files with 167 additions and 0 deletions

1
crc.py
View file

@ -1,5 +1,6 @@
import binascii
def insert_crc(i_filename, fbi_mode=False, o_filename=None):
if o_filename is None:
o_filename = i_filename

View file

@ -11,6 +11,7 @@ from misoclib.mem.sdram.phy import initsequence
from misoc_import import misoc_import
def _get_args():
parser = argparse.ArgumentParser(formatter_class=argparse.RawDescriptionHelpFormatter,
description="""\

View file

@ -1,5 +1,6 @@
import sys, importlib
def misoc_import(default, external, name):
if external:
try:

View file

@ -2,16 +2,19 @@ from migen.fhdl.std import *
from migen.genlib.cdc import MultiReg
from migen.bank.description import *
class GPIOIn(Module, AutoCSR):
def __init__(self, signal):
self._in = CSRStatus(flen(signal))
self.specials += MultiReg(signal, self._in.status)
class GPIOOut(Module, AutoCSR):
def __init__(self, signal):
self._out = CSRStorage(flen(signal))
self.comb += signal.eq(self._out.storage)
class GPIOInOut(Module):
def __init__(self, in_signal, out_signal):
self.submodules.gpio_in = GPIOIn(in_signal)
@ -20,6 +23,7 @@ class GPIOInOut(Module):
def get_csrs(self):
return self.gpio_in.get_csrs() + self.gpio_out.get_csrs()
class Blinker(Module):
def __init__(self, signal, divbits=26):
counter = Signal(divbits)

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.bank.description import *
from migen.genlib.fsm import FSM, NextState
class SPIMaster(Module, AutoCSR):
def __init__(self, pads, width=24, div=2, cpha=1):
self.pads = pads

View file

@ -4,6 +4,7 @@ from migen.sim.generic import run_simulation
from misoclib.com.spi import SPIMaster
class SPISlave(Module):
def __init__(self, pads, width):
self.pads = pads
@ -66,6 +67,7 @@ def spi_access(selfp, length, mosi):
while not (selfp.spi_master._status.status & 0x1):
yield
class TB(Module):
def __init__(self):
pads = Record([("cs_n", 1), ("clk", 1), ("mosi", 1), ("miso", 1)])

View file

@ -4,6 +4,7 @@ from migen.bank.eventmanager import *
from migen.genlib.record import Record
from migen.flow.actor import Sink, Source
class UART(Module, AutoCSR):
def __init__(self, phy):
self._rxtx = CSR(8)

View file

@ -1,6 +1,7 @@
from misoclib.com.liteeth.common import *
from misoclib.com.liteeth.generic import *
def UARTPHY(pads, *args, **kwargs):
# Autodetect PHY
if hasattr(pads, "source_stb"):

View file

@ -3,6 +3,7 @@ from migen.genlib.cdc import MultiReg
from migen.bank.description import *
from migen.flow.actor import Sink, Source
class UARTPHYSerialRX(Module):
def __init__(self, pads, tuning_word):
self.source = Source([("data", 8)])
@ -52,6 +53,7 @@ class UARTPHYSerialRX(Module):
Cat(phase_accumulator_rx, uart_clk_rxen).eq(2**31)
)
class UARTPHYSerialTX(Module):
def __init__(self, pads, tuning_word):
self.sink = Sink([("data", 8)])
@ -93,6 +95,7 @@ class UARTPHYSerialTX(Module):
)
]
class UARTPHYSerial(Module, AutoCSR):
def __init__(self, pads, clk_freq, baudrate=115200):
self._tuning_word = CSRStorage(32, reset=int((baudrate/clk_freq)*2**32))

View file

@ -3,6 +3,7 @@ import os, pty, time
from migen.fhdl.std import *
from migen.flow.actor import Sink, Source
class UARTPHYSim(Module):
def __init__(self, pads, *args, **kwargs):
self.sink = Sink([("data", 8)])

View file

@ -3,6 +3,7 @@ import os
from migen.fhdl.std import *
from migen.bus import wishbone
class LM32(Module):
def __init__(self, platform, eba_reset):
self.ibus = i = wishbone.Interface()

View file

@ -3,6 +3,7 @@ import os
from migen.fhdl.std import *
from migen.bus import wishbone
class MOR1KX(Module):
def __init__(self, platform, reset_pc):
self.ibus = i = wishbone.Interface()

View file

@ -3,6 +3,7 @@ from migen.bank.description import *
from misoclib.cpu.peripherals.identifier import git
class Identifier(Module, AutoCSR):
def __init__(self, sysid, frequency, revision=None):
self._sysid = CSRStatus(16)

View file

@ -1,5 +1,6 @@
import subprocess
def get_id():
output = subprocess.check_output(["git", "rev-parse", "HEAD"]).decode("ascii")
return int(output[:8], 16)

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.bank.description import *
from migen.bank.eventmanager import *
class Timer(Module, AutoCSR):
def __init__(self, width=32):
self._load = CSRStorage(width)

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.bus import wishbone
from migen.genlib.fsm import FSM, NextState
class NorFlash16(Module):
def __init__(self, pads, rd_timing, wr_timing):
self.bus = wishbone.Interface()

View file

@ -9,6 +9,7 @@ _FAST_READ = 0x0b
_DIOFR = 0xbb
_QIOFR = 0xeb
def _format_cmd(cmd, spi_width):
"""
`cmd` is the read instruction. Since everything is transmitted on all
@ -23,6 +24,7 @@ def _format_cmd(cmd, spi_width):
c &= ~(1<<(b*spi_width))
return c
class SpiFlash(Module, AutoCSR):
def __init__(self, pads, dummy=15, div=2, with_bitbang=True):
"""
@ -141,6 +143,7 @@ class SpiFlash(Module, AutoCSR):
self.sync += timeline(bus.cyc & bus.stb & (i == div - 1), tseq)
class SpiFlashTB(Module):
def __init__(self):
self.submodules.master = wishbone.Initiator(self.gen_reads())

View file

@ -6,6 +6,7 @@ from misoclib.mem.sdram.phy import dfii
from misoclib.mem.sdram.core import minicon, lasmicon
from misoclib.mem.sdram.core import lasmixbar
class SDRAMCore(Module, AutoCSR):
def __init__(self, phy, geom_settings, timing_settings, controller_settings, **kwargs):
# DFI

View file

@ -4,6 +4,7 @@ from migen.genlib import roundrobin
from migen.genlib.record import *
from migen.genlib.misc import optree
class Interface(Record):
def __init__(self, aw, dw, nbanks, req_queue_size, read_latency, write_latency):
self.aw = aw
@ -33,6 +34,7 @@ class Interface(Record):
]
Record.__init__(self, layout)
class Initiator(Module):
def __init__(self, generator, bus):
self.generator = generator
@ -75,6 +77,7 @@ class Initiator(Module):
else:
selfp.bus.we = 1
class TargetModel:
def __init__(self):
self.last_bank = 0
@ -96,6 +99,7 @@ class TargetModel:
self.last_bank += 1
return self.last_bank
class _ReqFIFO(Module):
def __init__(self, req_queue_size, bank):
self.req_queue_size = req_queue_size
@ -112,6 +116,7 @@ class _ReqFIFO(Module):
selfp.bank.lock = bool(self.contents)
do_simulation.passive = True
class Target(Module):
def __init__(self, model, *ifargs, **ifkwargs):
self.model = model

View file

@ -6,6 +6,7 @@ from misoclib.mem.sdram.core.lasmicon.refresher import *
from misoclib.mem.sdram.core.lasmicon.bankmachine import *
from misoclib.mem.sdram.core.lasmicon.multiplexer import *
class LASMIconSettings:
def __init__(self, req_queue_size=8,
read_time=32, write_time=16,
@ -24,6 +25,7 @@ class LASMIconSettings:
self.with_memtest = with_memtest
self.with_refresh = with_refresh
class LASMIcon(Module):
def __init__(self, phy_settings, geom_settings, timing_settings, controller_settings, **kwargs):
if phy_settings.memtype in ["SDR"]:

View file

@ -6,6 +6,7 @@ from migen.genlib.fifo import SyncFIFO
from misoclib.mem.sdram.core.lasmicon.multiplexer import *
class _AddressSlicer:
def __init__(self, colbits, address_align):
self.colbits = colbits
@ -25,6 +26,7 @@ class _AddressSlicer:
else:
return Cat(Replicate(0, self.address_align), address[:split])
class BankMachine(Module):
def __init__(self, geom_settings, timing_settings, controller_settings, address_align, bankn, req):
self.refresh_req = Signal()

View file

@ -6,6 +6,7 @@ from migen.bank.description import AutoCSR
from misoclib.mem.sdram.core.lasmicon.perf import Bandwidth
class CommandRequest:
def __init__(self, a, ba):
self.a = Signal(a)
@ -14,6 +15,7 @@ class CommandRequest:
self.ras_n = Signal(reset=1)
self.we_n = Signal(reset=1)
class CommandRequestRW(CommandRequest):
def __init__(self, a, ba):
CommandRequest.__init__(self, a, ba)
@ -23,6 +25,7 @@ class CommandRequestRW(CommandRequest):
self.is_read = Signal()
self.is_write = Signal()
class _CommandChooser(Module):
def __init__(self, requests):
self.want_reads = Signal()
@ -56,6 +59,7 @@ class _CommandChooser(Module):
for i, req in enumerate(requests)]
self.comb += rr.ce.eq(self.cmd.ack)
class _Steerer(Module):
def __init__(self, commands, dfi):
ncmd = len(commands)
@ -88,6 +92,7 @@ class _Steerer(Module):
phase.wrdata_en.eq(Array(stb_and(cmd, "is_write") for cmd in commands)[sel])
]
class Multiplexer(Module, AutoCSR):
def __init__(self, phy_settings, geom_settings, timing_settings, controller_settings, bank_machines, refresher, dfi, lasmic,
with_bandwidth=False):

View file

@ -1,6 +1,7 @@
from migen.fhdl.std import *
from migen.bank.description import *
class Bandwidth(Module, AutoCSR):
def __init__(self, cmd, data_width, period_bits=24):
self._update = CSR()

View file

@ -4,6 +4,7 @@ from migen.genlib.fsm import FSM
from misoclib.mem.sdram.core.lasmicon.multiplexer import *
class Refresher(Module):
def __init__(self, a, ba, tRP, tREFI, tRFC, enabled=True):
self.req = Signal()

View file

@ -5,6 +5,7 @@ from migen.genlib.misc import optree
from misoclib.mem.sdram.core.lasmibus import Interface
def _getattr_all(l, attr):
it = iter(l)
r = getattr(next(it), attr)
@ -13,6 +14,7 @@ def _getattr_all(l, attr):
raise ValueError
return r
class LASMIxbar(Module):
def __init__(self, controllers, cba_shift):
self._controllers = controllers

View file

@ -4,6 +4,7 @@ from migen.genlib.fsm import FSM, NextState
from misoclib.mem.sdram.phy import dfi as dfibus
class _AddressSlicer:
def __init__(self, colbits, bankbits, rowbits, address_align):
self.colbits = colbits
@ -34,10 +35,12 @@ class _AddressSlicer:
else:
return Cat(Replicate(0, self.address_align), address[:split])
class MiniconSettings:
def __init__(self):
pass
class Minicon(Module):
def __init__(self, phy_settings, geom_settings, timing_settings):
if phy_settings.memtype in ["SDR"]:

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.flow.actor import *
from migen.genlib.fifo import SyncFIFO
class Reader(Module):
def __init__(self, lasmim, fifo_depth=None):
self.address = Sink([("a", lasmim.aw)])

View file

@ -5,6 +5,7 @@ from migen.actorlib.spi import *
from misoclib.mem.sdram.frontend import dma_lasmi
@DecorateModule(InsertReset)
@DecorateModule(InsertCE)
class LFSR(Module):
@ -28,6 +29,7 @@ class LFSR(Module):
memtest_magic = 0x361f
class MemtestWriter(Module):
def __init__(self, lasmim):
self._magic = CSRStatus(16)
@ -64,6 +66,7 @@ class MemtestWriter(Module):
def get_csrs(self):
return [self._magic, self._reset, self._shoot] + self._dma.get_csrs()
class MemtestReader(Module):
def __init__(self, lasmim):
self._magic = CSRStatus(16)
@ -95,6 +98,7 @@ class MemtestReader(Module):
def get_csrs(self):
return [self._magic, self._reset, self._error_count] + self._dma.get_csrs()
class _LFSRTB(Module):
def __init__(self, *args, **kwargs):
self.submodules.dut = LFSR(*args, **kwargs)

View file

@ -5,6 +5,7 @@ from migen.genlib.fsm import FSM, NextState
from migen.genlib.misc import split, displacer, chooser
from migen.genlib.record import Record, layout_len
# cachesize (in 32-bit words) is the size of the data store, must be a power of 2
class WB2LASMI(Module, AutoCSR):
def __init__(self, cachesize, lasmim):

View file

@ -19,6 +19,7 @@ from math import ceil
from migen.fhdl.std import *
from misoclib.mem import sdram
class SDRAMModule:
def __init__(self, clk_freq, memtype, geom_settings, timing_settings):
self.clk_freq = clk_freq
@ -43,6 +44,7 @@ class SDRAMModule:
t += clk_period_ns/2
return ceil(t/clk_period_ns)
# SDR
class IS42S16160(SDRAMModule):
geom_settings = {
@ -63,6 +65,7 @@ class IS42S16160(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "SDR", self.geom_settings,
self.timing_settings)
class MT48LC4M16(SDRAMModule):
geom_settings = {
"nbanks": 4,
@ -81,6 +84,7 @@ class MT48LC4M16(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "SDR", self.geom_settings,
self.timing_settings)
class AS4C16M16(SDRAMModule):
geom_settings = {
"nbanks": 4,
@ -100,6 +104,7 @@ class AS4C16M16(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "SDR", self.geom_settings,
self.timing_settings)
# DDR
class MT46V32M16(SDRAMModule):
geom_settings = {
@ -119,6 +124,7 @@ class MT46V32M16(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "DDR", self.geom_settings,
self.timing_settings)
# LPDDR
class MT46H32M16(SDRAMModule):
geom_settings = {
@ -138,6 +144,7 @@ class MT46H32M16(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "LPDDR", self.geom_settings,
self.timing_settings)
# DDR2
class MT47H128M8(SDRAMModule):
geom_settings = {
@ -157,6 +164,7 @@ class MT47H128M8(SDRAMModule):
SDRAMModule.__init__(self, clk_freq, "DDR2", self.geom_settings,
self.timing_settings)
# DDR3
class MT8JTF12864(SDRAMModule):
geom_settings = {

View file

@ -1,6 +1,7 @@
from migen.fhdl.std import *
from migen.genlib.record import *
def phase_cmd_description(addressbits, bankbits):
return [
("address", addressbits, DIR_M_TO_S),
@ -14,6 +15,7 @@ def phase_cmd_description(addressbits, bankbits):
("reset_n", 1, DIR_M_TO_S)
]
def phase_wrdata_description(databits):
return [
("wrdata", databits, DIR_M_TO_S),
@ -21,6 +23,7 @@ def phase_wrdata_description(databits):
("wrdata_mask", databits//8, DIR_M_TO_S)
]
def phase_rddata_description(databits):
return [
("rddata_en", 1, DIR_M_TO_S),
@ -28,12 +31,14 @@ def phase_rddata_description(databits):
("rddata_valid", 1, DIR_S_TO_M)
]
def phase_description(addressbits, bankbits, databits):
r = phase_cmd_description(addressbits, bankbits)
r += phase_wrdata_description(databits)
r += phase_rddata_description(databits)
return r
class Interface(Record):
def __init__(self, addressbits, bankbits, databits, nphases=1):
layout = [("p"+str(i), phase_description(addressbits, bankbits, databits)) for i in range(nphases)]
@ -62,6 +67,7 @@ class Interface(Record):
r.append(("dfi_" + field + suffix, getattr(phase, field)))
return r
class Interconnect(Module):
def __init__(self, master, slave):
self.comb += master.connect(slave)

View file

@ -3,6 +3,7 @@ from migen.bank.description import *
from misoclib.mem.sdram.phy import dfi
class PhaseInjector(Module, AutoCSR):
def __init__(self, phase):
self._command = CSRStorage(6) # cs, we, cas, ras, wren, rden
@ -35,6 +36,7 @@ class PhaseInjector(Module, AutoCSR):
]
self.sync += If(phase.rddata_valid, self._rddata.status.eq(phase.rddata))
class DFIInjector(Module, AutoCSR):
def __init__(self, addressbits, bankbits, databits, nphases=1):
inti = dfi.Interface(addressbits, bankbits, databits, nphases)

View file

@ -28,6 +28,7 @@ from migen.fhdl.specials import *
from misoclib.mem.sdram.phy.dfi import *
from misoclib.mem import sdram
class GENSDRPHY(Module):
def __init__(self, pads, module):
addressbits = flen(pads.a)

View file

@ -1,5 +1,6 @@
from migen.fhdl.std import log2_int
def get_sdram_phy_header(sdram_phy_settings):
r = "#ifndef __GENERATED_SDRAM_PHY_H\n#define __GENERATED_SDRAM_PHY_H\n"
r += "#include <hw/common.h>\n#include <generated/csr.h>\n#include <hw/flags.h>\n\n"

View file

@ -6,6 +6,7 @@ from migen.bank.description import *
from misoclib.mem.sdram.phy.dfi import *
from misoclib.mem import sdram
class K7DDRPHY(Module, AutoCSR):
def __init__(self, pads, module):
addressbits = flen(pads.a)

View file

@ -20,6 +20,7 @@ from migen.genlib.record import *
from misoclib.mem.sdram.phy.dfi import *
from misoclib.mem import sdram
class S6DDRPHY(Module):
def __init__(self, pads, module, rd_bitslip, wr_bitslip, dqs_ddr_alignment):
if module.memtype not in ["DDR", "LPDDR", "DDR2"]:

View file

@ -11,6 +11,7 @@ from migen.fhdl.specials import *
from misoclib.mem.sdram.phy.dfi import *
from misoclib.mem import sdram
class Bank(Module):
def __init__(self, data_width, nrows, ncols):
self.activate = Signal()
@ -53,6 +54,7 @@ class Bank(Module):
)
]
class DFIPhase(Module):
def __init__(self, dfi, n):
phase = getattr(dfi, "p"+str(n))
@ -83,6 +85,7 @@ class DFIPhase(Module):
)
]
class SDRAMPHYSim(Module):
def __init__(self, module, settings):
addressbits = module.geom_settings.addressbits

View file

@ -4,6 +4,7 @@ from migen.sim.generic import run_simulation
from misoclib.mem.sdram.core import lasmibus
def my_generator(n):
bank = n % 4
for x in range(4):
@ -17,6 +18,7 @@ def my_generator(n):
print("{0}: Read {1:x} in {2} cycle(s)".format(n, t.data, t.latency))
assert(t.data == 0x1000*bank + 0x100*x)
class MyModel(lasmibus.TargetModel):
def read(self, bank, address):
r = 0x1000*bank + 0x100*address
@ -27,6 +29,7 @@ class MyModel(lasmibus.TargetModel):
print("write to bank {0} address {1:x} data {2:x}".format(bank, address, data))
assert(data == 0x1000*bank + 0x100*address)
class TB(Module):
def __init__(self):
self.submodules.controller = lasmibus.Target(MyModel(), aw=4, dw=32, nbanks=4, req_queue_size=4,

View file

@ -6,12 +6,14 @@ from misoclib.mem.sdram.core.lasmicon.bankmachine import *
from common import sdram_phy, sdram_geom, sdram_timing, CommandLogger
def my_generator():
for x in range(10):
yield True, x
for x in range(10):
yield False, 128*x
class TB(Module):
def __init__(self):
self.req = Interface(32, 32, 1,

View file

@ -9,6 +9,8 @@ MHz = 1000000
clk_freq = (83 + Fraction(1, 3))*MHz
clk_period_ns = 1000000000/clk_freq
def ns(t, margin=True):
if margin:
t += clk_period_ns/2
@ -45,6 +47,7 @@ sdram_timing = sdram.TimingSettings(
write_time=16
)
def decode_sdram(ras_n, cas_n, we_n, bank, address):
elts = []
if not ras_n and cas_n and we_n:
@ -73,6 +76,7 @@ def decode_sdram(ras_n, cas_n, we_n, bank, address):
elts.append("LMR")
return elts
class CommandLogger(Module):
def __init__(self, cmd, rw=False):
self.cmd = cmd
@ -87,6 +91,7 @@ class CommandLogger(Module):
print("\t".join(elts))
do_simulation.passive = True
class DFILogger(Module):
def __init__(self, dfi):
self.dfi = dfi

View file

@ -7,6 +7,7 @@ from misoclib.mem.sdram.frontend import dma_lasmi
from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
class TB(Module):
def __init__(self):
self.submodules.ctler = LASMIcon(sdram_phy, sdram_geom, sdram_timing)

View file

@ -6,24 +6,28 @@ from misoclib.mem.sdram.core.lasmicon import *
from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
def my_generator_r(n):
for x in range(10):
t = TRead(128*n + 48*n*x)
yield t
print("{0:3}: reads done".format(n))
def my_generator_w(n):
for x in range(10):
t = TWrite(128*n + 48*n*x, x)
yield t
print("{0:3}: writes done".format(n))
def my_generator(n):
if n % 2:
return my_generator_w(n // 2)
else:
return my_generator_r(n // 2)
class TB(Module):
def __init__(self):
self.submodules.dut = LASMIcon(sdram_phy, sdram_geom, sdram_timing)

View file

@ -11,6 +11,7 @@ from common import sdram_phy, sdram_geom, sdram_timing, DFILogger
l2_size = 8192 # in bytes
def my_generator():
for x in range(20):
t = TWrite(x, x)
@ -25,6 +26,7 @@ def my_generator():
yield t
print(str(t) + " delay=" + str(t.latency))
class TB(Module):
def __init__(self):
self.submodules.ctler = LASMIcon(sdram_phy, sdram_geom, sdram_timing)

View file

@ -15,12 +15,14 @@ clk_freq = 80000000
from math import ceil
def ns(t, margin=True):
clk_period_ns = 1000000000/clk_freq
if margin:
t += clk_period_ns/2
return ceil(t/clk_period_ns)
class MiniconTB(Module):
def __init__(self, sdrphy, dfi, sdram_geom, sdram_timing, pads, sdram_clk):
@ -76,6 +78,7 @@ class MiniconTB(Module):
while True:
yield
class MyTopLevel:
def __init__(self, vcd_name=None, vcd_level=1,
top_name="top", dut_type="dut", dut_name="dut",

View file

@ -7,6 +7,7 @@ from misoclib.mem.sdram.core.lasmicon.refresher import *
from common import CommandLogger
class Granter(Module):
def __init__(self, req, ack):
self.req = req
@ -35,6 +36,7 @@ class Granter(Module):
if len(elts) > 1:
print("\t".join(elts))
class TB(Module):
def __init__(self):
self.submodules.dut = Refresher(13, 2, tRP=3, tREFI=100, tRFC=5)

View file

@ -2,6 +2,7 @@ from fractions import Fraction
from migen.fhdl.std import *
class MXCRG(Module):
def __init__(self, pads, outfreq1x):
self.clock_domains.cd_sys = ClockDomain()

View file

@ -9,9 +9,11 @@ from misoclib.com import uart
from misoclib.cpu import lm32, mor1kx
from misoclib.cpu.peripherals import identifier, timer
def mem_decoder(address, start=26, end=29):
return lambda a: a[start:end] == ((address >> (start+2)) & (2**(end-start))-1)
class SoC(Module):
csr_map = {
"crg": 0, # user

View file

@ -1,6 +1,7 @@
from migen.fhdl.std import *
from migen.bank.description import CSRStatus
def get_cpu_mak(cpu_type):
if cpu_type == "lm32":
cpuflags = "-mbarrel-shift-enabled -mmultiply-enabled -mdivide-enabled -msign-extend-enabled"
@ -10,9 +11,11 @@ def get_cpu_mak(cpu_type):
raise ValueError("Unsupported CPU type: "+cpu_type)
return "CPU={}\nCPUFLAGS={}\n".format(cpu_type, cpuflags)
def get_linker_output_format(cpu_type):
return "OUTPUT_FORMAT(\"elf32-{}\")\n".format(cpu_type)
def get_linker_regions(regions):
r = "MEMORY {\n"
for name, origin, length in regions:
@ -20,6 +23,7 @@ def get_linker_regions(regions):
r += "}\n"
return r
def get_mem_header(regions, flash_boot_address):
r = "#ifndef __GENERATED_MEM_H\n#define __GENERATED_MEM_H\n\n"
for name, base, size in regions:
@ -29,6 +33,7 @@ def get_mem_header(regions, flash_boot_address):
r += "#endif\n"
return r
def _get_rw_functions(reg_name, reg_base, nwords, busword, read_only):
r = ""
@ -68,6 +73,7 @@ def _get_rw_functions(reg_name, reg_base, nwords, busword, read_only):
r += "}\n"
return r
def get_csr_header(regions, constants):
r = "#ifndef __GENERATED_CSR_H\n#define __GENERATED_CSR_H\n#include <hw/common.h>\n"
for name, origin, busword, obj in regions:
@ -88,6 +94,7 @@ def get_csr_header(regions, constants):
r += "\n#endif\n"
return r
def get_csr_csv(regions):
r = ""
for name, origin, busword, obj in regions:

View file

@ -8,6 +8,7 @@ from misoclib.mem.sdram.core.minicon import MiniconSettings
from misoclib.mem.sdram.frontend import memtest, wishbone2lasmi
from misoclib.soc import SoC
class SDRAMSoC(SoC):
csr_map = {
"sdram": 8,

View file

@ -11,6 +11,7 @@ from misoclib.video.dvisampler.chansync import ChanSync
from misoclib.video.dvisampler.analysis import SyncPolarity, ResolutionDetection, FrameExtraction
from misoclib.video.dvisampler.dma import DMA
class DVISampler(Module, AutoCSR):
def __init__(self, pads, lasmim, n_dma_slots=2):
self.submodules.edid = EDID(pads)

View file

@ -7,6 +7,7 @@ from migen.flow.actor import *
from misoclib.video.dvisampler.common import channel_layout
class SyncPolarity(Module):
def __init__(self):
self.valid_i = Signal()
@ -51,6 +52,7 @@ class SyncPolarity(Module):
)
]
class ResolutionDetection(Module, AutoCSR):
def __init__(self, nbits=11):
self.valid_i = Signal()
@ -105,6 +107,7 @@ class ResolutionDetection(Module, AutoCSR):
)
self.specials += MultiReg(vcounter_st, self._vres.status)
class FrameExtraction(Module, AutoCSR):
def __init__(self, word_width):
# in pix clock domain

View file

@ -7,6 +7,7 @@ from migen.bank.description import *
from misoclib.video.dvisampler.common import channel_layout
class _SyncBuffer(Module):
def __init__(self, width, depth):
self.din = Signal(width)
@ -37,6 +38,7 @@ class _SyncBuffer(Module):
]
self.sync += If(self.re, _inc(consume, depth))
class ChanSync(Module, AutoCSR):
def __init__(self, nchan=3, depth=8):
self.valid_i = Signal()
@ -87,6 +89,7 @@ class ChanSync(Module, AutoCSR):
)
self.specials += MultiReg(self.chan_synced, self._channels_synced.status)
class _TB(Module):
def __init__(self, test_seq_it):
self.test_seq_it = test_seq_it

View file

@ -5,6 +5,7 @@ from migen.bank.description import *
from misoclib.video.dvisampler.common import control_tokens
class CharSync(Module, AutoCSR):
def __init__(self, required_controls=8):
self.raw_data = Signal(10)

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.genlib.cdc import MultiReg
from migen.bank.description import *
class Clocking(Module, AutoCSR):
def __init__(self, pads):
self._pll_reset = CSRStorage(reset=1)

View file

@ -2,6 +2,7 @@ from migen.fhdl.std import *
from migen.genlib.cdc import MultiReg, PulseSynchronizer
from migen.bank.description import *
class DataCapture(Module, AutoCSR):
def __init__(self, pad_p, pad_n, ntbits):
self.serdesstrobe = Signal()

View file

@ -9,6 +9,7 @@ from misoclib.video.dvisampler.edid import EDID
from misoclib.video.dvisampler.clocking import Clocking
from misoclib.video.dvisampler.datacapture import DataCapture
class RawDVISampler(Module, AutoCSR):
def __init__(self, pads, asmiport):
self.submodules.edid = EDID(pads)

View file

@ -3,6 +3,7 @@ from migen.genlib.record import Record
from misoclib.video.dvisampler.common import control_tokens, channel_layout
class Decoding(Module):
def __init__(self):
self.valid_i = Signal()

View file

@ -6,6 +6,7 @@ from migen.flow.actor import *
from misoclib.mem.sdram.frontend import dma_lasmi
# Slot status: EMPTY=0 LOADED=1 PENDING=2
class _Slot(Module, AutoCSR):
def __init__(self, addr_bits, alignment_bits):
@ -30,6 +31,7 @@ class _Slot(Module, AutoCSR):
self.ev_source.trigger.eq(self._status.storage[1])
]
class _SlotArray(Module, AutoCSR):
def __init__(self, nslots, addr_bits, alignment_bits):
self.submodules.ev = EventManager()
@ -58,6 +60,7 @@ class _SlotArray(Module, AutoCSR):
self.comb += [slot.address_reached.eq(self.address_reached) for slot in slots]
self.comb += [slot.address_done.eq(self.address_done & (current_slot == n)) for n, slot in enumerate(slots)]
class DMA(Module):
def __init__(self, lasmim, nslots):
bus_aw = lasmim.aw

View file

@ -16,6 +16,7 @@ _default_edid = [
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x34,
]
class EDID(Module, AutoCSR):
def __init__(self, pads, default=_default_edid):
self._hpd_notif = CSRStatus()

View file

@ -5,6 +5,7 @@ from migen.genlib.cdc import PulseSynchronizer
from misoclib.video.dvisampler.common import control_tokens
class WER(Module, AutoCSR):
def __init__(self, period_bits=24):
self.data = Signal(10)

View file

@ -8,6 +8,7 @@ from misoclib.mem.sdram.frontend import dma_lasmi
from misoclib.video.framebuffer.format import bpp, pixel_layout, FrameInitiator, VTG
from misoclib.video.framebuffer.phy import Driver
class Framebuffer(Module, AutoCSR):
def __init__(self, pads_vga, pads_dvi, lasmim):
pack_factor = lasmim.dw//bpp

View file

@ -3,6 +3,7 @@ from migen.genlib.misc import optree
control_tokens = [0b1101010100, 0b0010101011, 0b0101010100, 0b1010101011]
class Encoder(Module):
def __init__(self):
self.d = Signal(8)
@ -83,6 +84,7 @@ class Encoder(Module):
cnt.eq(0)
)
class _EncoderSerializer(Module):
def __init__(self, serdesstrobe, pad_p, pad_n):
self.submodules.encoder = RenameClockDomains(Encoder(), "pix")
@ -156,6 +158,7 @@ class PHY(Module):
self.es2.de.eq(self.de),
]
class _EncoderTB(Module):
def __init__(self, inputs):
self.outs = []
@ -177,9 +180,11 @@ class _EncoderTB(Module):
if selfp.simulator.cycle_counter > 4:
self.outs.append(selfp.dut.out)
def _bit(i, n):
return (i >> n) & 1
def _decode_tmds(b):
try:
c = control_tokens.index(b)

View file

@ -16,6 +16,8 @@ pixel_layout_s = [
("g", bpc),
("b", bpc)
]
def pixel_layout(pack_factor):
return [("p"+str(i), pixel_layout_s) for i in range(pack_factor)]
@ -25,12 +27,15 @@ phy_layout_s = [
("g", bpc_phy),
("b", bpc_phy)
]
def phy_layout(pack_factor):
r = [("hsync", 1), ("vsync", 1), ("de", 1)]
for i in range(pack_factor):
r.append(("p"+str(i), phy_layout_s))
return r
class FrameInitiator(spi.SingleGenerator):
def __init__(self, bus_aw, pack_factor, ndmas=1):
h_alignment_bits = log2_int(pack_factor)
@ -59,6 +64,7 @@ class FrameInitiator(spi.SingleGenerator):
def dma_subr(self, i=0):
return ["length", "base"+str(i)]
class VTG(Module):
def __init__(self, pack_factor):
hbits_dyn = _hbits - log2_int(pack_factor)

View file

@ -7,6 +7,7 @@ from migen.flow.actor import *
from misoclib.video.framebuffer.format import bpc_phy, phy_layout
from misoclib.video.framebuffer import dvi
class _FIFO(Module):
def __init__(self, pack_factor):
self.phy = Sink(phy_layout(pack_factor))
@ -48,6 +49,7 @@ class _FIFO(Module):
)
self.comb += fifo.re.eq(unpack_counter == (pack_factor - 1))
# This assumes a 50MHz base clock
class _Clocking(Module, AutoCSR):
def __init__(self, pads_vga, pads_dvi):
@ -189,6 +191,7 @@ class _Clocking(Module, AutoCSR):
self.specials += Instance("OBUFDS", i_I=dvi_clk_se,
o_O=pads_dvi.clk_p, o_OB=pads_dvi.clk_n)
class Driver(Module, AutoCSR):
def __init__(self, pack_factor, pads_vga, pads_dvi):
fifo = _FIFO(pack_factor)

View file

@ -5,6 +5,7 @@ from misoclib.mem.sdram.phy import gensdrphy
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
from misoclib.soc.sdram import SDRAMSoC
class _PLL(Module):
def __init__(self, period_in, name, phase_shift, operation_mode):
self.clk_in = Signal()
@ -43,6 +44,7 @@ class _PLL(Module):
i_scanwrite=0
)
class _CRG(Module):
def __init__(self, platform):
self.clock_domains.cd_sys = ClockDomain()
@ -76,6 +78,7 @@ class _CRG(Module):
self.comb += platform.request("sdram_clock").eq(self.cd_sys_ps.clk)
class BaseSoC(SDRAMSoC):
default_platform = "de0nano"

View file

@ -11,6 +11,7 @@ from misoclib.soc.sdram import SDRAMSoC
from misoclib.com.liteeth.phy import LiteEthPHY
from misoclib.com.liteeth.mac import LiteEthMAC
class _CRG(Module):
def __init__(self, platform):
self.clock_domains.cd_sys = ClockDomain()
@ -67,6 +68,7 @@ class _CRG(Module):
)
self.specials += Instance("IDELAYCTRL", i_REFCLK=ClockSignal("clk200"), i_RST=ic_reset)
class BaseSoC(SDRAMSoC):
default_platform = "kc705"
@ -98,6 +100,7 @@ class BaseSoC(SDRAMSoC):
self.flash_boot_address = 0xb00000
self.register_rom(self.spiflash.bus)
class MiniSoC(BaseSoC):
csr_map = {
"ethphy": 18,

View file

@ -8,6 +8,7 @@ from misoclib.mem.sdram.phy import gensdrphy
from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
from misoclib.soc.sdram import SDRAMSoC
class _CRG(Module):
def __init__(self, platform, clk_freq):
self.clock_domains.cd_sys = ClockDomain()
@ -58,6 +59,7 @@ class _CRG(Module):
i_C0=self.cd_sys.clk, i_C1=~self.cd_sys.clk,
o_Q=platform.request("sdram_clock"))
class BaseSoC(SDRAMSoC):
default_platform = "minispartan6"

View file

@ -17,6 +17,7 @@ from misoclib.com import gpio
from misoclib.com.liteeth.phy import LiteEthPHY
from misoclib.com.liteeth.mac import LiteEthMAC
class _MXClockPads:
def __init__(self, platform):
self.clk50 = platform.request("clk50")
@ -30,6 +31,7 @@ class _MXClockPads:
self.ddr_clk_p = ddram_clock.p
self.ddr_clk_n = ddram_clock.n
class BaseSoC(SDRAMSoC):
default_platform = "mixxeo" # also supports m1
@ -64,6 +66,7 @@ INST "mxcrg/rd_bufpll" LOC = "BUFPLL_X0Y3";
""")
platform.add_source_dir(os.path.join("misoclib", "others", "mxcrg"))
class MiniSoC(BaseSoC):
csr_map = {
"ethphy": 16,
@ -95,6 +98,7 @@ class MiniSoC(BaseSoC):
self.add_wb_slave(mem_decoder(self.mem_map["ethmac"]), self.ethmac.bus)
self.add_memory_region("ethmac", self.mem_map["ethmac"]+0x80000000, 0x2000)
def get_vga_dvi(platform):
try:
pads_vga = platform.request("vga_out")
@ -110,6 +114,7 @@ PIN "dviout_pix_bufg.O" CLOCK_DEDICATED_ROUTE = FALSE;
""")
return pads_vga, pads_dvi
def add_vga_tig(platform, fb):
platform.add_platform_command("""
NET "{vga_clk}" TNM_NET = "GRPvga_clk";
@ -118,6 +123,7 @@ TIMESPEC "TSise_sucks1" = FROM "GRPvga_clk" TO "GRPsys_clk" TIG;
TIMESPEC "TSise_sucks2" = FROM "GRPsys_clk" TO "GRPvga_clk" TIG;
""", vga_clk=fb.driver.clocking.cd_pix.clk)
class FramebufferSoC(MiniSoC):
csr_map = {
"fb": 18,

View file

@ -9,6 +9,7 @@ from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
from misoclib.mem.flash import spiflash
from misoclib.soc.sdram import SDRAMSoC
class _CRG(Module):
def __init__(self, platform, clk_freq):
self.clock_domains.cd_sys = ClockDomain()
@ -86,6 +87,7 @@ class _CRG(Module):
i_C0=clk_sdram_half_shifted, i_C1=~clk_sdram_half_shifted,
o_Q=clk.n)
class BaseSoC(SDRAMSoC):
default_platform = "pipistrello"

View file

@ -9,6 +9,7 @@ from misoclib.mem.sdram.core.lasmicon import LASMIconSettings
from misoclib.mem.flash import spiflash
from misoclib.soc.sdram import SDRAMSoC
class _CRG(Module):
def __init__(self, platform, clk_freq):
self.clock_domains.cd_sys = ClockDomain()
@ -59,6 +60,7 @@ class _CRG(Module):
i_C0=self.cd_sys.clk, i_C1=~self.cd_sys.clk,
o_Q=platform.request("sdram_clock"))
class BaseSoC(SDRAMSoC):
default_platform = "papilio_pro"

View file

@ -6,6 +6,7 @@ from misoclib.soc import SoC, mem_decoder
from misoclib.com.liteeth.phy import LiteEthPHY
from misoclib.com.liteeth.mac import LiteEthMAC
class BaseSoC(SoC):
def __init__(self, platform, **kwargs):
SoC.__init__(self, platform,
@ -15,6 +16,7 @@ class BaseSoC(SoC):
**kwargs)
self.submodules.crg = CRG(platform.request(platform.default_clk_name))
class MiniSoC(BaseSoC):
csr_map = {
"ethphy": 20,

View file

@ -4,6 +4,7 @@ from migen.genlib.io import CRG
from misoclib.soc import SoC
class BaseSoC(SoC):
default_platform = "versa"
def __init__(self, platform, **kwargs):

View file

@ -54,12 +54,14 @@ crc16_table = [
0x6E17, 0x7E36, 0x4E55, 0x5E74, 0x2E93, 0x3EB2, 0x0ED1, 0x1EF0
]
def crc16(l):
crc = 0
for d in l:
crc = crc16_table[((crc >> 8) ^ d) & 0xff] ^ (crc << 8)
return crc
class SFLFrame:
def __init__(self):
self.length = None
@ -86,6 +88,7 @@ class SFLFrame:
for d in self.payload:
self.raw.append(d)
def get_file_data(filename):
with open(filename, "rb") as f:
data = []
@ -96,6 +99,7 @@ def get_file_data(filename):
data.append(int.from_bytes(w, "big"))
return data
class Flterm:
def __init__(self, kernel_image, kernel_address):
self.kernel_image = kernel_image
@ -268,6 +272,7 @@ class Flterm:
if not writer_only:
self.reader_thread.join()
def _get_args():
parser = argparse.ArgumentParser()
parser.add_argument("--port", default="2", help="serial port")