aboutsummaryrefslogtreecommitdiffstats
path: root/src/psl
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2020-03-11 21:09:39 +0100
committerTristan Gingold <tgingold@free.fr>2020-03-13 06:30:27 +0100
commitd70084ccb149ff4f5fca072c672b1f3d040358a9 (patch)
tree1b2cb2172368b02be2f5c92bab1f59583ec4dec9 /src/psl
parent5c398db1b18a346cf2cb25acac07b068ccd7deee (diff)
downloadghdl-d70084ccb149ff4f5fca072c672b1f3d040358a9.tar.gz
ghdl-d70084ccb149ff4f5fca072c672b1f3d040358a9.tar.bz2
ghdl-d70084ccb149ff4f5fca072c672b1f3d040358a9.zip
psl: keep denoting names in the PSL ast.
Diffstat (limited to 'src/psl')
-rw-r--r--src/psl/psl-hash.adb4
-rw-r--r--src/psl/psl-nfas-utils.adb2
-rw-r--r--src/psl/psl-nodes.adb20
-rw-r--r--src/psl/psl-nodes.adb.in3
-rw-r--r--src/psl/psl-nodes.ads20
-rw-r--r--src/psl/psl-nodes_meta.adb50
-rw-r--r--src/psl/psl-nodes_meta.ads2
-rw-r--r--src/psl/psl-prints.adb4
-rw-r--r--src/psl/psl-qm.adb2
-rw-r--r--src/psl/psl-rewrites.adb2
-rw-r--r--src/psl/psl-subsets.adb3
11 files changed, 91 insertions, 21 deletions
diff --git a/src/psl/psl-hash.adb b/src/psl/psl-hash.adb
index b2bdccc79..89394c97d 100644
--- a/src/psl/psl-hash.adb
+++ b/src/psl/psl-hash.adb
@@ -53,7 +53,7 @@ package body PSL.Hash is
-- In the primary table.
Res := Cells.Table (Idx).Res;
if Res = Null_Node then
- Res := Create_Node (N_HDL_Expr);
+ Res := Create_Node (N_HDL_Bool);
Set_HDL_Node (Res, Hdl);
Cells.Table (Idx).Res := Res;
return Res;
@@ -69,7 +69,7 @@ package body PSL.Hash is
Idx := N_Idx;
Res := Cells.Table (Idx).Res;
end loop;
- Res := Create_Node (N_HDL_Expr);
+ Res := Create_Node (N_HDL_Bool);
Set_HDL_Node (Res, Hdl);
Cells.Append ((Res => Res, Next => No_Index));
Cells.Table (Idx).Next := Cells.Last;
diff --git a/src/psl/psl-nfas-utils.adb b/src/psl/psl-nfas-utils.adb
index 5a5f01dab..283560719 100644
--- a/src/psl/psl-nfas-utils.adb
+++ b/src/psl/psl-nfas-utils.adb
@@ -339,7 +339,7 @@ package body PSL.NFAs.Utils is
return True;
when N_False
| N_True
- | N_HDL_Expr =>
+ | N_HDL_Bool =>
return False;
when N_Not_Bool =>
return Has_EOS (Get_Boolean (N));
diff --git a/src/psl/psl-nodes.adb b/src/psl/psl-nodes.adb
index 99b449d22..629041a73 100644
--- a/src/psl/psl-nodes.adb
+++ b/src/psl/psl-nodes.adb
@@ -374,7 +374,8 @@ package body PSL.Nodes is
| N_False
| N_True
| N_Boolean_Parameter
- | N_Paren_Bool =>
+ | N_Paren_Bool
+ | N_HDL_Bool =>
return Type_Boolean;
when N_Number
| N_Const_Parameter =>
@@ -460,6 +461,7 @@ package body PSL.Nodes is
| N_Or_Bool
| N_Imp_Bool
| N_HDL_Expr
+ | N_HDL_Bool
| N_False
| N_True
| N_EOS
@@ -854,6 +856,22 @@ package body PSL.Nodes is
Set_Field2 (N, Int32_To_Node (Idx));
end Set_HDL_Index;
+ function Get_HDL_Hash (N : Node) return Node is
+ begin
+ pragma Assert (N /= Null_Node);
+ pragma Assert (Has_HDL_Hash (Get_Kind (N)),
+ "no field HDL_Hash");
+ return Get_Field5 (N);
+ end Get_HDL_Hash;
+
+ procedure Set_HDL_Hash (N : Node; H : Node) is
+ begin
+ pragma Assert (N /= Null_Node);
+ pragma Assert (Has_HDL_Hash (Get_Kind (N)),
+ "no field HDL_Hash");
+ Set_Field5 (N, H);
+ end Set_HDL_Hash;
+
function Get_Presence (N : Node) return PSL_Presence_Kind is
begin
pragma Assert (N /= Null_Node);
diff --git a/src/psl/psl-nodes.adb.in b/src/psl/psl-nodes.adb.in
index 3c7888800..a7d34b64a 100644
--- a/src/psl/psl-nodes.adb.in
+++ b/src/psl/psl-nodes.adb.in
@@ -374,7 +374,8 @@ package body PSL.Nodes is
| N_False
| N_True
| N_Boolean_Parameter
- | N_Paren_Bool =>
+ | N_Paren_Bool
+ | N_HDL_Bool =>
return Type_Boolean;
when N_Number
| N_Const_Parameter =>
diff --git a/src/psl/psl-nodes.ads b/src/psl/psl-nodes.ads
index 0b11d0641..d5d3b93f5 100644
--- a/src/psl/psl-nodes.ads
+++ b/src/psl/psl-nodes.ads
@@ -92,6 +92,7 @@ package PSL.Nodes is
N_Or_Bool,
N_Imp_Bool, -- ->
N_HDL_Expr,
+ N_HDL_Bool,
N_False,
N_True,
N_EOS,
@@ -105,6 +106,8 @@ package PSL.Nodes is
subtype N_Booleans is Nkind range N_Paren_Bool .. N_True;
subtype N_Sequences is Nkind range N_Braced_SERE .. N_Equal_Repeat_Seq;
+ subtype N_HDLs is Nkind range N_HDL_Expr .. N_HDL_Bool;
+
type PSL_Types is
(
Type_Unknown,
@@ -372,7 +375,8 @@ package PSL.Nodes is
-- Get/Set_Boolean (Field3)
- -- N_HDL_Expr (Short)
+ -- N_HDL_Bool (Short)
+ -- An HDL expression of boolean type, that could be hashed.
--
-- Get/Set_Presence (State1)
--
@@ -384,6 +388,15 @@ package PSL.Nodes is
--
-- Get/Set_Hash_Link (Field6)
+ -- N_HDL_Expr (Short)
+ -- An HDL expression. Just a proxy to the N_HDL_Bool. The node
+ -- is removed when rewritten. This node is present so that denoting
+ -- names are kept in the PSL tree.
+ --
+ -- Get/Set_HDL_Node (Field1)
+ --
+ -- Get/Set_HDL_Hash (Field5)
+
-- N_Paren_Bool (Short)
--
-- Get/Set_Presence (State1)
@@ -574,6 +587,11 @@ package PSL.Nodes is
function Get_HDL_Index (N : Node) return Int32;
procedure Set_HDL_Index (N : Node; Idx : Int32);
+ -- Link the the hash-able node.
+ -- Field: Field5
+ function Get_HDL_Hash (N : Node) return Node;
+ procedure Set_HDL_Hash (N : Node; H : Node);
+
-- Field: State1 (pos)
function Get_Presence (N : Node) return PSL_Presence_Kind;
procedure Set_Presence (N : Node; P : PSL_Presence_Kind);
diff --git a/src/psl/psl-nodes_meta.adb b/src/psl/psl-nodes_meta.adb
index f33ac5122..ef5808fe4 100644
--- a/src/psl/psl-nodes_meta.adb
+++ b/src/psl/psl-nodes_meta.adb
@@ -43,6 +43,7 @@ package body PSL.Nodes_Meta is
Field_Hash => Type_Uns32,
Field_Hash_Link => Type_Node,
Field_HDL_Index => Type_Int32,
+ Field_HDL_Hash => Type_Node,
Field_Presence => Type_PSL_Presence_Kind,
Field_NFA => Type_NFA,
Field_Parameter_List => Type_Node,
@@ -109,6 +110,8 @@ package body PSL.Nodes_Meta is
return "hash_link";
when Field_HDL_Index =>
return "hdl_index";
+ when Field_HDL_Hash =>
+ return "hdl_hash";
when Field_Presence =>
return "presence";
when Field_NFA =>
@@ -241,6 +244,8 @@ package body PSL.Nodes_Meta is
return "imp_bool";
when N_HDL_Expr =>
return "hdl_expr";
+ when N_HDL_Bool =>
+ return "hdl_bool";
when N_False =>
return "false";
when N_True =>
@@ -307,6 +312,8 @@ package body PSL.Nodes_Meta is
return Attr_None;
when Field_HDL_Index =>
return Attr_None;
+ when Field_HDL_Hash =>
+ return Attr_None;
when Field_Presence =>
return Attr_None;
when Field_NFA =>
@@ -537,6 +544,9 @@ package body PSL.Nodes_Meta is
Field_Hash_Link,
-- N_HDL_Expr
Field_HDL_Node,
+ Field_HDL_Hash,
+ -- N_HDL_Bool
+ Field_HDL_Node,
Field_HDL_Index,
Field_Hash,
Field_Presence,
@@ -613,13 +623,14 @@ package body PSL.Nodes_Meta is
N_And_Bool => 142,
N_Or_Bool => 147,
N_Imp_Bool => 152,
- N_HDL_Expr => 157,
- N_False => 157,
- N_True => 157,
- N_EOS => 160,
- N_Name => 162,
- N_Name_Decl => 164,
- N_Number => 165
+ N_HDL_Expr => 154,
+ N_HDL_Bool => 159,
+ N_False => 159,
+ N_True => 159,
+ N_EOS => 162,
+ N_Name => 164,
+ N_Name_Decl => 166,
+ N_Number => 167
);
function Get_Fields (K : Nkind) return Fields_Array
@@ -801,6 +812,8 @@ package body PSL.Nodes_Meta is
return Get_Decl (N);
when Field_Hash_Link =>
return Get_Hash_Link (N);
+ when Field_HDL_Hash =>
+ return Get_HDL_Hash (N);
when Field_Parameter_List =>
return Get_Parameter_List (N);
when Field_Actual =>
@@ -855,6 +868,8 @@ package body PSL.Nodes_Meta is
Set_Decl (N, V);
when Field_Hash_Link =>
Set_Hash_Link (N, V);
+ when Field_HDL_Hash =>
+ Set_HDL_Hash (N, V);
when Field_Parameter_List =>
Set_Parameter_List (N, V);
when Field_Actual =>
@@ -1207,7 +1222,13 @@ package body PSL.Nodes_Meta is
function Has_HDL_Node (K : Nkind) return Boolean is
begin
- return K = N_HDL_Expr;
+ case K is
+ when N_HDL_Expr
+ | N_HDL_Bool =>
+ return True;
+ when others =>
+ return False;
+ end case;
end Has_HDL_Node;
function Has_Hash (K : Nkind) return Boolean is
@@ -1218,7 +1239,7 @@ package body PSL.Nodes_Meta is
| N_And_Bool
| N_Or_Bool
| N_Imp_Bool
- | N_HDL_Expr
+ | N_HDL_Bool
| N_EOS =>
return True;
when others =>
@@ -1234,7 +1255,7 @@ package body PSL.Nodes_Meta is
| N_And_Bool
| N_Or_Bool
| N_Imp_Bool
- | N_HDL_Expr
+ | N_HDL_Bool
| N_EOS =>
return True;
when others =>
@@ -1245,7 +1266,7 @@ package body PSL.Nodes_Meta is
function Has_HDL_Index (K : Nkind) return Boolean is
begin
case K is
- when N_HDL_Expr
+ when N_HDL_Bool
| N_EOS =>
return True;
when others =>
@@ -1253,6 +1274,11 @@ package body PSL.Nodes_Meta is
end case;
end Has_HDL_Index;
+ function Has_HDL_Hash (K : Nkind) return Boolean is
+ begin
+ return K = N_HDL_Expr;
+ end Has_HDL_Hash;
+
function Has_Presence (K : Nkind) return Boolean is
begin
case K is
@@ -1261,7 +1287,7 @@ package body PSL.Nodes_Meta is
| N_And_Bool
| N_Or_Bool
| N_Imp_Bool
- | N_HDL_Expr =>
+ | N_HDL_Bool =>
return True;
when others =>
return False;
diff --git a/src/psl/psl-nodes_meta.ads b/src/psl/psl-nodes_meta.ads
index e8df654b6..5319f407a 100644
--- a/src/psl/psl-nodes_meta.ads
+++ b/src/psl/psl-nodes_meta.ads
@@ -60,6 +60,7 @@ package PSL.Nodes_Meta is
Field_Hash,
Field_Hash_Link,
Field_HDL_Index,
+ Field_HDL_Hash,
Field_Presence,
Field_NFA,
Field_Parameter_List,
@@ -163,6 +164,7 @@ package PSL.Nodes_Meta is
function Has_Hash (K : Nkind) return Boolean;
function Has_Hash_Link (K : Nkind) return Boolean;
function Has_HDL_Index (K : Nkind) return Boolean;
+ function Has_HDL_Hash (K : Nkind) return Boolean;
function Has_Presence (K : Nkind) return Boolean;
function Has_NFA (K : Nkind) return Boolean;
function Has_Parameter_List (K : Nkind) return Boolean;
diff --git a/src/psl/psl-prints.adb b/src/psl/psl-prints.adb
index cdd99c0c3..4cadc3f97 100644
--- a/src/psl/psl-prints.adb
+++ b/src/psl/psl-prints.adb
@@ -71,6 +71,7 @@ package body PSL.Prints is
| N_False
| N_EOS
| N_HDL_Expr
+ | N_HDL_Bool
| N_Property_Instance
| N_Sequence_Instance =>
return Prio_HDL;
@@ -152,7 +153,8 @@ package body PSL.Prints is
end;
when N_Name_Decl =>
Put (Image (Get_Identifier (N)));
- when N_HDL_Expr =>
+ when N_HDL_Expr
+ | N_HDL_Bool =>
if HDL_Expr_Printer = null then
Put ("HDL_Expr");
else
diff --git a/src/psl/psl-qm.adb b/src/psl/psl-qm.adb
index 41f8e1001..722577018 100644
--- a/src/psl/psl-qm.adb
+++ b/src/psl/psl-qm.adb
@@ -197,7 +197,7 @@ package body PSL.QM is
function Build_Primes (N : Node; Negate : Boolean) return Primes_Set is
begin
case Get_Kind (N) is
- when N_HDL_Expr
+ when N_HDL_Bool
| N_EOS =>
declare
Res : Primes_Set (1);
diff --git a/src/psl/psl-rewrites.adb b/src/psl/psl-rewrites.adb
index e06ddd323..35bce015d 100644
--- a/src/psl/psl-rewrites.adb
+++ b/src/psl/psl-rewrites.adb
@@ -109,6 +109,8 @@ package body PSL.Rewrites is
Set_Right (N, Rewrite_Boolean (Get_Right (N)));
return N;
when N_HDL_Expr =>
+ return Get_HDL_Hash (N);
+ when N_HDL_Bool =>
return N;
when others =>
Error_Kind ("rewrite_boolean", N);
diff --git a/src/psl/psl-subsets.adb b/src/psl/psl-subsets.adb
index 95f8d781c..dc677cb21 100644
--- a/src/psl/psl-subsets.adb
+++ b/src/psl/psl-subsets.adb
@@ -190,7 +190,8 @@ package body PSL.Subsets is
| N_False
| N_Number
| N_EOS
- | N_HDL_Expr =>
+ | N_HDL_Expr
+ | N_HDL_Bool =>
null;
end case;
end Check_Simple;