1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00

fixed always_comb singleton senslist handling

make sure signal name equals port name when converting
This commit is contained in:
jand 2005-07-12 10:23:45 +00:00
parent dc4eed5f90
commit 09309a2c7a
5 changed files with 12 additions and 8 deletions

View File

@ -207,10 +207,10 @@ def _checkArgs(arglist):
if isinstance(arg, GeneratorType): if isinstance(arg, GeneratorType):
waiters.append(_inferWaiter(arg)) waiters.append(_inferWaiter(arg))
elif isinstance(arg, _AlwaysComb): elif isinstance(arg, _AlwaysComb):
if isinstance(arg.senslist, tuple): if len(arg.senslist) == 1:
waiters.append(_SignalTupleWaiter(arg.gen))
else:
waiters.append(_SignalWaiter(arg.gen)) waiters.append(_SignalWaiter(arg.gen))
else:
waiters.append(_SignalTupleWaiter(arg.gen))
elif isinstance(arg, Cosimulation): elif isinstance(arg, Cosimulation):
if cosim is not None: if cosim is not None:
raise SimulationError(_error.MultipleCosim) raise SimulationError(_error.MultipleCosim)

View File

@ -168,12 +168,12 @@ class _AlwaysComb(object):
self.inputs = v.inputs self.inputs = v.inputs
self.outputs = v.outputs self.outputs = v.outputs
self.senslist = tuple([self.sigdict[n] for n in self.inputs]) self.senslist = tuple([self.sigdict[n] for n in self.inputs])
if len(self.senslist) == 1:
self.senslist = self.senslist[0]
self.gen = self.genfunc() self.gen = self.genfunc()
def genfunc(self): def genfunc(self):
senslist = self.senslist senslist = self.senslist
if len(senslist) == 1:
senslist = senslist[0]
func = self.func func = self.func
while 1: while 1:
func() func()

View File

@ -62,6 +62,7 @@ def _analyzeSigs(hierarchy):
prefixes.append(name) prefixes.append(name)
else: else:
prefixes = prefixes[:curlevel] prefixes = prefixes[:curlevel]
# print sigdict
for n, s in sigdict.items(): for n, s in sigdict.items():
if s._name is None: if s._name is None:
if len(prefixes) > 1: if len(prefixes) > 1:

View File

@ -116,10 +116,10 @@ def _writeModuleHeader(f, intf):
print >> f print >> f
for portname in intf.argnames: for portname in intf.argnames:
s = intf.argdict[portname] s = intf.argdict[portname]
if s._name != portname: if s._name is None:
print s._name
print portname
raise ToVerilogError(_error.ShadowingSignal, portname) raise ToVerilogError(_error.ShadowingSignal, portname)
# make sure signal name is equal to its port name
s._name = portname
r = _getRangeString(s) r = _getRangeString(s)
if s._driven: if s._driven:
print >> f, "output %s%s;" % (r, portname) print >> f, "output %s%s;" % (r, portname)

View File

@ -74,12 +74,14 @@ v7, v6, v5, v4, v3, v2, v1, v0 = [Signal(bool()) for i in range(N)]
objfile = "rs.o" objfile = "rs.o"
analyze_cmd = "iverilog -o %s rs.v tb_rs.v" % objfile analyze_cmd = "iverilog -o %s rs.v tb_rs.v" % objfile
simulate_cmd = "vvp -m ../../../cosimulation/icarus/myhdl.vpi %s" % objfile simulate_cmd = "vvp -m ../../../cosimulation/icarus/myhdl.vpi %s" % objfile
cmd = "cver -q +loadvpi=../../../cosimulation/cver/myhdl_vpi:vpi_compat_bootstrap rs.v tb_rs.v"
def RandomScrambler_v(o7, o6, o5, o4, o3, o2, o1, o0, def RandomScrambler_v(o7, o6, o5, o4, o3, o2, o1, o0,
i7, i6, i5, i4, i3, i2, i1, i0): i7, i6, i5, i4, i3, i2, i1, i0):
if path.exists(objfile): if path.exists(objfile):
os.remove(objfile) os.remove(objfile)
# return Cosimulation(cmd, **locals())
os.system(analyze_cmd) os.system(analyze_cmd)
return Cosimulation(simulate_cmd, **locals()) return Cosimulation(simulate_cmd, **locals())
@ -91,6 +93,7 @@ class TestRandomScrambler(TestCase):
output = intbv() output = intbv()
output_v = intbv() output_v = intbv()
for i in range(100): for i in range(100):
# while 1:
input[:] = randrange(M) input[:] = randrange(M)
i7.next = input[7] i7.next = input[7]
i6.next = input[6] i6.next = input[6]