aboutsummaryrefslogtreecommitdiffstats
path: root/src/simul
diff options
context:
space:
mode:
Diffstat (limited to 'src/simul')
-rw-r--r--src/simul/simul-vhdl_simul.adb8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/simul/simul-vhdl_simul.adb b/src/simul/simul-vhdl_simul.adb
index 3eb3d2eed..0a07fc08b 100644
--- a/src/simul/simul-vhdl_simul.adb
+++ b/src/simul/simul-vhdl_simul.adb
@@ -1034,6 +1034,14 @@ package body Simul.Vhdl_Simul is
Ch := Synth_Expression (Inst, Get_Choice_Expression (Sw));
Eq := Is_Equal (Sel, Get_Memtyp (Ch));
end;
+ when Iir_Kind_Choice_By_Range =>
+ declare
+ Bnd : Discrete_Range_Type;
+ begin
+ Elab.Vhdl_Types.Synth_Discrete_Range
+ (Inst, Get_Choice_Range (Sw), Bnd);
+ Eq := In_Range (Bnd, Read_Discrete (Sel));
+ end;
when Iir_Kind_Choice_By_Others =>
Eq := True;
when others =>