phanrahan/mantle

CounterModM Broken When Compiling To CoreIR

Closed this issue · 13 comments

When compiling to CoreIR, CounterModM crashes with the following error:

ERROR: Counter5Mod2: Cannot wire together
inst1.O : Bit
inst0.RESET : coreir.rstIn

My test is: https://github.com/David-Durst/aetherling/blob/master/tests/test_up.py#L83

Through debugging, I've tracked down that this crash occurs while in the compile_definition call for the Counter5Mod2 module (the line https://github.com/phanrahan/magma/blob/master/magma/backend/coreir_.py#L261).

Also, are UInt types legacy? Why does the counter5mod2 have 5 uints rather than 5 bits?

UInt types are not legacy, see https://github.com/phanrahan/magma/wiki/Types,-Operators,-and-Functions for some info on them

@rdaly525 Looks like the issue is wiring the output of some arbitrary logic to a reset port of type coreir.rstIn. Is there a way to "cast" types in coreir? (e.g. in this case, we want the output of an and instance of type Bit to be a coreir.rstIn.

@David-Durst Can't reproduce this with aetherling, I get the following error

aetherling/modules/up.py:5: in <module>
    from magma.coreirModuleWrapper import ModuleFromGeneratorWrapper
E   ModuleNotFoundError: No module named 'magma.coreirModuleWrapper'

are you on a local branch for magma? Can you share that with me somehow? (easiest is to push the branch to the magma repo so I can just check it out)

Please use the counterModMTest branch of aetherling. The counterModM test now doesn't require any of my changes to magma/pycoreir/coreir. I have some in all three repos that need to get pull requested in.

On counterModM , still getting

aetherling/modules/up.py:5: in <module>
    from magma.coreirModuleWrapper import ModuleFromGeneratorWrapper
E   ModuleNotFoundError: No module named 'magma.coreirModuleWrapper'

The error indicates that it's trying to import something from magma that I don't have

Please pull and retry the test now. The includes should be removed now

Also, here's the backtrace of the error from lldb.

(lldb) bt
* thread #1, queue = 'com.apple.main-thread', stop reason = signal SIGABRT
  * frame #0: 0x00007fff6d58de3e libsystem_kernel.dylib`__pthread_kill + 10
    frame #1: 0x00007fff6d6cc150 libsystem_pthread.dylib`pthread_kill + 333
    frame #2: 0x00007fff6d4ea312 libsystem_c.dylib`abort + 127
    frame #3: 0x00007fff6d4b2368 libsystem_c.dylib`__assert_rtn + 320
    frame #4: 0x000000010506e185 libcoreir.dylib`CoreIR::Context::die() + 133
    frame #5: 0x00000001051f933a libcoreir.dylib`CoreIR::ModuleDef::connect(CoreIR::Wireable*, CoreIR::Wireable*) + 4186
    frame #6: 0x000000010466d147 libcoreir-c.dylib`COREModuleDefConnect + 71
    frame #7: 0x00000001019f6884 libffi.6.dylib`ffi_call_unix64 + 76
    frame #8: 0x00000001019f5e8b libffi.6.dylib`ffi_call + 939
    frame #9: 0x000000010267bcf8 _ctypes.cpython-36m-darwin.so`_ctypes_callproc + 552
    frame #10: 0x0000000102676222 _ctypes.cpython-36m-darwin.so`PyCFuncPtr_call + 242
    frame #11: 0x0000000100009df1 python`_PyObject_FastCallDict + 177
    frame #12: 0x0000000100163348 python`call_function + 392
    frame #13: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #14: 0x00000001001635fc python`fast_function + 188
    frame #15: 0x00000001001632ac python`call_function + 236
    frame #16: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #17: 0x00000001001635fc python`fast_function + 188
    frame #18: 0x00000001001632ac python`call_function + 236
    frame #19: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #20: 0x0000000100154589 python`_PyEval_EvalCodeWithName + 425
    frame #21: 0x00000001001636aa python`fast_function + 362
    frame #22: 0x00000001001632ac python`call_function + 236
    frame #23: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #24: 0x00000001001635fc python`fast_function + 188
    frame #25: 0x00000001001632ac python`call_function + 236
    frame #26: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #27: 0x00000001001635fc python`fast_function + 188
    frame #28: 0x00000001001632ac python`call_function + 236
    frame #29: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #30: 0x0000000100154589 python`_PyEval_EvalCodeWithName + 425
    frame #31: 0x00000001001636aa python`fast_function + 362
    frame #32: 0x00000001001632ac python`call_function + 236
    frame #33: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #34: 0x0000000100154589 python`_PyEval_EvalCodeWithName + 425
    frame #35: 0x0000000100163e15 python`_PyFunction_FastCallDict + 373
    frame #36: 0x0000000100009e80 python`_PyObject_FastCallDict + 320
    frame #37: 0x0000000100031468 python`method_call + 136
    frame #38: 0x00000001000114ee python`PyObject_Call + 62
    frame #39: 0x00000001000b3065 python`slot_tp_init + 117
    frame #40: 0x00000001000b75b1 python`type_call + 241
    frame #41: 0x0000000100009df1 python`_PyObject_FastCallDict + 177
    frame #42: 0x0000000100163348 python`call_function + 392
    frame #43: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #44: 0x00000001001635fc python`fast_function + 188
    frame #45: 0x00000001001632ac python`call_function + 236
    frame #46: 0x0000000100160f4c python`_PyEval_EvalFrameDefault + 47100
    frame #47: 0x0000000100154589 python`_PyEval_EvalCodeWithName + 425
    frame #48: 0x00000001001ac63c python`PyRun_FileExFlags + 252
    frame #49: 0x00000001001abdee python`PyRun_SimpleFileExFlags + 366
    frame #50: 0x00000001001d1dd6 python`Py_Main + 3718
    frame #51: 0x0000000100001e7d python`main + 509
    frame #52: 0x00007fff6d43e115 libdyld.dylib`start + 1
    frame #53: 0x00007fff6d43e115 libdyld.dylib`start + 1

Is this port supposed to be used as an asynchronous reset or a synchronous reset? If it is the latter, it is a bug. if it is the former, I have something called coreir.wrap which will wrap a bit into a named type.

@rdaly525 if I understand correctly, a synchronous reset should use a standard bit type, not the rst named type.

Yes, that is correct. It is on my TODO list to rename the rst type to "async_reset" or something like that

Fixed by:
eab6f26
and
1b317d85ffa3c68dba1d85dc149bee4103456e39
phanrahan/magma@1b317d8

Will open a separate issue to resolve the RESET type semantics and matching them up with coreir