If subdesigns don't show up properly, you can make your own .sym file and specify port locations, names, etc. An example is below:
hades.symbols.Rectangle 0 0 4000 2600
hades.symbols.InstanceLabel 150 450 1bit4to1MUX
hades.symbols.PortLabel 150 350 I0
hades.symbols.PortSymbol 0 200 I0
hades.symbols.PortLabel 150 950 I1
hades.symbols.PortSymbol 0 800 I1
hades.symbols.PortLabel 150 1550 I2
hades.symbols.PortLabel 150 2150 I3
hades.symbols.PortSymbol 0 2000 I3
hades.symbols.PortSymbol 0 1400 I2
hades.symbols.PortLabel 2800 350 S0
hades.symbols.PortSymbol 4000 200 S0
hades.symbols.PortLabel 2800 950 S1
hades.symbols.PortSymbol 4000 800 S1
hades.symbols.PortLabel 2800 1550 Output
hades.symbols.PortSymbol 4000 1400 Output
There are a number of reasons subdesigns will appear to be non functional or not respond in a larger design... I'll try to add to these as I find more:
1. Output named "Y" -- I've had success with this, but it seems to be unpredictable. Avoid it.
2. Edits to subdesigns will sometimes disconnect ports in larger designs. An easy way to test if this has happened is to move the subdesign in the larger design... wires should stay connected, if they don't, well, there you go... delete segments nearest your connections and then add segments to the original wire and reconnect.
3. In your subdesigns, set all your Ipins to default to 0. Defaulting to undefined can cause problems in larger designs.
4. you can't depend on Ipin vectors to take default values. Plan ahead on how to get data in.
I'm sure that there are more tips, but the semester is over and hades is slowly seeping out of mind. However, if you've stumbled across this and are knee deep in hades issues, go ahead and send an email, maybe i can help.
No comments:
Post a Comment