*** tpb <[email protected]> has joined #yosys | 00:00 | |
*** freemint <freemint!~freemint@2001:638:904:ffe8:2abf:c8f8:8aa3:41d7> has quit IRC (Quit: Leaving) | 00:05 | |
*** gsmecher <[email protected]> has quit IRC (Ping timeout: 240 seconds) | 00:24 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 250 seconds) | 00:32 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 00:33 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 250 seconds) | 00:42 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 00:45 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 250 seconds) | 00:49 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 02:08 | |
*** FabM <[email protected]> has joined #yosys | 06:25 | |
*** oldtopman <[email protected]> has quit IRC (Ping timeout: 252 seconds) | 06:30 | |
*** Sarayan <Sarayan!~galibert@2a01:e34:ec57:ec20:3e8c:f8ff:fe21:d13> has quit IRC (Remote host closed the connection) | 06:49 | |
*** emeb_mac <[email protected]> has quit IRC (Quit: Leaving.) | 06:59 | |
*** cr1901 <cr1901!~William@2601:8d:8600:911:8105:fac7:3460:a2e2> has quit IRC (Ping timeout: 240 seconds) | 07:20 | |
*** oldtopman <[email protected]> has joined #yosys | 07:37 | |
*** vidbina <[email protected]> has joined #yosys | 09:36 | |
*** pepijndevos[m] <pepijndevos[m]!~pepijndev@2001:470:69fc:105::b6a8> has joined #yosys | 09:36 | |
*** adjtm <[email protected]> has quit IRC (Quit: Leaving) | 12:05 | |
*** piegames <[email protected]> has quit IRC (Ping timeout: 256 seconds) | 13:08 | |
*** cr1901 <cr1901!~William@2601:8d:8600:911:8d3d:b75:a70:95ca> has joined #yosys | 13:14 | |
*** indy <[email protected]> has quit IRC (Quit: ZNC 1.8.2 - https://znc.in) | 13:30 | |
*** indy <[email protected]> has joined #yosys | 13:31 | |
*** piegames <[email protected]> has joined #yosys | 14:01 | |
piegames | How can I do "negative" cover statements? | 14:03 |
---|---|---|
piegames | Like "if A happens, B should never happen" | 14:03 |
piegames | Or on a more broader level, "this operation never takes longer than four cycles" | 14:03 |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 250 seconds) | 14:07 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 14:08 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 250 seconds) | 14:13 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 14:14 | |
*** vidbina <[email protected]> has quit IRC (Ping timeout: 250 seconds) | 14:28 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:4808:32d0:42ff:fe3c:c1f2> has joined #yosys | 14:34 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:4808:32d0:42ff:fe3c:c1f2> has quit IRC (Client Quit) | 14:36 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:4808:32d0:42ff:fe3c:c1f2> has joined #yosys | 14:36 | |
*** peepsalot <peepsalot!~peepsalot@openscad/peepsalot> has quit IRC (Ping timeout: 240 seconds) | 14:59 | |
*** peepsalot <peepsalot!~peepsalot@openscad/peepsalot> has joined #yosys | 14:59 | |
*** vidbina <[email protected]> has joined #yosys | 15:01 | |
*** FabM <FabM!~FabM@armadeus/team/FabM> has quit IRC (Ping timeout: 240 seconds) | 15:02 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:4808:32d0:42ff:fe3c:c1f2> has quit IRC (Ping timeout: 250 seconds) | 15:06 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:fd5a:de41:a9ff:fe9f:76d0> has joined #yosys | 15:06 | |
*** smkz <smkz!~x@user/smkz> has quit IRC (Quit: reboot) | 15:10 | |
*** smkz <smkz!~x@user/smkz> has joined #yosys | 15:11 | |
*** adjtm <[email protected]> has joined #yosys | 15:48 | |
*** adjtm <[email protected]> has quit IRC (Remote host closed the connection) | 15:51 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has quit IRC (Ping timeout: 240 seconds) | 15:52 | |
*** vidbina <[email protected]> has quit IRC (Ping timeout: 252 seconds) | 15:52 | |
*** GenTooMan <GenTooMan!~cyberman@2601:547:437f:e5c6:21f:5bff:fefe:a883> has joined #yosys | 16:11 | |
*** gsmecher <[email protected]> has joined #yosys | 16:19 | |
*** z0ttel <z0ttel!~quassel@2001:638:208:fd5a:de41:a9ff:fe9f:76d0> has quit IRC (Quit: https://quassel-irc.org - Komfortabler Chat. Überall.) | 16:57 | |
mwk | piegames: that sounds like a straightforward assertion, assert !(a_happened && b)? | 17:24 |
tnt | Is there any way to compare two synthesis results from a "topology" PoV ? Like the names of signals/cells is not stable obviously but looking at LUT INIT values, and how they're connected to each other and to FF, it should be possible to find equivalent to match the two graphs and find the parts that are different. | 17:34 |
killjoy | This sounds like LEC. | 17:35 |
killjoy | I don't know about opensource tools to do that, but this is what Cadence's Conformal LEC does. (They probably renamed it, they went through a rebranding a few years ago.) | 17:36 |
tnt | yeah. I mean I know they are _not_ equivalent, but trying to find the differences. | 17:37 |
killjoy | Yeah, you could ask lec these questions and it would show you. | 17:37 |
killjoy | Names didn't really matter, it basically did graph comparisons. | 17:37 |
tnt | I know I used a LVS tool to do SKY130 stuff, comparing the post-synthesis netlist with the extracted netlist after pnr. | 17:38 |
tnt | Maybe I could use that. | 17:38 |
killjoy | It's usually used to verify that synthesis didn't do something weird, but at a high level it really just diffs two designs. | 17:38 |
killjoy | LVS != LEC, not sure if you can do that really. | 17:39 |
killjoy | :shrug: I dunno. | 17:39 |
tnt | Yeah I know they're different, but here I expect the LUT / FF to exist "as-is" exactly the same. LEC would check if they do the same thing (no matter how they are arranged), LVS would check if they're wired the same way. | 17:40 |
killjoy | A quick google shows nothing in this realm. | 17:40 |
killjoy | According to https://openlane.readthedocs.io/en/develop/#openlane-architecture it looks like yosys can do LEC? | 17:48 |
tpb | Title: OpenLANE — OpenLANE documentation (at openlane.readthedocs.io) | 17:48 |
killjoy | Digging deeper I don't see anything. I'm curious if you get LVS to work for this. | 17:53 |
piegames | mwk: I was thinking to deep in implications so it actually took me a while to figure that one out. But yes, that works | 17:59 |
*** vidbina <[email protected]> has joined #yosys | 18:01 | |
*** vidbina <[email protected]> has quit IRC (Ping timeout: 250 seconds) | 18:23 | |
*** adjtm <[email protected]> has joined #yosys | 18:54 | |
*** emeb_mac <[email protected]> has joined #yosys | 19:02 | |
tnt | mmm ... lvs wants structural verilog only, so can't have constants in there, they need to be replaced with GND / VCC cells ... not sure if yosys can do that. | 19:56 |
gatecat | tnt: hilomap | 19:56 |
tnt | gatecat: Ah nice ! I had a look at the command list and missed it. | 19:58 |
*** vidbina <[email protected]> has joined #yosys | 20:18 | |
*** vidbina <[email protected]> has quit IRC (Ping timeout: 250 seconds) | 20:43 | |
*** adjtm <[email protected]> has quit IRC (Ping timeout: 250 seconds) | 20:51 | |
tnt | Next issue is that it doesn't seem to look at params so I'd need to turn ever parametrized instance into something with a unique name encoding the params in the name ... | 20:58 |
tnt | (realistically I'd just need the INIT for the LUT4, the rest doesn't matter much) | 20:59 |
*** V <[email protected]> has joined #yosys | 21:51 | |
killjoy | The more you go through this, the more I think you really need LEC. | 23:36 |
*** gsmecher <[email protected]> has quit IRC (Ping timeout: 250 seconds) | 23:39 |
Generated by irclog2html.py 2.17.2 by Marius Gedminas - find it at https://mg.pov.lt/irclog2html/!