diff options
-rw-r--r-- | src/vhdl/translate/trans-chap3.adb | 3 | ||||
-rw-r--r-- | src/vhdl/vhdl-evaluation.adb | 31 |
2 files changed, 21 insertions, 13 deletions
diff --git a/src/vhdl/translate/trans-chap3.adb b/src/vhdl/translate/trans-chap3.adb index 7e7cefb24..f1928ae2e 100644 --- a/src/vhdl/translate/trans-chap3.adb +++ b/src/vhdl/translate/trans-chap3.adb @@ -1047,6 +1047,9 @@ package body Trans.Chap3 is return -1; end if; Idx_Len := Eval_Discrete_Type_Length (Index); + if Idx_Len < 0 then + return -1; + end if; -- Do not consider very large arrays as static, to avoid overflow at -- compile time. diff --git a/src/vhdl/vhdl-evaluation.adb b/src/vhdl/vhdl-evaluation.adb index 41d18a07c..6a714a330 100644 --- a/src/vhdl/vhdl-evaluation.adb +++ b/src/vhdl/vhdl-evaluation.adb @@ -42,11 +42,6 @@ package body Vhdl.Evaluation is function Eval_Scalar_Compare (Left, Right : Iir) return Compare_Type; - function Is_Overflow (Expr : Iir) return Boolean is - begin - return Get_Kind (Expr) = Iir_Kind_Overflow_Literal; - end Is_Overflow; - function Get_Physical_Value (Expr : Iir) return Int64 is pragma Unsuppress (Overflow_Check); @@ -622,7 +617,7 @@ package body Vhdl.Evaluation is Func : Iir_Predefined_Functions; begin - if Is_Overflow (Operand) then + if Is_Overflow_Literal (Operand) then -- Propagate overflow. return Build_Overflow (Orig); end if; @@ -1080,7 +1075,7 @@ package body Vhdl.Evaluation is El := Get_Right (Op); end if; Ops_Val (I) := Eval_Static_Expr (El); - if Is_Overflow (Ops_Val (I)) then + if Is_Overflow_Literal (Ops_Val (I)) then Err_Orig := El; else case Iir_Predefined_Concat_Functions (Def) is @@ -1103,7 +1098,7 @@ package body Vhdl.Evaluation is Left_Op := Get_Left (Op); end if; Left_Val := Eval_Static_Expr (Left_Op); - if Is_Overflow (Left_Val) then + if Is_Overflow_Literal (Left_Val) then Err_Orig := Left_Op; else Left_Def := Def; @@ -1575,7 +1570,7 @@ package body Vhdl.Evaluation is Func : constant Iir_Predefined_Functions := Get_Implicit_Definition (Imp); begin - if Is_Overflow (Left) or else Is_Overflow (Right) then + if Is_Overflow_Literal (Left) or else Is_Overflow_Literal (Right) then return Build_Overflow (Orig); end if; @@ -2546,7 +2541,7 @@ package body Vhdl.Evaluation is begin Prefix := Get_Prefix (Expr); Prefix := Eval_Static_Expr (Prefix); - if Is_Overflow (Prefix) then + if Is_Overflow_Literal (Prefix) then return Build_Overflow (Expr, Get_Type (Expr)); end if; @@ -3703,7 +3698,9 @@ package body Vhdl.Evaluation is R_Expr : constant Iir := Get_Right_Limit (Range_Constraint); L, R : Int64; begin - if Is_Overflow (L_Expr) or else Is_Overflow (R_Expr) then + if Is_Overflow_Literal (L_Expr) + or else Is_Overflow_Literal (R_Expr) + then return False; end if; -- Check for null range. @@ -3765,11 +3762,19 @@ package body Vhdl.Evaluation is is -- We don't want to deal with very large ranges here. pragma Suppress (Overflow_Check); + Left_Expr : constant Iir := Get_Left_Limit (Constraint); + Right_Expr : constant Iir := Get_Right_Limit (Constraint); Res : Int64; Left, Right : Int64; begin - Left := Eval_Pos (Get_Left_Limit (Constraint)); - Right := Eval_Pos (Get_Right_Limit (Constraint)); + if Is_Overflow_Literal (Left_Expr) + or else Is_Overflow_Literal (Right_Expr) + then + return -1; + end if; + + Left := Eval_Pos (Left_Expr); + Right := Eval_Pos (Right_Expr); case Get_Direction (Constraint) is when Dir_To => if Right < Left then |