mirror of
https://github.com/myhdl/myhdl.git
synced 2025-01-24 21:52:56 +08:00
bug fix merge from default
--HG-- branch : 0.9-dev
This commit is contained in:
commit
7e644341e1
@ -171,9 +171,11 @@ class _ToVHDLConvertor(object):
|
||||
# add enum types to port-related set
|
||||
if isinstance(s._val, EnumItemType):
|
||||
obj = s._val._type
|
||||
assert obj in _enumTypeSet
|
||||
if obj in _enumTypeSet:
|
||||
_enumTypeSet.remove(obj)
|
||||
_enumPortTypeSet.add(obj)
|
||||
else:
|
||||
assert obj in _enumPortTypeSet
|
||||
|
||||
doc = _makeDoc(inspect.getdoc(func))
|
||||
|
||||
|
31
myhdl/test/bugs/test_enum_toVHDL.py
Normal file
31
myhdl/test/bugs/test_enum_toVHDL.py
Normal file
@ -0,0 +1,31 @@
|
||||
from myhdl import *
|
||||
|
||||
#t_state = enum('WAIT_POSEDGE', 'WAIT_NEGEDGE', encoding='one_hot')
|
||||
t_state = enum('WAIT_POSEDGE', 'WAIT_NEGEDGE')
|
||||
|
||||
def pcie_legacyint_next_state_logic(state_i, next_state_o, next_state_en_o, interrupt_pending_i, interrupt_assert_o):
|
||||
@always_comb
|
||||
def sm_output(): # state machine
|
||||
if state_i==t_state.WAIT_POSEDGE:
|
||||
interrupt_assert_o.next=0
|
||||
next_state_en_o .next=interrupt_pending_i
|
||||
next_state_o .next=t_state.WAIT_NEGEDGE
|
||||
elif state_i==t_state.WAIT_NEGEDGE:
|
||||
interrupt_assert_o.next=1
|
||||
next_state_en_o .next=not interrupt_pending_i
|
||||
next_state_o .next=t_state.WAIT_POSEDGE
|
||||
else:
|
||||
interrupt_assert_o.next=0
|
||||
next_state_en_o .next=1
|
||||
next_state_o .next=t_state.WAIT_POSEDGE
|
||||
return sm_output
|
||||
|
||||
state = Signal(t_state.WAIT_POSEDGE)
|
||||
next_state = Signal(t_state.WAIT_POSEDGE)
|
||||
next_state_en = Signal(bool(0)) # Enable transition to next state
|
||||
interrupt_pending = Signal(bool(0))
|
||||
interrupt_assert = Signal(bool(0))
|
||||
|
||||
def test_enum_toVHDL():
|
||||
toVHDL(pcie_legacyint_next_state_logic, state, next_state, next_state_en, interrupt_pending, interrupt_assert)
|
||||
|
Loading…
x
Reference in New Issue
Block a user