aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2017-02-21 04:43:37 +0100
committerTristan Gingold <tgingold@free.fr>2017-02-21 04:47:56 +0100
commitbc78710187b5875d40d4b539b81da5ec464c508d (patch)
tree01772a07c6abb4de7fe7c44392e732eec30bccb0 /src
parentbed747fc425d388786c9ff5107e6e8ee777cbbf3 (diff)
downloadghdl-bc78710187b5875d40d4b539b81da5ec464c508d.tar.gz
ghdl-bc78710187b5875d40d4b539b81da5ec464c508d.tar.bz2
ghdl-bc78710187b5875d40d4b539b81da5ec464c508d.zip
unbounded records: add rti support (WIP)
Diffstat (limited to 'src')
-rw-r--r--src/grt/grt-avhpi.adb40
-rw-r--r--src/grt/grt-disp_rti.adb342
-rw-r--r--src/grt/grt-disp_rti.ads1
-rw-r--r--src/grt/grt-disp_tree.adb5
-rw-r--r--src/grt/grt-rtis.ads46
-rw-r--r--src/grt/grt-rtis_addr.adb73
-rw-r--r--src/grt/grt-rtis_addr.ads6
-rw-r--r--src/grt/grt-rtis_utils.adb42
-rw-r--r--src/grt/grt-vcd.adb4
-rw-r--r--src/grt/grt-waves.adb21
-rw-r--r--src/vhdl/translate/trans-chap3.adb2
-rw-r--r--src/vhdl/translate/trans-rtis.adb131
-rw-r--r--src/vhdl/translate/trans-rtis.ads2
13 files changed, 438 insertions, 277 deletions
diff --git a/src/grt/grt-avhpi.adb b/src/grt/grt-avhpi.adb
index a83be7cc6..06ad210a8 100644
--- a/src/grt/grt-avhpi.adb
+++ b/src/grt/grt-avhpi.adb
@@ -146,9 +146,10 @@ package body Grt.Avhpi is
case Res.N_Type.Kind is
when Ghdl_Rtik_Subtype_Array =>
declare
- St : constant Ghdl_Rtin_Subtype_Array_Acc :=
- To_Ghdl_Rtin_Subtype_Array_Acc (Res.N_Type);
- Bt : constant Ghdl_Rtin_Type_Array_Acc := St.Basetype;
+ St : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Res.N_Type);
+ Bt : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (St.Basetype);
Rngs : Ghdl_Range_Array (0 .. Bt.Nbr_Dim - 1);
begin
Bound_To_Range
@@ -203,10 +204,10 @@ package body Grt.Avhpi is
when Ghdl_Rtik_Subtype_Array =>
if Is_Sig then
El_Size := Ghdl_Index_Type
- (To_Ghdl_Rtin_Subtype_Array_Acc (El_Type1).Sigsize);
+ (To_Ghdl_Rtin_Subtype_Composite_Acc (El_Type1).Sigsize);
else
El_Size := Ghdl_Index_Type
- (To_Ghdl_Rtin_Subtype_Array_Acc (El_Type1).Valsize);
+ (To_Ghdl_Rtin_Subtype_Composite_Acc (El_Type1).Valsize);
end if;
when others =>
Internal_Error ("add_index");
@@ -383,11 +384,11 @@ package body Grt.Avhpi is
Obj => To_Ghdl_Rtin_Object_Acc (Rti));
when Ghdl_Rtik_Subtype_Array =>
declare
- Atype : Ghdl_Rtin_Subtype_Array_Acc;
- Bt : Ghdl_Rtin_Type_Array_Acc;
+ Atype : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
+ Bt : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (Atype.Basetype);
begin
- Atype := To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
- Bt := Atype.Basetype;
if Atype.Name = Bt.Name then
Res := (Kind => VhpiArrayTypeDeclK,
Ctxt => Ctxt,
@@ -933,8 +934,7 @@ package body Grt.Avhpi is
case Atype.Kind is
when Ghdl_Rtik_Subtype_Array =>
Rti_To_Handle
- (To_Ghdl_Rti_Access (To_Ghdl_Rtin_Subtype_Array_Acc
- (Atype).Basetype),
+ (To_Ghdl_Rtin_Subtype_Composite_Acc (Atype).Basetype,
Ref.Ctxt, Res);
if Res.Kind /= VhpiUndefined then
Error := AvhpiErrorOk;
@@ -955,18 +955,19 @@ package body Grt.Avhpi is
end;
when VhpiElemSubtype =>
declare
- Base_Type : Ghdl_Rtin_Type_Array_Acc;
+ Base_Type : Ghdl_Rti_Access;
begin
case Ref.Atype.Kind is
when Ghdl_Rtik_Subtype_Array =>
Base_Type :=
- To_Ghdl_Rtin_Subtype_Array_Acc (Ref.Atype).Basetype;
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Ref.Atype).Basetype;
when Ghdl_Rtik_Type_Array =>
- Base_Type := To_Ghdl_Rtin_Type_Array_Acc (Ref.Atype);
+ Base_Type := Ref.Atype;
when others =>
return;
end case;
- Rti_To_Handle (Base_Type.Element, Ref.Ctxt, Res);
+ Rti_To_Handle (To_Ghdl_Rtin_Type_Array_Acc (Base_Type).Element,
+ Ref.Ctxt, Res);
if Res.Kind /= VhpiUndefined then
Error := AvhpiErrorOk;
end if;
@@ -981,8 +982,7 @@ package body Grt.Avhpi is
Ref : VhpiHandleT;
Index : Natural;
Res : out VhpiHandleT;
- Error : out AvhpiErrorT)
- is
+ Error : out AvhpiErrorT) is
begin
-- Default error.
Error := AvhpiErrorNotImplemented;
@@ -993,10 +993,10 @@ package body Grt.Avhpi is
when VhpiSubtypeIndicK =>
if Ref.Atype.Kind = Ghdl_Rtik_Subtype_Array then
declare
- Arr_Subtype : constant Ghdl_Rtin_Subtype_Array_Acc :=
- To_Ghdl_Rtin_Subtype_Array_Acc (Ref.Atype);
+ Arr_Subtype : constant Ghdl_Rtin_Subtype_Composite_Acc
+ := To_Ghdl_Rtin_Subtype_Composite_Acc (Ref.Atype);
Basetype : constant Ghdl_Rtin_Type_Array_Acc :=
- Arr_Subtype.Basetype;
+ To_Ghdl_Rtin_Type_Array_Acc (Arr_Subtype.Basetype);
Idx : constant Ghdl_Index_Type :=
Ghdl_Index_Type (Index);
Bounds : Ghdl_Range_Array (0 .. Basetype.Nbr_Dim - 1);
diff --git a/src/grt/grt-disp_rti.adb b/src/grt/grt-disp_rti.adb
index 2a49281a7..bf77e56dc 100644
--- a/src/grt/grt-disp_rti.adb
+++ b/src/grt/grt-disp_rti.adb
@@ -192,19 +192,25 @@ package body Grt.Disp_Rti is
-- end Get_Scalar_Type_Kind;
procedure Disp_Array_Value_1 (Stream : FILEs;
- El_Rti : Ghdl_Rti_Access;
+ Arr_Rti : Ghdl_Rtin_Type_Array_Acc;
Ctxt : Rti_Context;
- Rngs : Ghdl_Range_Array;
- Rtis : Ghdl_Rti_Arr_Acc;
Index : Ghdl_Index_Type;
Obj : in out Address;
+ Bounds : in out Address;
Is_Sig : Boolean)
is
+ El_Rti : constant Ghdl_Rti_Access := Arr_Rti.Element;
+ Idx_Rti : constant Ghdl_Rti_Access :=
+ Get_Base_Type (Arr_Rti.Indexes (Index));
+ Last_Idx : constant Ghdl_Index_Type := Arr_Rti.Nbr_Dim - 1;
+ Rng : Ghdl_Range_Ptr;
Length : Ghdl_Index_Type;
+ Bounds2 : Address;
begin
- Length := Range_To_Length (Rngs (Index), Get_Base_Type (Rtis (Index)));
+ Extract_Range (Bounds, Idx_Rti, Rng);
+ Length := Range_To_Length (Rng, Idx_Rti);
- if Index = Rngs'Last
+ if Index = Last_Idx
and then (El_Rti.Kind = Ghdl_Rtik_Type_B1
or else El_Rti.Kind = Ghdl_Rtik_Type_E8)
then
@@ -214,40 +220,32 @@ package body Grt.Disp_Rti is
end if;
Put (Stream, "(");
- for I in 1 .. Length loop
- if I /= 1 then
- Put (Stream, ", ");
- end if;
- if Index = Rngs'Last then
- Disp_Value (Stream, El_Rti, Ctxt, Obj, Is_Sig);
- else
- Disp_Array_Value_1
- (Stream, El_Rti, Ctxt, Rngs, Rtis, Index + 1, Obj, Is_Sig);
- end if;
- end loop;
+ if Length = 0 then
+ Put (Stream, "<>");
+ -- FIXME: need to update bounds.
+ else
+ for I in 1 .. Length loop
+ Bounds2 := Bounds;
+ if I /= 1 then
+ Put (Stream, ", ");
+ end if;
+ if Index = Last_Idx then
+ Disp_Value (Stream, El_Rti, Ctxt, Obj, Bounds2, Is_Sig);
+ else
+ Disp_Array_Value_1
+ (Stream, Arr_Rti, Ctxt, Index + 1, Obj, Bounds2, Is_Sig);
+ end if;
+ end loop;
+ Bounds := Bounds2;
+ end if;
Put (Stream, ")");
end Disp_Array_Value_1;
- procedure Disp_Array_Value (Stream : FILEs;
- Rti : Ghdl_Rtin_Type_Array_Acc;
- Ctxt : Rti_Context;
- Vals : Ghdl_Uc_Array_Acc;
- Is_Sig : Boolean)
- is
- Nbr_Dim : constant Ghdl_Index_Type := Rti.Nbr_Dim;
- Rngs : Ghdl_Range_Array (0 .. Nbr_Dim - 1);
- Obj : Address;
- begin
- Bound_To_Range (Vals.Bounds, Rti, Rngs);
- Obj := Vals.Base;
- Disp_Array_Value_1
- (Stream, Rti.Element, Ctxt, Rngs, Rti.Indexes, 0, Obj, Is_Sig);
- end Disp_Array_Value;
-
procedure Disp_Record_Value (Stream : FILEs;
Rti : Ghdl_Rtin_Type_Record_Acc;
Ctxt : Rti_Context;
Obj : Address;
+ Bounds : in out Address;
Is_Sig : Boolean)
is
El : Ghdl_Rtin_Element_Acc;
@@ -266,21 +264,33 @@ package body Grt.Disp_Rti is
else
El_Addr := Obj + El.Val_Off;
end if;
- if Rti_Complex_Type (El.Eltype) then
- El_Addr := Obj + To_Ghdl_Index_Acc (El_Addr).all;
- end if;
- Disp_Value (Stream, El.Eltype, Ctxt, El_Addr, Is_Sig);
+ case El.Eltype.Kind is
+ when Ghdl_Rtik_Subtype_Array
+ | Ghdl_Rtik_Type_Record =>
+ -- Element is an offset.
+ if Rti_Complex_Type (El.Eltype) then
+ El_Addr := Obj + To_Ghdl_Index_Acc (El_Addr).all;
+ end if;
+ when Ghdl_Rtik_Type_Array
+ | Ghdl_Rtik_Type_Unbounded_Record
+ | Ghdl_Rtik_Subtype_Unbounded_Record =>
+ -- Element is an offset.
+ El_Addr := Obj + To_Ghdl_Index_Acc (El_Addr).all;
+ when others =>
+ null;
+ end case;
+ Disp_Value (Stream, El.Eltype, Ctxt, El_Addr, Bounds, Is_Sig);
end loop;
Put (")");
-- FIXME: update ADDR.
end Disp_Record_Value;
- procedure Disp_Value
- (Stream : FILEs;
- Rti : Ghdl_Rti_Access;
- Ctxt : Rti_Context;
- Obj : in out Address;
- Is_Sig : Boolean)
+ procedure Disp_Value (Stream : FILEs;
+ Rti : Ghdl_Rti_Access;
+ Ctxt : Rti_Context;
+ Obj : in out Address;
+ Bounds : in out Address;
+ Is_Sig : Boolean)
is
begin
case Rti.Kind is
@@ -294,19 +304,19 @@ package body Grt.Disp_Rti is
| Ghdl_Rtik_Type_B1 =>
Disp_Scalar_Value (Stream, Rti, Obj, Is_Sig);
when Ghdl_Rtik_Type_Array =>
- Disp_Array_Value (Stream, To_Ghdl_Rtin_Type_Array_Acc (Rti), Ctxt,
- To_Ghdl_Uc_Array_Acc (Obj), Is_Sig);
+ Disp_Array_Value_1
+ (Stream, To_Ghdl_Rtin_Type_Array_Acc (Rti), Ctxt, 0,
+ Obj, Bounds, Is_Sig);
when Ghdl_Rtik_Subtype_Array =>
declare
- St : constant Ghdl_Rtin_Subtype_Array_Acc :=
- To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
- Bt : constant Ghdl_Rtin_Type_Array_Acc := St.Basetype;
- Rngs : Ghdl_Range_Array (0 .. Bt.Nbr_Dim - 1);
+ St : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
+ Bt : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (St.Basetype);
+ Bounds : Address;
begin
- Bound_To_Range
- (Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt), Bt, Rngs);
- Disp_Array_Value_1
- (Stream, Bt.Element, Ctxt, Rngs, Bt.Indexes, 0, Obj, Is_Sig);
+ Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt);
+ Disp_Array_Value_1 (Stream, Bt, Ctxt, 0, Obj, Bounds, Is_Sig);
end;
when Ghdl_Rtik_Type_File =>
declare
@@ -320,7 +330,19 @@ package body Grt.Disp_Rti is
end;
when Ghdl_Rtik_Type_Record =>
Disp_Record_Value
- (Stream, To_Ghdl_Rtin_Type_Record_Acc (Rti), Ctxt, Obj, Is_Sig);
+ (Stream, To_Ghdl_Rtin_Type_Record_Acc (Rti), Ctxt,
+ Obj, Bounds, Is_Sig);
+ when Ghdl_Rtik_Subtype_Record =>
+ declare
+ St : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
+ Bt : constant Ghdl_Rtin_Type_Record_Acc :=
+ To_Ghdl_Rtin_Type_Record_Acc (St.Basetype);
+ Bounds : Address;
+ begin
+ Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt);
+ Disp_Record_Value (Stream, Bt, Ctxt, Obj, Bounds, Is_Sig);
+ end;
when Ghdl_Rtik_Type_Protected =>
Put (Stream, "Unhandled protected type");
when others =>
@@ -405,8 +427,15 @@ package body Grt.Disp_Rti is
Put ("ghdl_rtik_type_array");
when Ghdl_Rtik_Subtype_Array =>
Put ("ghdl_rtik_subtype_array");
+
when Ghdl_Rtik_Type_Record =>
Put ("ghdl_rtik_type_record");
+ when Ghdl_Rtik_Type_Unbounded_Record =>
+ Put ("ghdl_rtik_type_unbounded_record");
+ when Ghdl_Rtik_Subtype_Unbounded_Record =>
+ Put ("ghdl_rtik_subtype_unbounded_record");
+ when Ghdl_Rtik_Subtype_Record =>
+ Put ("ghdl_rtik_subtype_record");
when Ghdl_Rtik_Type_Access =>
Put ("ghdl_rtik_type_access");
@@ -433,6 +462,7 @@ package body Grt.Disp_Rti is
Put ("ghdl_rtik_psl_endpoint");
when others =>
+ -- Should never happen, except when not synchronized.
Put ("ghdl_rtik_#");
Put_I32 (stdout, Ghdl_Rtik'Pos (Kind));
end case;
@@ -523,71 +553,90 @@ package body Grt.Disp_Rti is
end case;
end Disp_Scalar_Type_Name;
+ procedure Disp_Type_Array_Bounds (Def : Ghdl_Rtin_Type_Array_Acc;
+ Bounds : in out Address)
+ is
+ Rng : Ghdl_Range_Ptr;
+ Idx_Base : Ghdl_Rti_Access;
+ begin
+ Put (" (");
+ for I in 0 .. Def.Nbr_Dim - 1 loop
+ if I /= 0 then
+ Put (", ");
+ end if;
+ if Boolean'(False) then
+ Disp_Scalar_Type_Name (Def.Indexes (I));
+ Put (" range ");
+ end if;
+ Idx_Base := Get_Base_Type (Def.Indexes (I));
+ Extract_Range (Bounds, Idx_Base, Rng);
+ Disp_Range (stdout, Idx_Base, Rng);
+ end loop;
+ Put (")");
+ end Disp_Type_Array_Bounds;
+
+ procedure Disp_Type_Record_Bounds (Def : Ghdl_Rtin_Type_Record_Acc;
+ Bounds : in out Address)
+ is
+ El : Ghdl_Rtin_Element_Acc;
+ First : Boolean;
+ begin
+ Put (" (");
+ First := True;
+ for I in 1 .. Def.Nbrel loop
+ El := To_Ghdl_Rtin_Element_Acc (Def.Elements (I - 1));
+ case El.Eltype.Kind is
+ when Ghdl_Rtik_Type_Array
+ | Ghdl_Rtik_Type_Unbounded_Record =>
+ if First then
+ First := False;
+ else
+ Put (", ");
+ end if;
+ Put (El.Name);
+ case El.Eltype.Kind is
+ when Ghdl_Rtik_Type_Array =>
+ Disp_Type_Array_Bounds
+ (To_Ghdl_Rtin_Type_Array_Acc (El.Eltype), Bounds);
+ when Ghdl_Rtik_Type_Unbounded_Record =>
+ Disp_Type_Record_Bounds
+ (To_Ghdl_Rtin_Type_Record_Acc (El.Eltype), Bounds);
+ when others =>
+ raise Program_Error;
+ end case;
+ when others =>
+ null;
+ end case;
+ end loop;
+ Put (")");
+ end Disp_Type_Record_Bounds;
+
procedure Disp_Type_Array_Name (Def : Ghdl_Rtin_Type_Array_Acc;
Bounds_Ptr : Address)
is
Bounds : Address;
-
- procedure Align (A : Ghdl_Index_Type) is
- begin
- Bounds := Align (Bounds, Ghdl_Rti_Loc (A));
- end Align;
-
- procedure Update (S : Ghdl_Index_Type) is
- begin
- Bounds := Bounds + (S / Storage_Unit);
- end Update;
-
- procedure Disp_Bounds (Def : Ghdl_Rti_Access)
- is
- Ndef : Ghdl_Rti_Access;
- begin
- if Bounds = Null_Address then
- Put ("?");
- else
- if Def.Kind = Ghdl_Rtik_Subtype_Scalar then
- Ndef := To_Ghdl_Rtin_Subtype_Scalar_Acc (Def).Basetype;
- else
- Ndef := Def;
- end if;
- case Ndef.Kind is
- when Ghdl_Rtik_Type_I32 =>
- Align (Ghdl_Range_I32'Alignment);
- Disp_Range (stdout, Ndef, To_Ghdl_Range_Ptr (Bounds));
- Update (Ghdl_Range_I32'Size);
- when Ghdl_Rtik_Type_B1 =>
- Align (Ghdl_Range_B1'Alignment);
- Disp_Range (stdout, Ndef, To_Ghdl_Range_Ptr (Bounds));
- Update (Ghdl_Range_B1'Size);
- when Ghdl_Rtik_Type_E8 =>
- Align (Ghdl_Range_E8'Alignment);
- Disp_Range (stdout, Ndef, To_Ghdl_Range_Ptr (Bounds));
- Update (Ghdl_Range_E8'Size);
- when others =>
- Disp_Kind (Ndef.Kind);
- -- Bounds are not known anymore.
- Bounds := Null_Address;
- end case;
- end if;
- end Disp_Bounds;
begin
Disp_Name (Def.Name);
if Bounds_Ptr = Null_Address then
return;
end if;
- Put (" (");
Bounds := Bounds_Ptr;
- for I in 0 .. Def.Nbr_Dim - 1 loop
- if I /= 0 then
- Put (", ");
- end if;
- Disp_Scalar_Type_Name (Def.Indexes (I));
- Put (" range ");
- Disp_Bounds (Def.Indexes (I));
- end loop;
- Put (")");
+ Disp_Type_Array_Bounds (Def, Bounds);
end Disp_Type_Array_Name;
+ procedure Disp_Type_Record_Name (Def : Ghdl_Rtin_Type_Record_Acc;
+ Bounds_Ptr : Address)
+ is
+ Bounds : Address;
+ begin
+ Disp_Name (Def.Name);
+ if Bounds_Ptr = Null_Address then
+ return;
+ end if;
+ Bounds := Bounds_Ptr;
+ Disp_Type_Record_Bounds (Def, Bounds);
+ end Disp_Type_Record_Name;
+
procedure Disp_Subtype_Scalar_Range
(Stream : FILEs; Def : Ghdl_Rtin_Subtype_Scalar_Acc; Ctxt : Rti_Context)
is
@@ -633,6 +682,19 @@ package body Grt.Disp_Rti is
Disp_Name (To_Ghdl_Rtin_Type_Fileacc_Acc (Def).Name);
when Ghdl_Rtik_Type_Record =>
Disp_Name (To_Ghdl_Rtin_Type_Record_Acc (Def).Name);
+ when Ghdl_Rtik_Subtype_Record =>
+ declare
+ Sdef : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Def);
+ begin
+ if Sdef.Name /= null then
+ Disp_Name (Sdef.Name);
+ else
+ Disp_Type_Record_Name
+ (To_Ghdl_Rtin_Type_Record_Acc (Sdef.Basetype),
+ Loc_To_Addr (Sdef.Common.Depth, Sdef.Bounds, Ctxt));
+ end if;
+ end;
when Ghdl_Rtik_Type_Array =>
declare
Bounds : Address;
@@ -647,14 +709,14 @@ package body Grt.Disp_Rti is
end;
when Ghdl_Rtik_Subtype_Array =>
declare
- Sdef : Ghdl_Rtin_Subtype_Array_Acc;
+ Sdef : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Def);
begin
- Sdef := To_Ghdl_Rtin_Subtype_Array_Acc (Def);
if Sdef.Name /= null then
Disp_Name (Sdef.Name);
else
Disp_Type_Array_Name
- (Sdef.Basetype,
+ (To_Ghdl_Rtin_Type_Array_Acc (Sdef.Basetype),
Loc_To_Addr (Sdef.Common.Depth, Sdef.Bounds, Ctxt));
end if;
end;
@@ -796,7 +858,7 @@ package body Grt.Disp_Rti is
Ctxt : Rti_Context;
Indent : Natural)
is
- Addr : Address;
+ Addr, Bounds : Address;
Obj_Type : Ghdl_Rti_Access;
begin
Disp_Obj_Header (Obj, Indent);
@@ -807,13 +869,25 @@ package body Grt.Disp_Rti is
Put (" := ");
-- FIXME: put this into a function.
- if (Obj_Type.Kind = Ghdl_Rtik_Subtype_Array
- or Obj_Type.Kind = Ghdl_Rtik_Type_Record)
- and then Rti_Complex_Type (Obj_Type)
- then
- Addr := To_Addr_Acc (Addr).all;
- end if;
- Disp_Value (stdout, Obj_Type, Ctxt, Addr, Is_Sig);
+ Bounds := Null_Address;
+ case Obj_Type.Kind is
+ when Ghdl_Rtik_Subtype_Array
+ | Ghdl_Rtik_Type_Record
+ | Ghdl_Rtik_Subtype_Record =>
+ -- Object is a pointer.
+ if Rti_Complex_Type (Obj_Type) then
+ Addr := To_Addr_Acc (Addr).all;
+ end if;
+ when Ghdl_Rtik_Type_Array
+ | Ghdl_Rtik_Type_Unbounded_Record
+ | Ghdl_Rtik_Subtype_Unbounded_Record =>
+ -- Object is a fat pointer.
+ Bounds := To_Ghdl_Uc_Array_Acc (Addr).Bounds;
+ Addr := To_Ghdl_Uc_Array_Acc (Addr).Base;
+ when others =>
+ null;
+ end case;
+ Disp_Value (stdout, Obj_Type, Ctxt, Addr, Bounds, Is_Sig);
New_Line;
end Disp_Object;
@@ -1057,11 +1131,12 @@ package body Grt.Disp_Rti is
New_Line;
end Disp_Type_Array_Decl;
- procedure Disp_Subtype_Array_Decl (Def : Ghdl_Rtin_Subtype_Array_Acc;
+ procedure Disp_Subtype_Array_Decl (Def : Ghdl_Rtin_Subtype_Composite_Acc;
Ctxt : Rti_Context;
Indent : Natural)
is
- Basetype : constant Ghdl_Rtin_Type_Array_Acc := Def.Basetype;
+ Basetype : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (Def.Basetype);
begin
Disp_Indent (Indent);
Disp_Kind (Def.Common.Kind);
@@ -1123,6 +1198,27 @@ package body Grt.Disp_Rti is
end loop;
end Disp_Type_Record;
+ procedure Disp_Subtype_Record_Decl (Def : Ghdl_Rtin_Subtype_Composite_Acc;
+ Ctxt : Rti_Context;
+ Indent : Natural)
+ is
+ Basetype : constant Ghdl_Rtin_Type_Record_Acc :=
+ To_Ghdl_Rtin_Type_Record_Acc (Def.Basetype);
+ Bounds : Address;
+ begin
+ Disp_Indent (Indent);
+ Disp_Kind (Def.Common.Kind);
+ Put (": ");
+ Disp_Name (Def.Name);
+ Put (" is ");
+ Disp_Name (Basetype.Name);
+ if Def.Common.Kind = Ghdl_Rtik_Subtype_Record then
+ Bounds := Loc_To_Addr (Def.Common.Depth, Def.Bounds, Ctxt);
+ Disp_Type_Record_Bounds (Basetype, Bounds);
+ end if;
+ New_Line;
+ end Disp_Subtype_Record_Decl;
+
procedure Disp_Type_Protected (Def : Ghdl_Rtin_Type_Scalar_Acc;
Ctxt : Rti_Context;
Indent : Natural)
@@ -1192,14 +1288,18 @@ package body Grt.Disp_Rti is
(To_Ghdl_Rtin_Type_Array_Acc (Rti), Ctxt, Indent);
when Ghdl_Rtik_Subtype_Array =>
Disp_Subtype_Array_Decl
- (To_Ghdl_Rtin_Subtype_Array_Acc (Rti), Ctxt, Indent);
+ (To_Ghdl_Rtin_Subtype_Composite_Acc (Rti), Ctxt, Indent);
when Ghdl_Rtik_Type_Access
| Ghdl_Rtik_Type_File =>
Disp_Type_File_Or_Access
(To_Ghdl_Rtin_Type_Fileacc_Acc (Rti), Ctxt, Indent);
- when Ghdl_Rtik_Type_Record =>
+ when Ghdl_Rtik_Type_Record
+ | Ghdl_Rtik_Type_Unbounded_Record =>
Disp_Type_Record
(To_Ghdl_Rtin_Type_Record_Acc (Rti), Ctxt, Indent);
+ when Ghdl_Rtik_Subtype_Record =>
+ Disp_Subtype_Record_Decl
+ (To_Ghdl_Rtin_Subtype_Composite_Acc (Rti), Ctxt, Indent);
when Ghdl_Rtik_Type_Protected =>
Disp_Type_Protected
(To_Ghdl_Rtin_Type_Scalar_Acc (Rti), Ctxt, Indent);
diff --git a/src/grt/grt-disp_rti.ads b/src/grt/grt-disp_rti.ads
index 6033d2011..e1c63db88 100644
--- a/src/grt/grt-disp_rti.ads
+++ b/src/grt/grt-disp_rti.ads
@@ -37,6 +37,7 @@ package Grt.Disp_Rti is
Rti : Ghdl_Rti_Access;
Ctxt : Rti_Context;
Obj : in out Address;
+ Bounds : in out Address;
Is_Sig : Boolean);
procedure Register;
diff --git a/src/grt/grt-disp_tree.adb b/src/grt/grt-disp_tree.adb
index ce2144445..0be17c9e3 100644
--- a/src/grt/grt-disp_tree.adb
+++ b/src/grt/grt-disp_tree.adb
@@ -120,12 +120,13 @@ package body Grt.Disp_Tree is
To_Ghdl_Rtin_Block_Acc (Gen.Child);
Iter : constant Ghdl_Rtin_Object_Acc :=
To_Ghdl_Rtin_Object_Acc (Bod.Children (0));
- Addr : Address;
+ Addr, Bounds : Address;
begin
Disp_Name (Gen.Name);
Addr := Loc_To_Addr (Iter.Common.Depth, Iter.Loc, Ctxt);
+ Bounds := Null_Address;
Put ('(');
- Disp_Value (stdout, Iter.Obj_Type, Ctxt, Addr, False);
+ Disp_Value (stdout, Iter.Obj_Type, Ctxt, Addr, Bounds, False);
Put (')');
end;
when Ghdl_Rtik_Signal
diff --git a/src/grt/grt-rtis.ads b/src/grt/grt-rtis.ads
index 4d5571147..685df3eae 100644
--- a/src/grt/grt-rtis.ads
+++ b/src/grt/grt-rtis.ads
@@ -29,7 +29,9 @@ with Ada.Unchecked_Conversion;
package Grt.Rtis is
pragma Preelaborate (Grt.Rtis);
- -- Must be synchronized with trans-rtis.ads
+ -- To keep in sync with:
+ -- * trans-rtis.ads
+ -- * grt.disp_rti.Disp_Kind
type Ghdl_Rtik is
(Ghdl_Rtik_Top,
Ghdl_Rtik_Library, -- use scalar
@@ -73,24 +75,26 @@ package Grt.Rtis is
Ghdl_Rtik_Type_Array,
Ghdl_Rtik_Type_Record,
+ Ghdl_Rtik_Type_Unbounded_Record,
Ghdl_Rtik_Type_File,
Ghdl_Rtik_Subtype_Scalar,
Ghdl_Rtik_Subtype_Array,
Ghdl_Rtik_Subtype_Unconstrained_Array,
- Ghdl_Rtik_Subtype_Record,
- Ghdl_Rtik_Subtype_Access, -- 40
+ Ghdl_Rtik_Subtype_Record, -- 40
+ Ghdl_Rtik_Subtype_Unbounded_Record,
+ Ghdl_Rtik_Subtype_Access,
Ghdl_Rtik_Type_Protected,
Ghdl_Rtik_Element,
+
Ghdl_Rtik_Unit64,
Ghdl_Rtik_Unitptr,
-
Ghdl_Rtik_Attribute_Transaction,
Ghdl_Rtik_Attribute_Quiet,
Ghdl_Rtik_Attribute_Stable,
+
Ghdl_Rtik_Psl_Assert,
Ghdl_Rtik_Psl_Cover,
-
Ghdl_Rtik_Psl_Endpoint,
Ghdl_Rtik_Error);
@@ -128,6 +132,7 @@ package Grt.Rtis is
-- 0
Max_Depth : Ghdl_Rti_Depth;
end record;
+ pragma Convention (C, Ghdl_Rti_Common);
type Ghdl_Rti_Access is access all Ghdl_Rti_Common;
@@ -150,6 +155,7 @@ package Grt.Rtis is
Nbr_Child : Ghdl_Index_Type;
Children : Ghdl_Rti_Arr_Acc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Block);
type Ghdl_Rtin_Block_Acc is access Ghdl_Rtin_Block;
function To_Ghdl_Rtin_Block_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Block_Acc);
@@ -166,6 +172,7 @@ package Grt.Rtis is
Size : Ghdl_Index_Type;
Child : Ghdl_Rti_Access;
end record;
+ pragma Convention (C, Ghdl_Rtin_Generate);
type Ghdl_Rtin_Generate_Acc is access Ghdl_Rtin_Generate;
function To_Ghdl_Rtin_Generate_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Generate_Acc);
@@ -176,6 +183,7 @@ package Grt.Rtis is
Block : Ghdl_Rtin_Block;
Filename : Ghdl_C_String;
end record;
+ pragma Convention (C, Ghdl_Rtin_Block_Filename);
type Ghdl_Rtin_Block_Filename_Acc is access Ghdl_Rtin_Block_Filename;
function To_Ghdl_Rtin_Block_Filename_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Block_Filename_Acc);
@@ -194,6 +202,7 @@ package Grt.Rtis is
-- Line and column of the declaration.
Linecol : Ghdl_Index_Type;
end record;
+ pragma Convention (C, Ghdl_Rtin_Object);
type Ghdl_Rtin_Object_Acc is access Ghdl_Rtin_Object;
function To_Ghdl_Rtin_Object_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Object_Acc);
@@ -208,6 +217,7 @@ package Grt.Rtis is
Parent : Ghdl_Rti_Access;
Instance : Ghdl_Rti_Access; -- Component or entity.
end record;
+ pragma Convention (C, Ghdl_Rtin_Instance);
type Ghdl_Rtin_Instance_Acc is access Ghdl_Rtin_Instance;
function To_Ghdl_Rtin_Instance_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Instance_Acc);
@@ -235,6 +245,7 @@ package Grt.Rtis is
Nbr_Child : Ghdl_Index_Type;
Children : Ghdl_Rti_Arr_Acc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Component);
type Ghdl_Rtin_Component_Acc is access Ghdl_Rtin_Component;
function To_Ghdl_Rtin_Component_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Component_Acc);
@@ -247,6 +258,7 @@ package Grt.Rtis is
-- extended identifiers are represented as is too.
Names : Ghdl_C_String_Array_Ptr;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Enum);
type Ghdl_Rtin_Type_Enum_Acc is access Ghdl_Rtin_Type_Enum;
function To_Ghdl_Rtin_Type_Enum_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Enum_Acc);
@@ -255,6 +267,7 @@ package Grt.Rtis is
Common : Ghdl_Rti_Common;
Name : Ghdl_C_String;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Scalar);
type Ghdl_Rtin_Type_Scalar_Acc is access Ghdl_Rtin_Type_Scalar;
function To_Ghdl_Rtin_Type_Scalar_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Scalar_Acc);
@@ -265,6 +278,7 @@ package Grt.Rtis is
Basetype : Ghdl_Rti_Access;
Range_Loc : Ghdl_Rti_Loc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Subtype_Scalar);
type Ghdl_Rtin_Subtype_Scalar_Acc is access Ghdl_Rtin_Subtype_Scalar;
function To_Ghdl_Rtin_Subtype_Scalar_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Subtype_Scalar_Acc);
@@ -286,31 +300,34 @@ package Grt.Rtis is
Nbr_Dim : Ghdl_Index_Type;
Indexes : Ghdl_Rti_Arr_Acc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Array);
type Ghdl_Rtin_Type_Array_Acc is access Ghdl_Rtin_Type_Array;
function To_Ghdl_Rtin_Type_Array_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Array_Acc);
function To_Ghdl_Rti_Access is new Ada.Unchecked_Conversion
(Source => Ghdl_Rtin_Type_Array_Acc, Target => Ghdl_Rti_Access);
- type Ghdl_Rtin_Subtype_Array is record
+ type Ghdl_Rtin_Subtype_Composite is record
Common : Ghdl_Rti_Common;
Name : Ghdl_C_String;
- Basetype : Ghdl_Rtin_Type_Array_Acc;
+ Basetype : Ghdl_Rti_Access;
Bounds : Ghdl_Rti_Loc;
Valsize : Ghdl_Rti_Loc;
Sigsize : Ghdl_Rti_Loc;
end record;
- type Ghdl_Rtin_Subtype_Array_Acc is access Ghdl_Rtin_Subtype_Array;
- function To_Ghdl_Rtin_Subtype_Array_Acc is new Ada.Unchecked_Conversion
- (Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Subtype_Array_Acc);
+ pragma Convention (C, Ghdl_Rtin_Subtype_Composite);
+ type Ghdl_Rtin_Subtype_Composite_Acc is access Ghdl_Rtin_Subtype_Composite;
+ function To_Ghdl_Rtin_Subtype_Composite_Acc is new Ada.Unchecked_Conversion
+ (Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Subtype_Composite_Acc);
function To_Ghdl_Rti_Access is new Ada.Unchecked_Conversion
- (Source => Ghdl_Rtin_Subtype_Array_Acc, Target => Ghdl_Rti_Access);
+ (Source => Ghdl_Rtin_Subtype_Composite_Acc, Target => Ghdl_Rti_Access);
type Ghdl_Rtin_Type_Fileacc is record
Common : Ghdl_Rti_Common;
Name : Ghdl_C_String;
Base : Ghdl_Rti_Access;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Fileacc);
type Ghdl_Rtin_Type_Fileacc_Acc is access Ghdl_Rtin_Type_Fileacc;
function To_Ghdl_Rtin_Type_Fileacc_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Fileacc_Acc);
@@ -322,6 +339,7 @@ package Grt.Rtis is
Val_Off : Ghdl_Index_Type;
Sig_Off : Ghdl_Index_Type;
end record;
+ pragma Convention (C, Ghdl_Rtin_Element);
type Ghdl_Rtin_Element_Acc is access Ghdl_Rtin_Element;
function To_Ghdl_Rtin_Element_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Element_Acc);
@@ -332,6 +350,7 @@ package Grt.Rtis is
Nbrel : Ghdl_Index_Type;
Elements : Ghdl_Rti_Arr_Acc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Record);
type Ghdl_Rtin_Type_Record_Acc is access Ghdl_Rtin_Type_Record;
function To_Ghdl_Rtin_Type_Record_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Record_Acc);
@@ -341,6 +360,7 @@ package Grt.Rtis is
Name : Ghdl_C_String;
Value : Ghdl_I64;
end record;
+ pragma Convention (C, Ghdl_Rtin_Unit64);
type Ghdl_Rtin_Unit64_Acc is access Ghdl_Rtin_Unit64;
function To_Ghdl_Rtin_Unit64_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Unit64_Acc);
@@ -350,6 +370,7 @@ package Grt.Rtis is
Name : Ghdl_C_String;
Addr : Ghdl_Value_Ptr;
end record;
+ pragma Convention (C, Ghdl_Rtin_Unitptr);
type Ghdl_Rtin_Unitptr_Acc is access Ghdl_Rtin_Unitptr;
function To_Ghdl_Rtin_Unitptr_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Unitptr_Acc);
@@ -362,6 +383,7 @@ package Grt.Rtis is
Nbr : Ghdl_Index_Type;
Units : Ghdl_Rti_Arr_Acc;
end record;
+ pragma Convention (C, Ghdl_Rtin_Type_Physical);
type Ghdl_Rtin_Type_Physical_Acc is access Ghdl_Rtin_Type_Physical;
function To_Ghdl_Rtin_Type_Physical_Acc is new Ada.Unchecked_Conversion
(Source => Ghdl_Rti_Access, Target => Ghdl_Rtin_Type_Physical_Acc);
@@ -382,6 +404,7 @@ package Grt.Rtis is
Rti : Ghdl_Rti_Access;
Parent : Ghdl_Component_Link_Acc;
end record;
+ pragma Convention (C, Ghdl_Entity_Link_Type);
type Ghdl_Entity_Link_Acc is access Ghdl_Entity_Link_Type;
@@ -392,6 +415,7 @@ package Grt.Rtis is
Instance : Ghdl_Entity_Link_Acc;
Stmt : Ghdl_Rti_Access;
end record;
+ pragma Convention (C, Ghdl_Component_Link_Type);
function To_Ghdl_Component_Link_Acc is new Ada.Unchecked_Conversion
(Source => Address, Target => Ghdl_Component_Link_Acc);
diff --git a/src/grt/grt-rtis_addr.adb b/src/grt/grt-rtis_addr.adb
index 8be2a2e75..7be70eb02 100644
--- a/src/grt/grt-rtis_addr.adb
+++ b/src/grt/grt-rtis_addr.adb
@@ -239,12 +239,10 @@ package body Grt.Rtis_Addr is
end if;
end Get_Instance_Context;
- procedure Bound_To_Range (Bounds_Addr : Address;
- Def : Ghdl_Rtin_Type_Array_Acc;
- Res : out Ghdl_Range_Array)
+ procedure Extract_Range (Bounds : in out Address;
+ Def : Ghdl_Rti_Access;
+ Rng : out Ghdl_Range_Ptr)
is
- Bounds : Address;
-
procedure Align (A : Ghdl_Index_Type) is
begin
Bounds := Align (Bounds, Ghdl_Rti_Loc (A));
@@ -254,7 +252,37 @@ package body Grt.Rtis_Addr is
begin
Bounds := Bounds + (S / Storage_Unit);
end Update;
+ begin
+ if Bounds = Null_Address then
+ -- Propagate failure.
+ Rng := null;
+ return;
+ end if;
+ case Def.Kind is
+ when Ghdl_Rtik_Type_I32 =>
+ Align (Ghdl_Range_I32'Alignment);
+ Rng := To_Ghdl_Range_Ptr (Bounds);
+ Update (Ghdl_Range_I32'Size);
+ when Ghdl_Rtik_Type_B1 =>
+ Align (Ghdl_Range_B1'Alignment);
+ Rng := To_Ghdl_Range_Ptr (Bounds);
+ Update (Ghdl_Range_B1'Size);
+ when Ghdl_Rtik_Type_E8 =>
+ Align (Ghdl_Range_E8'Alignment);
+ Rng := To_Ghdl_Range_Ptr (Bounds);
+ Update (Ghdl_Range_E8'Size);
+ when others =>
+ -- Bounds are not known anymore.
+ Rng := null;
+ end case;
+ end Extract_Range;
+
+ procedure Bound_To_Range (Bounds_Addr : Address;
+ Def : Ghdl_Rtin_Type_Array_Acc;
+ Res : out Ghdl_Range_Array)
+ is
+ Bounds : Address;
Idx_Def : Ghdl_Rti_Access;
begin
if Res'Length /= Def.Nbr_Dim or else Res'First /= 0 then
@@ -265,45 +293,18 @@ package body Grt.Rtis_Addr is
for I in 0 .. Def.Nbr_Dim - 1 loop
Idx_Def := Def.Indexes (I);
-
- if Bounds = Null_Address then
- Res (I) := null;
- else
- Idx_Def := Get_Base_Type (Idx_Def);
- case Idx_Def.Kind is
- when Ghdl_Rtik_Type_I32 =>
- Align (Ghdl_Range_I32'Alignment);
- Res (I) := To_Ghdl_Range_Ptr (Bounds);
- Update (Ghdl_Range_I32'Size);
- when Ghdl_Rtik_Type_B1 =>
- Align (Ghdl_Range_B1'Alignment);
- Res (I) := To_Ghdl_Range_Ptr (Bounds);
- Update (Ghdl_Range_B1'Size);
- when Ghdl_Rtik_Type_E8 =>
- Align (Ghdl_Range_E8'Alignment);
- Res (I) := To_Ghdl_Range_Ptr (Bounds);
- Update (Ghdl_Range_E8'Size);
- when Ghdl_Rtik_Type_E32 =>
- Align (Ghdl_Range_E32'Alignment);
- Res (I) := To_Ghdl_Range_Ptr (Bounds);
- Update (Ghdl_Range_E32'Size);
- when others =>
- -- Bounds are not known anymore.
- Bounds := Null_Address;
- end case;
- end if;
+ Idx_Def := Get_Base_Type (Idx_Def);
+ Extract_Range (Bounds, Idx_Def, Res (I));
end loop;
end Bound_To_Range;
- function Get_Base_Type (Atype : Ghdl_Rti_Access) return Ghdl_Rti_Access
- is
+ function Get_Base_Type (Atype : Ghdl_Rti_Access) return Ghdl_Rti_Access is
begin
case Atype.Kind is
when Ghdl_Rtik_Subtype_Scalar =>
return To_Ghdl_Rtin_Subtype_Scalar_Acc (Atype).Basetype;
when Ghdl_Rtik_Subtype_Array =>
- return To_Ghdl_Rti_Access
- (To_Ghdl_Rtin_Subtype_Array_Acc (Atype).Basetype);
+ return To_Ghdl_Rtin_Subtype_Composite_Acc (Atype).Basetype;
when Ghdl_Rtik_Type_E8
| Ghdl_Rtik_Type_E32
| Ghdl_Rtik_Type_B1 =>
diff --git a/src/grt/grt-rtis_addr.ads b/src/grt/grt-rtis_addr.ads
index 574f5cba5..550576733 100644
--- a/src/grt/grt-rtis_addr.ads
+++ b/src/grt/grt-rtis_addr.ads
@@ -85,6 +85,12 @@ package Grt.Rtis_Addr is
Ctxt : Rti_Context;
Sub_Ctxt : out Rti_Context);
+ -- Extract range RNG of type DEF from BOUNDS. BOUNDS is updated to the
+ -- next range. DEF must be a base type.
+ procedure Extract_Range (Bounds : in out Address;
+ Def : Ghdl_Rti_Access;
+ Rng : out Ghdl_Range_Ptr);
+
-- Extract range of every dimension from bounds.
procedure Bound_To_Range (Bounds_Addr : Address;
Def : Ghdl_Rtin_Type_Array_Acc;
diff --git a/src/grt/grt-rtis_utils.adb b/src/grt/grt-rtis_utils.adb
index a43a20066..e520e5435 100644
--- a/src/grt/grt-rtis_utils.adb
+++ b/src/grt/grt-rtis_utils.adb
@@ -267,14 +267,17 @@ package body Grt.Rtis_Utils is
end case;
end Pos_To_Vstring;
- procedure Handle_Array_1 (El_Rti : Ghdl_Rti_Access;
- Rngs : Ghdl_Range_Array;
- Rtis : Ghdl_Rti_Arr_Acc;
+ procedure Handle_Array_1 (Arr_Rti : Ghdl_Rtin_Type_Array_Acc;
+ Bounds : in out Address;
Index : Ghdl_Index_Type)
is
+ Idx_Rti : constant Ghdl_Rti_Access := Arr_Rti.Indexes (Index);
+ Base_Type : constant Ghdl_Rti_Access := Get_Base_Type (Idx_Rti);
+ El_Rti : constant Ghdl_Rti_Access := Arr_Rti.Element;
+ Last_Index : constant Ghdl_Index_Type := Arr_Rti.Nbr_Dim - 1;
+ Rng : Ghdl_Range_Ptr;
Len : Ghdl_Index_Type;
P : Natural;
- Base_Type : Ghdl_Rti_Access;
begin
P := Length (Name);
if Index = 0 then
@@ -283,16 +286,16 @@ package body Grt.Rtis_Utils is
Append (Name, ',');
end if;
- Base_Type := Get_Base_Type (Rtis (Index));
- Len := Range_To_Length (Rngs (Index), Base_Type);
+ Extract_Range (Bounds, Base_Type, Rng);
+ Len := Range_To_Length (Rng, Base_Type);
for I in 1 .. Len loop
- Pos_To_Vstring (Name, Base_Type, Rngs (Index), I - 1);
- if Index = Rngs'Last then
+ Pos_To_Vstring (Name, Base_Type, Rng, I - 1);
+ if Index = Last_Index then
Append (Name, ')');
Handle_Any (El_Rti);
else
- Handle_Array_1 (El_Rti, Rngs, Rtis, Index + 1);
+ Handle_Array_1 (Arr_Rti, Bounds, Index + 1);
end if;
Truncate (Name, P + 1);
end loop;
@@ -302,12 +305,11 @@ package body Grt.Rtis_Utils is
procedure Handle_Array (Rti : Ghdl_Rtin_Type_Array_Acc;
Vals : Ghdl_Uc_Array_Acc)
is
- Nbr_Dim : constant Ghdl_Index_Type := Rti.Nbr_Dim;
- Rngs : Ghdl_Range_Array (0 .. Nbr_Dim - 1);
+ Bounds : Address;
begin
- Bound_To_Range (Vals.Bounds, Rti, Rngs);
Addr := Vals.Base;
- Handle_Array_1 (Rti.Element, Rngs, Rti.Indexes, 0);
+ Bounds := Vals.Bounds;
+ Handle_Array_1 (Rti, Bounds, 0);
end Handle_Array;
procedure Handle_Record (Rti : Ghdl_Rtin_Type_Record_Acc)
@@ -356,14 +358,14 @@ package body Grt.Rtis_Utils is
To_Ghdl_Uc_Array_Acc (Addr));
when Ghdl_Rtik_Subtype_Array =>
declare
- St : constant Ghdl_Rtin_Subtype_Array_Acc :=
- To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
- Bt : constant Ghdl_Rtin_Type_Array_Acc := St.Basetype;
- Rngs : Ghdl_Range_Array (0 .. Bt.Nbr_Dim - 1);
+ St : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
+ Bt : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (St.Basetype);
+ Bounds : Address;
begin
- Bound_To_Range
- (Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt), Bt, Rngs);
- Handle_Array_1 (Bt.Element, Rngs, Bt.Indexes, 0);
+ Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt);
+ Handle_Array_1 (Bt, Bounds, 0);
end;
-- when Ghdl_Rtik_Type_File =>
-- declare
diff --git a/src/grt/grt-vcd.adb b/src/grt/grt-vcd.adb
index eab5fa89a..ca0d7c6e5 100644
--- a/src/grt/grt-vcd.adb
+++ b/src/grt/grt-vcd.adb
@@ -352,9 +352,9 @@ package body Grt.Vcd is
Kind := Rti_To_Vcd_Kind (Rti);
when Ghdl_Rtik_Subtype_Array =>
declare
- St : Ghdl_Rtin_Subtype_Array_Acc;
+ St : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
begin
- St := To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
Kind := Rti_To_Vcd_Kind (St.Basetype);
Irange := To_Ghdl_Range_Ptr
(Loc_To_Addr (St.Common.Depth, St.Bounds,
diff --git a/src/grt/grt-waves.adb b/src/grt/grt-waves.adb
index 33edffdf2..43ae4ec73 100644
--- a/src/grt/grt-waves.adb
+++ b/src/grt/grt-waves.adb
@@ -623,17 +623,17 @@ package body Grt.Waves is
end;
when Ghdl_Rtik_Subtype_Array =>
declare
- Arr : Ghdl_Rtin_Subtype_Array_Acc;
+ Arr : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
B_Ctxt : Rti_Context;
begin
- Arr := To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
Create_String_Id (Arr.Name);
if Rti_Complex_Type (Rti) then
B_Ctxt := Ctxt;
else
B_Ctxt := N_Ctxt;
end if;
- Create_Type (To_Ghdl_Rti_Access (Arr.Basetype), B_Ctxt);
+ Create_Type (Arr.Basetype, B_Ctxt);
end;
when Ghdl_Rtik_Type_Array =>
declare
@@ -1313,20 +1313,21 @@ package body Grt.Waves is
end;
when Ghdl_Rtik_Subtype_Array =>
declare
- Arr : Ghdl_Rtin_Subtype_Array_Acc;
+ Arr : constant Ghdl_Rtin_Subtype_Composite_Acc :=
+ To_Ghdl_Rtin_Subtype_Composite_Acc (Rti);
begin
- Arr := To_Ghdl_Rtin_Subtype_Array_Acc (Rti);
Write_String_Id (Arr.Name);
- Write_Type_Id (To_Ghdl_Rti_Access (Arr.Basetype), Ctxt);
+ Write_Type_Id (Arr.Basetype, Ctxt);
declare
- Rngs : Ghdl_Range_Array
- (0 .. Arr.Basetype.Nbr_Dim - 1);
+ Bt : constant Ghdl_Rtin_Type_Array_Acc :=
+ To_Ghdl_Rtin_Type_Array_Acc (Arr.Basetype);
+ Rngs : Ghdl_Range_Array (0 .. Bt.Nbr_Dim - 1);
begin
Bound_To_Range
(Loc_To_Addr (Rti.Depth, Arr.Bounds, Ctxt),
- Arr.Basetype, Rngs);
+ Bt, Rngs);
for I in Rngs'Range loop
- Write_Range (Arr.Basetype.Indexes (I), Rngs (I));
+ Write_Range (Bt.Indexes (I), Rngs (I));
end loop;
end;
end;
diff --git a/src/vhdl/translate/trans-chap3.adb b/src/vhdl/translate/trans-chap3.adb
index 8f6ae4c12..969be57ad 100644
--- a/src/vhdl/translate/trans-chap3.adb
+++ b/src/vhdl/translate/trans-chap3.adb
@@ -1225,6 +1225,8 @@ package body Trans.Chap3 is
-- By default, use the same representation as the type mark.
Info.all := Type_Mark_Info.all;
Info.S := Ortho_Info_Subtype_Record_Init;
+ -- However, it is a different subtype which has its own rti.
+ Info.Type_Rti := O_Dnode_Null;
if Get_Constraint_State (Def) /= Fully_Constrained
or else not Has_New_Constraints
diff --git a/src/vhdl/translate/trans-rtis.adb b/src/vhdl/translate/trans-rtis.adb
index 96abfc206..dd60c817a 100644
--- a/src/vhdl/translate/trans-rtis.adb
+++ b/src/vhdl/translate/trans-rtis.adb
@@ -105,14 +105,14 @@ package body Trans.Rtis is
Ghdl_Rtin_Type_Array_Nbrdim : O_Fnode;
Ghdl_Rtin_Type_Array_Indexes : O_Fnode;
- -- Node for an array subtype.
- Ghdl_Rtin_Subtype_Array : O_Tnode;
- Ghdl_Rtin_Subtype_Array_Common : O_Fnode;
- Ghdl_Rtin_Subtype_Array_Name : O_Fnode;
- Ghdl_Rtin_Subtype_Array_Basetype : O_Fnode;
- Ghdl_Rtin_Subtype_Array_Bounds : O_Fnode;
- Ghdl_Rtin_Subtype_Array_Valsize : O_Fnode;
- Ghdl_Rtin_Subtype_Array_Sigsize : O_Fnode;
+ -- Node for a composite subtype.
+ Ghdl_Rtin_Subtype_Composite : O_Tnode;
+ Ghdl_Rtin_Subtype_Composite_Common : O_Fnode;
+ Ghdl_Rtin_Subtype_Composite_Name : O_Fnode;
+ Ghdl_Rtin_Subtype_Composite_Basetype : O_Fnode;
+ Ghdl_Rtin_Subtype_Composite_Bounds : O_Fnode;
+ Ghdl_Rtin_Subtype_Composite_Valsize : O_Fnode;
+ Ghdl_Rtin_Subtype_Composite_Sigsize : O_Fnode;
-- Node for a record element.
Ghdl_Rtin_Element : O_Tnode;
@@ -271,6 +271,9 @@ package body Trans.Rtis is
(Constr, Get_Identifier ("__ghdl_rtik_type_record"),
Ghdl_Rtik_Type_Record);
New_Enum_Literal
+ (Constr, Get_Identifier ("__ghdl_rtik_type_unbounded_record"),
+ Ghdl_Rtik_Type_Unbounded_Record);
+ New_Enum_Literal
(Constr, Get_Identifier ("__ghdl_rtik_type_file"),
Ghdl_Rtik_Type_File);
New_Enum_Literal
@@ -287,6 +290,9 @@ package body Trans.Rtis is
(Constr, Get_Identifier ("__ghdl_rtik_subtype_record"),
Ghdl_Rtik_Subtype_Record);
New_Enum_Literal
+ (Constr, Get_Identifier ("__ghdl_rtik_subtype_unbounded_record"),
+ Ghdl_Rtik_Subtype_Unbounded_Record);
+ New_Enum_Literal
(Constr, Get_Identifier ("__ghdl_rtik_subtype_access"),
Ghdl_Rtik_Subtype_Access);
New_Enum_Literal
@@ -596,26 +602,26 @@ package body Trans.Rtis is
Ghdl_Rtin_Type_Array);
end;
- -- subtype_Array.
+ -- subtype_composite.
declare
Constr : O_Element_List;
begin
Start_Record_Type (Constr);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Common,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Common,
Get_Identifier ("common"), Ghdl_Rti_Common);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Name,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Name,
Get_Identifier ("name"), Char_Ptr_Type);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Basetype,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Basetype,
Get_Identifier ("basetype"), Ghdl_Rti_Access);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Bounds,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Bounds,
Get_Identifier ("bounds"), Ghdl_Ptr_Type);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Valsize,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Valsize,
Get_Identifier ("val_size"), Ghdl_Ptr_Type);
- New_Record_Field (Constr, Ghdl_Rtin_Subtype_Array_Sigsize,
+ New_Record_Field (Constr, Ghdl_Rtin_Subtype_Composite_Sigsize,
Get_Identifier ("sig_size"), Ghdl_Ptr_Type);
- Finish_Record_Type (Constr, Ghdl_Rtin_Subtype_Array);
- New_Type_Decl (Get_Identifier ("__ghdl_rtin_subtype_array"),
- Ghdl_Rtin_Subtype_Array);
+ Finish_Record_Type (Constr, Ghdl_Rtin_Subtype_Composite);
+ New_Type_Decl (Get_Identifier ("__ghdl_rtin_subtype_composite"),
+ Ghdl_Rtin_Subtype_Composite);
end;
-- type record.
@@ -1365,10 +1371,6 @@ package body Trans.Rtis is
Base_Type := Get_Type (Get_File_Type_Mark (Atype));
Base := Generate_Type_Definition (Base_Type);
Kind := Ghdl_Rtik_Type_File;
- when Iir_Kind_Record_Subtype_Definition =>
- Base_Type := Get_Base_Type (Atype);
- Base := Get_Info (Base_Type).Type_Rti;
- Kind := Ghdl_Rtik_Subtype_Record;
when Iir_Kind_Access_Subtype_Definition =>
Base_Type := Get_Base_Type (Atype);
Base := Get_Info (Base_Type).Type_Rti;
@@ -1508,12 +1510,11 @@ package body Trans.Rtis is
Finish_Init_Value (Info.Type_Rti, Val);
end Generate_Array_Type_Definition;
- procedure Generate_Array_Subtype_Definition
- (Atype : Iir_Array_Subtype_Definition)
+ procedure Generate_Composite_Subtype_Definition (Atype : Iir)
is
- Base_Type : Iir;
- Base_Info : Type_Info_Acc;
- Info : Type_Info_Acc;
+ Info : constant Type_Info_Acc := Get_Info (Atype);
+ Base_Type : constant Iir := Get_Base_Type (Atype);
+ Base_Info : constant Type_Info_Acc := Get_Info (Base_Type);
Aggr : O_Record_Aggr_List;
Val : O_Cnode;
Base_Rti : O_Dnode;
@@ -1521,31 +1522,15 @@ package body Trans.Rtis is
Bounds : Var_Type;
Name : O_Dnode;
Kind : O_Cnode;
- Mark : Id_Mark_Type;
Depth : Rti_Depth_Type;
begin
- -- FIXME: temporary work-around
- if Get_Constraint_State (Atype) /= Fully_Constrained then
- return;
- end if;
-
- Info := Get_Info (Atype);
-
- Base_Type := Get_Base_Type (Atype);
- Base_Info := Get_Info (Base_Type);
- if Base_Info.Type_Rti = O_Dnode_Null then
- Push_Identifier_Prefix (Mark, "BT");
- Base_Rti := Generate_Type_Definition (Base_Type);
- Pop_Identifier_Prefix (Mark);
- end if;
-
Bounds := Info.S.Composite_Bounds;
Depth := Get_Depth_From_Var (Bounds);
Info.B.Rti_Max_Depth :=
Rti_Depth_Type'Max (Depth, Base_Info.B.Rti_Max_Depth);
-- Generate node.
- Generate_Type_Rti (Info, Ghdl_Rtin_Subtype_Array);
+ Generate_Type_Rti (Info, Ghdl_Rtin_Subtype_Composite);
if Global_Storage = O_Storage_External then
return;
@@ -1554,14 +1539,18 @@ package body Trans.Rtis is
Name := Generate_Type_Name (Atype);
Start_Init_Value (Info.Type_Rti);
- Start_Record_Aggr (Aggr, Ghdl_Rtin_Subtype_Array);
+ Start_Record_Aggr (Aggr, Ghdl_Rtin_Subtype_Composite);
case Info.Type_Mode is
when Type_Mode_Array =>
Kind := Ghdl_Rtik_Subtype_Array;
- when Type_Mode_Fat_Array =>
+ when Type_Mode_Unbounded_Array =>
Kind := Ghdl_Rtik_Subtype_Unconstrained_Array;
+ when Type_Mode_Record =>
+ Kind := Ghdl_Rtik_Subtype_Record;
+ when Type_Mode_Unbounded_Record =>
+ Kind := Ghdl_Rtik_Subtype_Unbounded_Record;
when others =>
- Error_Kind ("generate_array_subtype_definition", Atype);
+ Error_Kind ("generate_composite_subtype_definition", Atype);
end case;
New_Record_Aggr_El
(Aggr,
@@ -1577,7 +1566,8 @@ package body Trans.Rtis is
New_Record_Aggr_El (Aggr, Val);
for I in Mode_Value .. Mode_Signal loop
case Info.Type_Mode is
- when Type_Mode_Array =>
+ when Type_Mode_Array
+ | Type_Mode_Record =>
Val := Get_Null_Loc;
if Info.Ortho_Type (I) /= O_Tnode_Null then
if Is_Complex_Type (Info) then
@@ -1589,16 +1579,41 @@ package body Trans.Rtis is
Ghdl_Ptr_Type);
end if;
end if;
- when Type_Mode_Fat_Array =>
+ when Type_Mode_Unbounded_Array
+ | Type_Mode_Unbounded_Record =>
Val := Get_Null_Loc;
when others =>
- Error_Kind ("generate_array_subtype_definition", Atype);
+ Error_Kind ("generate_composite_subtype_definition", Atype);
end case;
New_Record_Aggr_El (Aggr, Val);
end loop;
Finish_Record_Aggr (Aggr, Val);
Finish_Init_Value (Info.Type_Rti, Val);
+ end Generate_Composite_Subtype_Definition;
+
+ procedure Generate_Array_Subtype_Definition
+ (Atype : Iir_Array_Subtype_Definition)
+ is
+ Base_Type : constant Iir := Get_Base_Type (Atype);
+ Base_Info : constant Type_Info_Acc := Get_Info (Base_Type);
+ Base_Rti : O_Dnode;
+ pragma Unreferenced (Base_Rti);
+ Mark : Id_Mark_Type;
+ begin
+ -- FIXME: temporary work-around
+ if Get_Constraint_State (Atype) /= Fully_Constrained then
+ return;
+ end if;
+
+ -- Generate base type (when anonymous).
+ if Base_Info.Type_Rti = O_Dnode_Null then
+ Push_Identifier_Prefix (Mark, "BT");
+ Base_Rti := Generate_Type_Definition (Base_Type);
+ Pop_Identifier_Prefix (Mark);
+ end if;
+
+ Generate_Composite_Subtype_Definition (Atype);
end Generate_Array_Subtype_Definition;
procedure Generate_Record_Type_Definition (Atype : Iir)
@@ -1675,15 +1690,20 @@ package body Trans.Rtis is
declare
Aggr : O_Record_Aggr_List;
Name : O_Dnode;
+ Rtik : O_Cnode;
begin
Name := Generate_Type_Name (Atype);
Start_Init_Value (Info.Type_Rti);
Start_Record_Aggr (Aggr, Ghdl_Rtin_Type_Record);
+ if Get_Constraint_State (Atype) = Fully_Constrained then
+ Rtik := Ghdl_Rtik_Type_Record;
+ else
+ Rtik := Ghdl_Rtik_Type_Unbounded_Record;
+ end if;
New_Record_Aggr_El
(Aggr,
- Generate_Common_Type (Ghdl_Rtik_Type_Record, 0, Max_Depth,
- Type_To_Mode (Atype)));
+ Generate_Common_Type (Rtik, 0, Max_Depth, Type_To_Mode (Atype)));
New_Record_Aggr_El (Aggr, New_Name_Address (Name));
New_Record_Aggr_El
(Aggr, New_Unsigned_Literal
@@ -1750,8 +1770,9 @@ package body Trans.Rtis is
when Iir_Kind_Access_Type_Definition
| Iir_Kind_File_Type_Definition =>
Generate_Fileacc_Type_Definition (Atype);
- when Iir_Kind_Record_Subtype_Definition
- | Iir_Kind_Access_Subtype_Definition =>
+ when Iir_Kind_Record_Subtype_Definition =>
+ Generate_Composite_Subtype_Definition (Atype);
+ when Iir_Kind_Access_Subtype_Definition =>
-- FIXME: No separate infos (yet).
Info.Type_Rti := Get_Info (Get_Base_Type (Atype)).Type_Rti;
when Iir_Kind_Record_Type_Definition =>
@@ -1787,7 +1808,7 @@ package body Trans.Rtis is
when Iir_Kind_Array_Type_Definition =>
Rti_Type := Ghdl_Rtin_Type_Array;
when Iir_Kind_Array_Subtype_Definition =>
- Rti_Type := Ghdl_Rtin_Subtype_Array;
+ Rti_Type := Ghdl_Rtin_Subtype_Composite;
when Iir_Kind_Access_Type_Definition
| Iir_Kind_File_Type_Definition =>
Rti_Type := Ghdl_Rtin_Type_Fileacc;
diff --git a/src/vhdl/translate/trans-rtis.ads b/src/vhdl/translate/trans-rtis.ads
index 8f51957f3..73bc514e0 100644
--- a/src/vhdl/translate/trans-rtis.ads
+++ b/src/vhdl/translate/trans-rtis.ads
@@ -54,11 +54,13 @@ package Trans.Rtis is
Ghdl_Rtik_Type_Access : O_Cnode;
Ghdl_Rtik_Type_Array : O_Cnode;
Ghdl_Rtik_Type_Record : O_Cnode;
+ Ghdl_Rtik_Type_Unbounded_Record : O_Cnode;
Ghdl_Rtik_Type_File : O_Cnode;
Ghdl_Rtik_Subtype_Scalar : O_Cnode;
Ghdl_Rtik_Subtype_Array : O_Cnode;
Ghdl_Rtik_Subtype_Unconstrained_Array : O_Cnode;
Ghdl_Rtik_Subtype_Record : O_Cnode;
+ Ghdl_Rtik_Subtype_Unbounded_Record : O_Cnode;
Ghdl_Rtik_Subtype_Access : O_Cnode;
Ghdl_Rtik_Type_Protected : O_Cnode;
Ghdl_Rtik_Element : O_Cnode;