cores/dvi_sampler: fix imports

This commit is contained in:
Sebastien Bourdeauducq 2015-11-01 22:38:06 +08:00
parent ca9631f7d3
commit 2a818661e1
12 changed files with 53 additions and 41 deletions

View file

@ -1 +1 @@
from misoc.dvisampler.core import DVISampler
from misoc.cores.dvi_sampler.core import DVISampler

View file

@ -2,10 +2,9 @@ from migen import *
from migen.genlib.cdc import MultiReg, PulseSynchronizer
from migen.genlib.fifo import AsyncFIFO
from migen.genlib.record import Record
from migen.bank.description import *
from migen.flow.actor import *
from misoc.dvisampler.common import channel_layout
from misoc.interconnect.csr import *
from misoc.cores.dvi_sampler.common import channel_layout
class SyncPolarity(Module):

View file

@ -1,11 +1,13 @@
from functools import reduce
from operator import or_, and_
from migen import *
from migen.genlib.cdc import MultiReg
from migen.genlib.fifo import _inc
from migen.genlib.record import Record, layout_len
from migen.genlib.misc import optree
from migen.bank.description import *
from misoc.dvisampler.common import channel_layout
from misoc.interconnect.csr import *
from misoc.cores.dvi_sampler.common import channel_layout
class _SyncBuffer(Module):
@ -73,8 +75,8 @@ class ChanSync(Module, AutoCSR):
some_control = Signal()
self.comb += [
all_control.eq(optree("&", lst_control)),
some_control.eq(optree("|", lst_control))
all_control.eq(reduce(and_, lst_control)),
some_control.eq(reduce(or_, lst_control))
]
self.sync.pix += If(~self.valid_i,
self.chan_synced.eq(0)

View file

@ -1,9 +1,11 @@
from functools import reduce
from operator import or_
from migen import *
from migen.genlib.cdc import MultiReg
from migen.genlib.misc import optree
from migen.bank.description import *
from misoc.dvisampler.common import control_tokens
from misoc.interconnect.csr import *
from misoc.cores.dvi_sampler.common import control_tokens
class CharSync(Module, AutoCSR):
@ -26,7 +28,7 @@ class CharSync(Module, AutoCSR):
control_position = Signal(max=10)
self.sync.pix += found_control.eq(0)
for i in range(10):
self.sync.pix += If(optree("|", [raw[i:i+10] == t for t in control_tokens]),
self.sync.pix += If(reduce(or_, [raw[i:i+10] == t for t in control_tokens]),
found_control.eq(1),
control_position.eq(i)
)

View file

@ -1,6 +1,7 @@
from migen import *
from migen.genlib.cdc import MultiReg
from migen.bank.description import *
from misoc.interconnect.csr import *
class Clocking(Module, AutoCSR):

View file

@ -1,15 +1,15 @@
from migen import *
from migen.bank.description import AutoCSR
from misoc.dvisampler.edid import EDID
from misoc.dvisampler.clocking import Clocking
from misoc.dvisampler.datacapture import DataCapture
from misoc.dvisampler.charsync import CharSync
from misoc.dvisampler.wer import WER
from misoc.dvisampler.decoding import Decoding
from misoc.dvisampler.chansync import ChanSync
from misoc.dvisampler.analysis import SyncPolarity, ResolutionDetection, FrameExtraction
from misoc.dvisampler.dma import DMA
from misoc.interconnect.csr import AutoCSR
from misoc.cores.dvi_sampler.edid import EDID
from misoc.cores.dvi_sampler.clocking import Clocking
from misoc.cores.dvi_sampler.datacapture import DataCapture
from misoc.cores.dvi_sampler.charsync import CharSync
from misoc.cores.dvi_sampler.wer import WER
from misoc.cores.dvi_sampler.decoding import Decoding
from misoc.cores.dvi_sampler.chansync import ChanSync
from misoc.cores.dvi_sampler.analysis import SyncPolarity, ResolutionDetection, FrameExtraction
from misoc.cores.dvi_sampler.dma import DMA
class DVISampler(Module, AutoCSR):

View file

@ -1,6 +1,7 @@
from migen import *
from migen.genlib.cdc import MultiReg, PulseSynchronizer
from migen.bank.description import *
from misoc.interconnect.csr import *
class DataCapture(Module, AutoCSR):

View file

@ -1,13 +1,14 @@
from migen import *
from migen.genlib.fifo import AsyncFIFO
from migen.genlib.record import layout_len
from migen.bank.description import AutoCSR
from migen.actorlib import structuring, spi
from misoc.mem.sdram.frontend import dma_lasmi
from misoc.dvisampler.edid import EDID
from misoc.dvisampler.clocking import Clocking
from misoc.dvisampler.datacapture import DataCapture
from misoc.cores.dvi_sampler.edid import EDID
from misoc.cores.dvi_sampler.clocking import Clocking
from misoc.cores.dvi_sampler.datacapture import DataCapture
# TODO
#from misoc.mem.sdram.frontend import dma_lasmi
class RawDVISampler(Module, AutoCSR):

View file

@ -1,7 +1,7 @@
from migen import *
from migen.genlib.record import Record
from misoc.dvisampler.common import control_tokens, channel_layout
from misoc.cores.dvi_sampler.common import control_tokens, channel_layout
class Decoding(Module):

View file

@ -1,10 +1,12 @@
from migen import *
from migen.genlib.fsm import FSM, NextState
from migen.bank.description import *
from migen.bank.eventmanager import *
from migen.flow.actor import *
from misoc.mem.sdram.frontend import dma_lasmi
from misoc.interconnect.csr import *
from misoc.interconnect.csr_eventmanager import *
# TODO: rewrite dma_lasmi module
# TODO: use stream packets to resync DMA
#from misoc.mem.sdram.frontend import dma_lasmi
# Slot status: EMPTY=0 LOADED=1 PENDING=2

View file

@ -3,7 +3,9 @@ from migen.fhdl.specials import Tristate
from migen.genlib.cdc import MultiReg
from migen.genlib.fsm import FSM, NextState
from migen.genlib.misc import chooser
from migen.bank.description import CSRStorage, CSRStatus, AutoCSR
from misoc.interconnect.csr import CSRStorage, CSRStatus, AutoCSR
_default_edid = [
0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x3D, 0x17, 0x32, 0x12, 0x2A, 0x6A, 0xBF, 0x00,

View file

@ -1,9 +1,11 @@
from functools import reduce
from operator import add, or_
from migen import *
from migen.bank.description import *
from migen.genlib.misc import optree
from migen.genlib.cdc import PulseSynchronizer
from misoc.dvisampler.common import control_tokens
from misoc.interconnect.csr import *
from misoc.cores.dvi_sampler.common import control_tokens
class WER(Module, AutoCSR):
@ -23,10 +25,10 @@ class WER(Module, AutoCSR):
transitions = Signal(8)
self.comb += [transitions[i].eq(data_r[i] ^ data_r[i+1]) for i in range(8)]
transition_count = Signal(max=9)
self.sync.pix += transition_count.eq(optree("+", [transitions[i] for i in range(8)]))
self.sync.pix += transition_count.eq(reduce(add, [transitions[i] for i in range(8)]))
is_control = Signal()
self.sync.pix += is_control.eq(optree("|", [data_r == ct for ct in control_tokens]))
self.sync.pix += is_control.eq(reduce(or_, [data_r == ct for ct in control_tokens]))
# pipeline stage 3
is_error = Signal()