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

37 lines
905 B
Python
Raw Normal View History

2003-02-05 22:07:33 +00:00
from __future__ import generators
from myhdl import Signal, delay, posedge, now, Simulation
def clkGen(clock, period=20):
lowTime = int(period/2)
highTime = period - lowTime
while 1:
yield delay(lowTime)
clock.next = 1
yield delay(highTime)
clock.next = 0
def sayHello(clock, to="World!"):
while 1:
yield posedge(clock)
print "%s Hello %s" % (now(), to)
def greetings():
clk1 = Signal(0)
clk2 = Signal(0)
clkGen1 = clkGen(clk1) # positional and default association
clkGen2 = clkGen(clock=clk2, period=19) # named assocation
sayHello1 = sayHello(clock=clk1) # named and default association
sayHello2 = sayHello(to="MyHDL", clock=clk2) # named assocation
return clkGen1, clkGen2, sayHello1, sayHello2
2003-06-30 14:24:23 +00:00
def main():
sim = Simulation(greetings())
sim.run(50)
if __name__ == '__main__':
main()
2003-02-05 22:07:33 +00:00