コード例 #1
0
def test_sub_access_non_vector():
    sa = SubAccess(n("vc", uw(8)), u(2, w(3)), uw(8))
    assert not check(sa)

    sa = SubAccess(n("vc", bdl(a=(vec(uw(8), 10), True))),
                   u(2, w(3)), vec(uw(8), 10))
    assert not check(sa)
コード例 #2
0
ファイル: test_asuint.py プロジェクト: zhongzc/py-hcl
def test_asuint():
    basis_tester(asuint_basis_cases)
    encounter_error_tester(asuint_type_wrong_cases)
    encounter_error_tester(asuint_width_wrong_cases)
    serialize_equal(AsUInt(u(20, w(5)), uw(5)), 'asUInt(UInt<5>("h14"))')
    serialize_equal(AsUInt(s(-20, w(6)), uw(5)), 'asUInt(SInt<6>("h-14"))')
    serialize_equal(AsUInt(n("clock", ClockType()), uw(1)), 'asUInt(clock)')
コード例 #3
0
ファイル: test_module.py プロジェクト: zhongzc/py-hcl
def test_module_basis():
    mod = DefModule("m", [OutputPort("p", uw(8))],
                    Connect(n("p", uw(8)), u(2, w(8))))
    assert check(mod)
    serialize_stmt_equal(
        mod, 'module m :\n'
        '  output p : UInt<8>\n'
        '\n'
        '  p <= UInt<8>("h2")')

    mod = DefModule(
        "m",
        [InputPort("b", uw(8)), OutputPort("a", uw(8))],
        Block([
            DefNode("n", u(1, w(1))),
            Conditionally(n("n", uw(1)), EmptyStmt(),
                          Connect(n("a", uw(8)), n("b", uw(8))))
        ]))
    assert check(mod)
    serialize_stmt_equal(
        mod, 'module m :\n'
        '  input b : UInt<8>\n'
        '  output a : UInt<8>\n'
        '\n'
        '  node n = UInt<1>("h1")\n'
        '  when n :\n'
        '    skip\n'
        '  else :\n'
        '    a <= b')
コード例 #4
0
def test_circuit_basis():
    m1 = DefModule("m1", [OutputPort("p", uw(8))],
                   Connect(n("p", uw(8)), u(2, w(8))))

    m2 = DefModule(
        "m2",
        [InputPort("b", uw(8)), OutputPort("a", uw(8))],
        Block([
            DefNode("n", u(1, w(1))),
            Conditionally(n("n", uw(1)), EmptyStmt(),
                          Connect(n("a", uw(8)), n("b", uw(8))))
        ]))
    ct = DefCircuit("m1", [m1, m2])
    assert check(ct)
    serialize_stmt_equal(
        ct, 'circuit m1 :\n'
        '  module m1 :\n'
        '    output p : UInt<8>\n'
        '\n'
        '    p <= UInt<8>("h2")\n'
        '\n'
        '  module m2 :\n'
        '    input b : UInt<8>\n'
        '    output a : UInt<8>\n'
        '\n'
        '    node n = UInt<1>("h1")\n'
        '    when n :\n'
        '      skip\n'
        '    else :\n'
        '      a <= b\n'
        '\n')
コード例 #5
0
ファイル: test_neg.py プロジェクト: zhongzc/py-hcl
def test_neg():
    basis_tester(neg_basis_cases)
    encounter_error_tester(neg_type_wrong_cases)
    encounter_error_tester(neg_width_wrong_cases)
    serialize_equal(Neg(u(20, w(5)), sw(6)),
                    'neg(UInt<5>("h14"))')
    serialize_equal(Neg(s(-20, w(6)), sw(7)),
                    'neg(SInt<6>("h-14"))')
