diff options
author | Tristan Gingold <tgingold@free.fr> | 2021-04-15 07:45:57 +0200 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2021-04-15 07:45:57 +0200 |
commit | e2f0e4b59816b0b64a83fac22614c97a7bd7d85d (patch) | |
tree | b379d953870b39c16cb295d47497066f37159619 /src/synth/synth-insts.adb | |
parent | e5cf1849821cec0f3340babf69c29929d1d25fca (diff) | |
download | ghdl-e2f0e4b59816b0b64a83fac22614c97a7bd7d85d.tar.gz ghdl-e2f0e4b59816b0b64a83fac22614c97a7bd7d85d.tar.bz2 ghdl-e2f0e4b59816b0b64a83fac22614c97a7bd7d85d.zip |
synth: avoid crash in case of non-elaboratable generic.
Diffstat (limited to 'src/synth/synth-insts.adb')
-rw-r--r-- | src/synth/synth-insts.adb | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/synth/synth-insts.adb b/src/synth/synth-insts.adb index 5937a793e..250fbcf61 100644 --- a/src/synth/synth-insts.adb +++ b/src/synth/synth-insts.adb @@ -994,9 +994,11 @@ package body Synth.Insts is Inter := Get_Generic_Chain (Inst_Obj.Decl); while Inter /= Null_Node loop Vt := Get_Value (Inst_Obj.Syn_Inst, Inter); - Pv := Memtyp_To_Pval (Get_Memtyp (Vt)); - Set_Param_Pval (Inst, Idx, Pv); - + if Vt /= No_Valtyp then + -- Avoid errors + Pv := Memtyp_To_Pval (Get_Memtyp (Vt)); + Set_Param_Pval (Inst, Idx, Pv); + end if; Inter := Get_Chain (Inter); Idx := Idx + 1; end loop; |