Skip to content

Commit

Permalink
Merge pull request #248 from miek/phy_startup
Browse files Browse the repository at this point in the history
gateware.interface.ulpi: wait for min Tstart time before using the bus
  • Loading branch information
mossmann authored May 15, 2024
2 parents 8378945 + cf6abaa commit 6601d4e
Showing 1 changed file with 14 additions and 2 deletions.
16 changes: 14 additions & 2 deletions luna/gateware/interface/ulpi.py
Original file line number Diff line number Diff line change
Expand Up @@ -688,6 +688,8 @@ class UTMITranslator(Elaboratable):
"""

_CYCLES_1_MILLISECONDS = 60000

# UTMI status signals translated from the ULPI bus.
RXEVENT_STATUS_SIGNALS = [
('line_state', 2), ('vbus_valid', 1), ('session_valid', 1), ('session_end', 1),
Expand Down Expand Up @@ -850,9 +852,19 @@ def elaborate(self, platform):


# Hook up our reset signal iff our ULPI bus has one.
phy_ready = Signal()
if hasattr(self.ulpi, 'rst'):
m.d.comb += self.ulpi.rst.o.eq(ResetSignal(raw_clock_domain)),

# After reset, DIR may not be driven high immediately.
# Before using the bus, wait for the minimum Tstart time according to [USB334x: Table 4.3].
startup_counter = Signal(range(self._CYCLES_1_MILLISECONDS + 1))
m.d.usb += startup_counter.eq(startup_counter + 1)
with m.If(startup_counter == self._CYCLES_1_MILLISECONDS):
m.d.usb += phy_ready.eq(1)
else:
m.d.usb += phy_ready.eq(1)


# Connect our ULPI control signals to each of our subcomponents.
m.d.comb += [
Expand All @@ -871,13 +883,13 @@ def elaborate(self, platform):
# Connect our inputs to our transmit translator.
transmit_translator.ulpi_nxt .eq(self.ulpi.nxt.i),
transmit_translator.op_mode .eq(self.op_mode),
transmit_translator.bus_idle .eq(~control_translator.busy & ~self.ulpi.dir.i),
transmit_translator.bus_idle .eq(~control_translator.busy & ~self.ulpi.dir.i & phy_ready),
transmit_translator.tx_data .eq(self.tx_data),
transmit_translator.tx_valid .eq(self.tx_valid),
self.tx_ready .eq(transmit_translator.tx_ready),

# Connect our inputs to our control translator / register window.
control_translator.bus_idle .eq(~transmit_translator.busy),
control_translator.bus_idle .eq(~transmit_translator.busy & phy_ready),
register_window.ulpi_data_in .eq(self.ulpi.data.i),
register_window.ulpi_dir .eq(self.ulpi.dir.i),
register_window.ulpi_next .eq(self.ulpi.nxt.i),
Expand Down

0 comments on commit 6601d4e

Please sign in to comment.