コード例 #6
0
ファイル: test_mul.py プロジェクト: zhongzc/py-hcl
def test_mul():
    basis_tester(mul_basis_cases)
    encounter_error_tester(mul_type_wrong_cases)
    encounter_error_tester(mul_width_wrong_cases)
    serialize_equal(Mul([u(20, w(5)), u(15, w(4))], uw(9)),
                    'mul(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Mul([s(-20, w(6)), s(-15, w(5))], sw(11)),
                    'mul(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #7
0
def test_sub():
    basis_tester(sub_basis_cases)
    encounter_error_tester(sub_type_wrong_cases)
    encounter_error_tester(sub_width_wrong_cases)
    serialize_equal(Sub([u(20, w(5)), u(15, w(4))], sw(6)),
                    'sub(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Sub([s(-20, w(6)), s(-15, w(5))], sw(7)),
                    'sub(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #8
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_write_port_clock_wrong():
    mem_ref = n("m", vec(uw(8), 10))
    mw = DefMemWritePort("mw", mem_ref, u(2, w(8)), n("clock", uw(1)))
    assert not check(mw)

    mem_ref = n("m", vec(bdl(a=(uw(8), False)), 10))
    mw = DefMemWritePort("mw", mem_ref, n("a", uw(2)), u(0, w(1)))
    assert not check(mw)
コード例 #9
0
ファイル: test_and.py プロジェクト: zhongzc/py-hcl
def test_and():
    basis_tester(and_basis_cases)
    encounter_error_tester(and_type_wrong_cases)
    encounter_error_tester(and_width_wrong_cases)
    serialize_equal(And([u(20, w(5)), u(15, w(4))], uw(5)),
                    'and(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(And([s(-20, w(6)), s(-15, w(5))], uw(6)),
                    'and(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #10
0
def test_dshr():
    basis_tester(dshr_basis_cases)
    encounter_error_tester(dshr_type_wrong_cases)
    encounter_error_tester(dshr_width_wrong_cases)
    serialize_equal(Dshr([u(20, w(5)), u(15, w(4))], uw(5)),
                    'dshr(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Dshr([s(-20, w(6)), u(15, w(4))], uw(6)),
                    'dshr(SInt<6>("h-14"), UInt<4>("hf"))')
コード例 #11
0
def test_rem():
    basis_tester(rem_basis_cases)
    encounter_error_tester(rem_type_wrong_cases)
    encounter_error_tester(rem_width_wrong_cases)
    serialize_equal(Rem([u(20, w(5)), u(15, w(4))], uw(4)),
                    'rem(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Rem([s(-20, w(6)), s(-15, w(5))], sw(5)),
                    'rem(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #12
0
ファイル: test_register.py プロジェクト: zhongzc/py-hcl
def test_init_register_type_not_match():
    r1 = DefInitRegister("r1", uw(8), n("clock", ClockType()), n("r", uw(1)),
                         s(5, w(8)))
    assert not check(r1)

    r2 = DefInitRegister("r2", uw(8), n("clock", ClockType()), u(0, w(1)),
                         s(5, w(8)))
    assert not check(r2)
コード例 #13
0
def test_leq():
    basis_tester(leq_basis_cases)
    encounter_error_tester(leq_type_wrong_cases)
    encounter_error_tester(leq_width_wrong_cases)
    serialize_equal(Leq([u(20, w(5)), u(15, w(4))], uw(1)),
                    'leq(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Leq([s(-20, w(6)), s(-15, w(5))], uw(1)),
                    'leq(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #14
0
ファイル: test_shr.py プロジェクト: zhongzc/py-hcl
def test_shr():
    basis_tester(shr_basis_cases)
    encounter_error_tester(shr_type_wrong_cases)
    encounter_error_tester(shr_width_wrong_cases)
    serialize_equal(Shr(u(20, w(5)), 3, uw(2)),
                    'shr(UInt<5>("h14"), 3)')
    serialize_equal(Shr(s(-20, w(6)), 3, uw(3)),
                    'shr(SInt<6>("h-14"), 3)')
コード例 #15
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_read_port_clock_wrong():
    mem_ref = n("m", vec(uw(8), 10))
    mr = DefMemReadPort("mr", mem_ref, u(2, w(8)), n("clock", uw(1)))
    assert not check(mr)

    mem_ref = n("m", vec(bdl(a=(uw(8), False)), 10))
    mr = DefMemReadPort("mr", mem_ref, n("a", uw(2)), u(0, w(1)))
    assert not check(mr)
コード例 #16
0
ファイル: test_register.py プロジェクト: zhongzc/py-hcl
def test_init_register_reset_wrong():
    r1 = DefInitRegister("r1", uw(8), n("clock", ClockType()), n("r", sw(1)),
                         u(5, w(8)))
    assert not check(r1)

    r2 = DefInitRegister("r2", sw(8), n("clock", ClockType()), s(0, w(1)),
                         s(5, w(8)))
    assert not check(r2)
コード例 #17
0
def test_cat():
    basis_tester(cat_basis_cases)
    encounter_error_tester(cat_type_wrong_cases)
    encounter_error_tester(cat_width_wrong_cases)
    serialize_equal(Cat([u(20, w(5)), u(15, w(4))], uw(9)),
                    'cat(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Cat([s(-20, w(6)), s(-15, w(5))], uw(11)),
                    'cat(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #18
0
ファイル: test_div.py プロジェクト: zhongzc/py-hcl
def test_div():
    basis_tester(div_basis_cases)
    encounter_error_tester(div_type_wrong_cases)
    encounter_error_tester(div_width_wrong_cases)
    serialize_equal(Div([u(20, w(5)), u(15, w(4))], uw(5)),
                    'div(UInt<5>("h14"), UInt<4>("hf"))')
    serialize_equal(Div([s(-20, w(6)), s(-15, w(5))], uw(7)),
                    'div(SInt<6>("h-14"), SInt<5>("h-f"))')
コード例 #19
0
ファイル: test_bits.py プロジェクト: zhongzc/py-hcl
def test_bits():
    basis_tester(bits_basis_cases)
    encounter_error_tester(bits_type_wrong_cases)
    encounter_error_tester(bits_width_wrong_cases)
    encounter_error_tester(bits_invalid_cases)
    serialize_equal(Bits(u(20, w(5)), [4, 4], uw(1)),
                    'bits(UInt<5>("h14"), 4, 4)')
    serialize_equal(Bits(s(-20, w(6)), [4, 3], uw(2)),
                    'bits(SInt<6>("h-14"), 4, 3)')
コード例 #20
0
ファイル: test_connect.py プロジェクト: zhongzc/py-hcl
def test_connect_type_wrong():
    cn = Connect(n("a", uw(8)), n("b", sw(8)))
    assert not check(cn)

    cn = Connect(n("a", sw(8)), n("b", uw(8)))
    assert not check(cn)

    cn = Connect(n("a", uw(8)), s(20, w(8)))
    assert not check(cn)

    cn = Connect(n("a", sw(8)), n(-20, w(8)))
    assert not check(cn)
コード例 #21
0
ファイル: test_register.py プロジェクト: zhongzc/py-hcl
def test_init_register_basis():
    r1 = DefInitRegister("r1", uw(8), n("clock", ClockType()), n("r", uw(1)),
                         u(5, w(8)))
    assert check(r1)
    serialize_stmt_equal(
        r1, 'reg r1 : UInt<8>, clock with :\n'
        '  reset => (r, UInt<8>("h5"))')

    r2 = DefInitRegister("r2", sw(8), n("clock", ClockType()), u(0, w(1)),
                         s(5, w(8)))
    assert check(r2)
    serialize_stmt_equal(
        r2, 'reg r2 : SInt<8>, clock with :\n'
        '  reset => (UInt<1>("h0"), SInt<8>("h5"))')
コード例 #22
0
def test_circuit_module_not_exist():
    m1 = DefModule("m1", [OutputPort("p", uw(8))],
                   Connect(n("p", uw(8)), u(2, w(8))))

    m2 = DefModule(
        "m2",
        [InputPort("b", uw(8)), OutputPort("a", uw(8))],
        Block([
            DefNode("n", u(1, w(1))),
            Conditionally(n("n", uw(1)), EmptyStmt(),
                          Connect(n("a", uw(8)), n("b", uw(8))))
        ]))
    ct = DefCircuit("m3", [m1, m2])
    assert not check(ct)
コード例 #23
0
ファイル: test_connect.py プロジェクト: zhongzc/py-hcl
def test_connect_basis():
    cn = Connect(n("a", uw(8)), n("b", uw(8)))
    assert check(cn)
    serialize_stmt_equal(cn, "a <= b")

    cn = Connect(n("a", sw(8)), n("b", sw(8)))
    assert check(cn)
    serialize_stmt_equal(cn, "a <= b")

    cn = Connect(n("a", uw(8)), u(20, w(8)))
    assert check(cn)
    serialize_stmt_equal(cn, 'a <= UInt<8>("h14")')

    cn = Connect(n("a", sw(8)), s(-20, w(8)))
    assert check(cn)
    serialize_stmt_equal(cn, 'a <= SInt<8>("h-14")')
コード例 #24
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_read_port_mem_wrong():
    mem_ref = n("m", bdl(a=(vec(uw(8), 10), False)))
    mr = DefMemReadPort("mr", mem_ref, u(2, w(8)), n("clock", ClockType()))
    assert not check(mr)

    mem_ref = n("m", uw(9))
    mr = DefMemReadPort("mr", mem_ref, n("a", uw(2)), n("clock", ClockType()))
    assert not check(mr)
コード例 #25
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_write_port_mem_wrong():
    mem_ref = n("m", bdl(a=(vec(uw(8), 10), False)))
    mw = DefMemWritePort("mw", mem_ref, u(2, w(8)), n("clock", ClockType()))
    assert not check(mw)

    mem_ref = n("m", uw(9))
    mw = DefMemWritePort("mw", mem_ref, n("a", uw(2)), n("clock", ClockType()))
    assert not check(mw)
コード例 #26
0
def test_sub_access_idx_non_uint():
    vc = vec(uw(8), 10)
    sa = SubAccess(n("vc", vc), s(2, w(3)), uw(8))
    assert not check(sa)

    vc = vec(uw(8), 10)
    sa = SubAccess(n("vc", vc), n("a", sw(8)), uw(8))
    assert not check(sa)
コード例 #27
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_write_port_index_wrong():
    mem_ref = n("m", vec(uw(8), 10))
    mw = DefMemWritePort("mw", mem_ref, s(2, w(8)), n("clock", ClockType()))
    assert not check(mw)

    mem_ref = n("m", vec(bdl(a=(uw(8), False)), 10))
    mw = DefMemWritePort("mw", mem_ref, n("a", vec(uw(1), 10)),
                         n("clock", ClockType()))
    assert not check(mw)
コード例 #28
0
def test_mux_basis():
    mux = Mux(n("c", uw(1)), n("a", uw(8)), n("b", uw(8)), uw(8))
    assert check(mux)
    serialize_equal(mux, "mux(c, a, b)")

    mux = Mux(u(1, w(1)), n("b", vec(sw(8), 10)), n("c", vec(sw(8), 10)),
              vec(sw(8), 10))
    assert check(mux)
    serialize_equal(mux, 'mux(UInt<1>("h1"), b, c)')
コード例 #29
0
ファイル: test_memory.py プロジェクト: zhongzc/py-hcl
def test_read_port_index_wrong():
    mem_ref = n("m", vec(uw(8), 10))
    mr = DefMemReadPort("mr", mem_ref, s(2, w(8)), n("clock", ClockType()))
    assert not check(mr)

    mem_ref = n("m", vec(bdl(a=(uw(8), False)), 10))
    mr = DefMemReadPort("mr", mem_ref, n("a", vec(uw(1), 10)),
                        n("clock", ClockType()))
    assert not check(mr)
コード例 #30
0
def test_sub_access_basis():
    vc = vec(uw(8), 10)
    sa = SubAccess(n("vc", vc), u(2, w(3)), uw(8))
    assert check(sa)
    serialize_equal(sa, 'vc[UInt<3>("h2")]')

    vc = vec(uw(8), 10)
    sa = SubAccess(n("vc", vc), n("a", uw(8)), uw(8))
    assert check(sa)
    serialize_equal(sa, 'vc[a]')