Skip to content

Commit

Permalink
Deploying to main from @ amaranth-lang/amaranth@8f6ca5a 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
whitequark committed Dec 16, 2024
1 parent f914629 commit 2bc88c4
Show file tree
Hide file tree
Showing 160 changed files with 35,118 additions and 0 deletions.
2 changes: 2 additions & 0 deletions docs/amaranth/v0.5.4/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
_build/
_linkcheck/
24 changes: 24 additions & 0 deletions docs/amaranth/v0.5.4/_code/led_blinker.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
from amaranth import *


class LEDBlinker(Elaboratable):
def elaborate(self, platform):
m = Module()

led = platform.request("led")

half_freq = int(platform.default_clk_frequency // 2)
timer = Signal(range(half_freq + 1))

with m.If(timer == half_freq):
m.d.sync += led.o.eq(~led.o)
m.d.sync += timer.eq(0)
with m.Else():
m.d.sync += timer.eq(timer + 1)

return m
# --- BUILD ---
from amaranth_boards.icestick import ICEStickPlatform


ICEStickPlatform().build(LEDBlinker(), do_program=True)
81 changes: 81 additions & 0 deletions docs/amaranth/v0.5.4/_code/up_counter.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
from amaranth import *
from amaranth.lib import wiring
from amaranth.lib.wiring import In, Out


class UpCounter(wiring.Component):
"""
A 16-bit up counter with a fixed limit.
Parameters
----------
limit : int
The value at which the counter overflows.
Attributes
----------
en : Signal, in
The counter is incremented if ``en`` is asserted, and retains
its value otherwise.
ovf : Signal, out
``ovf`` is asserted when the counter reaches its limit.
"""

en: In(1)
ovf: Out(1)

def __init__(self, limit):
self.limit = limit
self.count = Signal(16)

super().__init__()

def elaborate(self, platform):
m = Module()

m.d.comb += self.ovf.eq(self.count == self.limit)

with m.If(self.en):
with m.If(self.ovf):
m.d.sync += self.count.eq(0)
with m.Else():
m.d.sync += self.count.eq(self.count + 1)

return m
# --- TEST ---
from amaranth.sim import Simulator


dut = UpCounter(25)
async def bench(ctx):
# Disabled counter should not overflow.
ctx.set(dut.en, 0)
for _ in range(30):
await ctx.tick()
assert not ctx.get(dut.ovf)

# Once enabled, the counter should overflow in 25 cycles.
ctx.set(dut.en, 1)
for _ in range(24):
await ctx.tick()
assert not ctx.get(dut.ovf)
await ctx.tick()
assert ctx.get(dut.ovf)

# The overflow should clear in one cycle.
await ctx.tick()
assert not ctx.get(dut.ovf)


sim = Simulator(dut)
sim.add_clock(1e-6) # 1 MHz
sim.add_testbench(bench)
with sim.write_vcd("up_counter.vcd"):
sim.run()
# --- CONVERT ---
from amaranth.back import verilog


top = UpCounter(25)
with open("up_counter.v", "w") as f:
f.write(verilog.convert(top))
50 changes: 50 additions & 0 deletions docs/amaranth/v0.5.4/_code/up_counter.v
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
(* generator = "Amaranth" *)
module top(ovf, clk, rst, en);
reg \$auto$verilog_backend.cc:2255:dump_module$1 = 0;
(* src = "up_counter.py:36" *)
wire \$1 ;
(* src = "up_counter.py:42" *)
wire [16:0] \$3 ;
(* src = "up_counter.py:42" *)
wire [16:0] \$4 ;
(* src = "<site-packages>/amaranth/hdl/ir.py:509" *)
input clk;
wire clk;
(* src = "up_counter.py:29" *)
reg [15:0] count = 16'h0000;
(* src = "up_counter.py:29" *)
reg [15:0] \count$next ;
(* src = "<site-packages>/amaranth/lib/wiring.py:1647" *)
input en;
wire en;
(* src = "<site-packages>/amaranth/lib/wiring.py:1647" *)
output ovf;
wire ovf;
(* src = "<site-packages>/amaranth/hdl/ir.py:509" *)
input rst;
wire rst;
assign \$1 = count == (* src = "up_counter.py:36" *) 5'h19;
assign \$4 = count + (* src = "up_counter.py:42" *) 1'h1;
always @(posedge clk)
count <= \count$next ;
always @* begin
if (\$auto$verilog_backend.cc:2255:dump_module$1 ) begin end
\count$next = count;
(* src = "up_counter.py:38" *)
if (en) begin
(* full_case = 32'd1 *)
(* src = "up_counter.py:39" *)
if (ovf) begin
\count$next = 16'h0000;
end else begin
\count$next = \$4 [15:0];
end
end
(* src = "<site-packages>/amaranth/hdl/xfrm.py:534" *)
if (rst) begin
\count$next = 16'h0000;
end
end
assign \$3 = \$4 ;
assign ovf = \$1 ;
endmodule
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
from amaranth import *
from amaranth.lib import wiring
from amaranth.lib.wiring import In, Out


class UpCounter(wiring.Component):
"""
A 16-bit up counter with a fixed limit.
Parameters
----------
limit : int
The value at which the counter overflows.
Attributes
----------
en : Signal, in
The counter is incremented if ``en`` is asserted, and retains
its value otherwise.
ovf : Signal, out
``ovf`` is asserted when the counter reaches its limit.
"""

en: In(1)
ovf: Out(1)

def __init__(self, limit):
self.limit = limit
self.count = Signal(16)

super().__init__()

def elaborate(self, platform):
m = Module()

m.d.comb += self.ovf.eq(self.count == self.limit)

with m.If(self.en):
with m.If(self.ovf):
m.d.sync += self.count.eq(0)
with m.Else():
m.d.sync += self.count.eq(self.count + 1)

return m
# --- TEST ---
from amaranth.sim import Simulator


dut = UpCounter(25)
async def bench(ctx):
# Disabled counter should not overflow.
ctx.set(dut.en, 0)
for _ in range(30):
await ctx.tick()
assert not ctx.get(dut.ovf)

# Once enabled, the counter should overflow in 25 cycles.
ctx.set(dut.en, 1)
for _ in range(24):
await ctx.tick()
assert not ctx.get(dut.ovf)
await ctx.tick()
assert ctx.get(dut.ovf)

# The overflow should clear in one cycle.
await ctx.tick()
assert not ctx.get(dut.ovf)


sim = Simulator(dut)
sim.add_clock(1e-6) # 1 MHz
sim.add_testbench(bench)
with sim.write_vcd("up_counter.vcd"):
sim.run()
# --- CONVERT ---
from amaranth.back import verilog


top = UpCounter(25)
with open("up_counter.v", "w") as f:
f.write(verilog.convert(top))
1 change: 1 addition & 0 deletions docs/amaranth/v0.5.4/_images/simulator/example1.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions docs/amaranth/v0.5.4/_images/simulator/example2.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions docs/amaranth/v0.5.4/_images/simulator/example3.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions docs/amaranth/v0.5.4/_images/start/up_counter.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/amaranth/v0.5.4/_images/stream_pipeline.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit 2bc88c4

Please sign in to comment.