-
Notifications
You must be signed in to change notification settings - Fork 309
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[DC CAPI][PyCDE] Add cmerge and demux handshake ops
- Adds cmerge and demux functions to the handshake pycde module. - Lowering them requires fixes to the conversion pass and the CAPI code.
- Loading branch information
Showing
5 changed files
with
59 additions
and
21 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,42 +1,50 @@ | ||
# RUN: %PYTHON% %s | FileCheck %s | ||
|
||
from pycde import (Clock, Output, Input, generator, types, Module) | ||
from pycde.handshake import Func | ||
from pycde.handshake import Func, cmerge, demux | ||
from pycde.testing import unittestmodule | ||
from pycde.types import Bits, Channel | ||
|
||
# CHECK: hw.module @Top(in %clk : !seq.clock, in %rst : i1, in %a : !esi.channel<i8>, out x : !esi.channel<i8>) | ||
# CHECK: [[R0:%.+]] = handshake.esi_instance @TestFunc "TestFunc" clk %clk rst %rst(%a) : (!esi.channel<i8>) -> !esi.channel<i8> | ||
# CHECK: hw.output [[R0]] : !esi.channel<i8> | ||
# CHECK: } | ||
# CHECK: handshake.func @TestFunc(%arg0: i8, ...) -> i8 | ||
# CHECK: hw.module @Top(in %clk : !seq.clock, in %rst : i1, in %a : !esi.channel<i8>, in %b : !esi.channel<i8>, out x : !esi.channel<i8>) | ||
# CHECK: %0:2 = handshake.esi_instance @TestFunc "TestFunc" clk %clk rst %rst(%a, %b) : (!esi.channel<i8>, !esi.channel<i8>) -> (!esi.channel<i8>, !esi.channel<i8>) | ||
# CHECK: hw.output %0#0 : !esi.channel<i8> | ||
|
||
# CHECK: handshake.func @TestFunc(%arg0: i8, %arg1: i8, ...) -> (i8, i8) | ||
# CHECK: %result, %index = control_merge %arg0, %arg1 : i8, i1 | ||
# CHECK: %c15_i8 = hw.constant 15 : i8 | ||
# CHECK: %0 = comb.and bin %arg0, %c15_i8 : i8 | ||
# CHECK: return %0 : i8 | ||
# CHECK: } | ||
# CHECK: [[R0:%.+]] = comb.and bin %result, %c15_i8 : i8 | ||
# CHECK: %trueResult, %falseResult = cond_br %index, [[R0]] : i8 | ||
# CHECK: return %trueResult, %falseResult : i8, i8 | ||
|
||
|
||
class TestFunc(Func): | ||
a = Input(Bits(8)) | ||
b = Input(Bits(8)) | ||
x = Output(Bits(8)) | ||
y = Output(Bits(8)) | ||
|
||
@generator | ||
def build(ports): | ||
ports.x = ports.a & Bits(8)(0xF) | ||
c, sel = cmerge(ports.a, ports.b) | ||
z = c & Bits(8)(0xF) | ||
x, y = demux(sel, z) | ||
ports.x = x | ||
ports.y = y | ||
|
||
|
||
BarType = types.struct({"foo": types.i12}, "bar") | ||
|
||
|
||
@unittestmodule(print=True, run_passes=True) | ||
@unittestmodule(print=True) | ||
class Top(Module): | ||
clk = Clock() | ||
rst = Input(Bits(1)) | ||
|
||
a = Input(Channel(Bits(8))) | ||
b = Input(Channel(Bits(8))) | ||
x = Output(Channel(Bits(8))) | ||
|
||
@generator | ||
def build(ports): | ||
test = TestFunc(clk=ports.clk, rst=ports.rst, a=ports.a) | ||
test = TestFunc(clk=ports.clk, rst=ports.rst, a=ports.a, b=ports.b) | ||
ports.x = test.x |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters