aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2022-02-24 17:28:10 +0100
committerTristan Gingold <tgingold@free.fr>2022-02-24 21:37:09 +0100
commit26eeee5d480cbec7f08173c73958940aa7da3188 (patch)
treecae4d2fa8730c4f47eb3cd5e1680994d9ebfdb91
parent8fb84c1ca46c299996886dd22a7796817015c681 (diff)
downloadghdl-26eeee5d480cbec7f08173c73958940aa7da3188.tar.gz
ghdl-26eeee5d480cbec7f08173c73958940aa7da3188.tar.bz2
ghdl-26eeee5d480cbec7f08173c73958940aa7da3188.zip
vhdl-sem_psl.adb: don't crash on overload in HDL expr. Fix #1979
-rw-r--r--src/vhdl/vhdl-sem_psl.adb14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/vhdl/vhdl-sem_psl.adb b/src/vhdl/vhdl-sem_psl.adb
index 9cd7b52fb..55a4d7257 100644
--- a/src/vhdl/vhdl-sem_psl.adb
+++ b/src/vhdl/vhdl-sem_psl.adb
@@ -57,9 +57,19 @@ package body Vhdl.Sem_Psl is
end Is_Psl_Boolean_Type;
-- Return TRUE if EXPR type is a PSL boolean type.
- function Is_Psl_Boolean_Expr (Expr : Iir) return Boolean is
+ function Is_Psl_Boolean_Expr (Expr : Iir) return Boolean
+ is
+ Etype : constant Iir := Get_Type (Expr);
begin
- return Is_Psl_Boolean_Type (Get_Type (Expr));
+ -- In case of overload, consider the expression not as a PSL boolean.
+ -- It couldn't be resolved, so there will be an error, unless the whole
+ -- property is used in an assertion and the assertion is not considered
+ -- as a PSL assertion.
+ if Sem_Names.Is_Overload_List (Etype) then
+ return False;
+ end if;
+
+ return Is_Psl_Boolean_Type (Etype);
end Is_Psl_Boolean_Expr;
function Is_Psl_Bit_Type (Atype : Iir) return Boolean