ethernet/rtl
Sean Anderson e2544d702f Add MII output receive interface
This generates the appropriate output for MII receive signals. Because
we don't have a clock synchronous to the recieved data, we may
occasionally have some cycles which are 32 ns or 48 ns long (instead of
the nominal 40 ns). This distorts the duty cycle to 38% or 58%,
respectively, which is within the specified 35% to 65%. This does change
the frequency to either 31 MHz or 21 MHz, respectively, which *is* a
violation of the spec. This could be avoided by introducing a FIFO to
smooth out any variations in jitter, like what RMII does.

The generation of rx_clk is a bit tricky. We can use a combinatorial
signal for the posedge, since that is what the rest of the logic is
referenced to, However, we need to register the negedge to prevent an
early (or late) ce from modifying the duty cycle.

Signed-off-by: Sean Anderson <seanga2@gmail.com>
2022-08-28 17:09:51 -04:00
..
common.vh Move default_nettype/timescale declaration to common.vh 2022-08-24 12:04:10 -04:00
descramble.v Add (de)scrambling support 2022-08-27 13:06:38 -04:00
io.vh Add pmd 2022-08-06 14:02:44 -04:00
mdio.v Add mdio module 2022-08-27 15:59:29 -04:00
mdio_io.v Add MDIO I/O module 2022-08-28 12:21:02 -04:00
mii_io_rx.v Add MII output receive interface 2022-08-28 17:09:51 -04:00
nrzi_decode.v Add NRZI support 2022-08-24 12:29:09 -04:00
nrzi_encode.v Add NRZI support 2022-08-24 12:29:09 -04:00
pcs.v pcs: Assert CRS after TX_EN sooner 2022-08-24 12:10:52 -04:00
pmd.v pmd: Consolidate initial assignment 2022-08-28 12:21:02 -04:00
scramble.v Add (de)scrambling support 2022-08-27 13:06:38 -04:00