diff options
author | Tristan Gingold <tgingold@free.fr> | 2017-02-22 07:51:27 +0100 |
---|---|---|
committer | Tristan Gingold <tgingold@free.fr> | 2017-02-22 07:51:27 +0100 |
commit | c1e39ee2038b36ac1d7455f42a33564133e8d6ea (patch) | |
tree | a6835ab789f591f95ad81b86e405dffa835418c5 /src/grt | |
parent | 58e1d46280fa86b0c369d9134d51b90771b9a25c (diff) | |
download | ghdl-c1e39ee2038b36ac1d7455f42a33564133e8d6ea.tar.gz ghdl-c1e39ee2038b36ac1d7455f42a33564133e8d6ea.tar.bz2 ghdl-c1e39ee2038b36ac1d7455f42a33564133e8d6ea.zip |
rtis/vcd/ghw: handle record subtypes.
Diffstat (limited to 'src/grt')
-rw-r--r-- | src/grt/ghwlib.c | 21 | ||||
-rw-r--r-- | src/grt/ghwlib.h | 11 | ||||
-rw-r--r-- | src/grt/grt-disp_rti.adb | 41 | ||||
-rw-r--r-- | src/grt/grt-ghw.ads | 1 | ||||
-rw-r--r-- | src/grt/grt-rtis_utils.adb | 105 | ||||
-rw-r--r-- | src/grt/grt-rtis_utils.ads | 13 | ||||
-rw-r--r-- | src/grt/grt-vcd.adb | 38 | ||||
-rw-r--r-- | src/grt/grt-waves.adb | 50 |
8 files changed, 179 insertions, 101 deletions
diff --git a/src/grt/ghwlib.c b/src/grt/ghwlib.c index eadb64cdd..996057ff6 100644 --- a/src/grt/ghwlib.c +++ b/src/grt/ghwlib.c @@ -411,6 +411,8 @@ get_nbr_elements (union ghw_type *t) return t->sa.nbr_el; case ghdl_rtik_type_record: return t->rec.nbr_el; + case ghdl_rtik_subtype_record: + return t->sr.base->nbr_el; default: fprintf (stderr, "get_nbr_elements: unhandled type %d\n", t->kind); abort (); @@ -621,6 +623,19 @@ ghw_read_type (struct ghw_handler *h) h->types[i] = (union ghw_type *)rec; } break; + case ghdl_rtik_subtype_record: + { + struct ghw_subtype_record *sr; + + sr = malloc (sizeof (struct ghw_subtype_record)); + sr->kind = t; + sr->name = ghw_read_strid (h); + sr->base = (struct ghw_type_record *)ghw_read_typeid (h); + if (h->flag_verbose > 1) + printf ("subtype record: %s\n", sr->name); + h->types[i] = (union ghw_type *)sr; + } + break; default: fprintf (stderr, "ghw_read_type: unknown type %d\n", t); return -1; @@ -723,6 +738,8 @@ ghw_read_signal (struct ghw_handler *h, unsigned int *sigs, union ghw_type *t) } } return 0; + case ghdl_rtik_subtype_record: + return ghw_read_signal (h, sigs, (union ghw_type *)t->sr.base); default: fprintf (stderr, "ghw_read_signal: type kind %d unhandled\n", t->kind); abort (); @@ -1686,6 +1703,9 @@ ghw_disp_subtype_definition (struct ghw_handler *h, union ghw_type *t) printf (")"); } break; + case ghdl_rtik_subtype_record: + ghw_disp_typename (h, (union ghw_type *)t->sr.base); + break; default: printf ("ghw_disp_subtype_definition: unhandled type kind %d\n", t->kind); @@ -1792,6 +1812,7 @@ ghw_disp_type (struct ghw_handler *h, union ghw_type *t) case ghdl_rtik_subtype_array: case ghdl_rtik_subtype_array_ptr: case ghdl_rtik_subtype_scalar: + case ghdl_rtik_subtype_record: { struct ghw_type_common *c = &t->common; printf ("subtype %s is ", c->name); diff --git a/src/grt/ghwlib.h b/src/grt/ghwlib.h index bcb4d9b2c..7e51376af 100644 --- a/src/grt/ghwlib.h +++ b/src/grt/ghwlib.h @@ -219,7 +219,15 @@ struct ghw_type_record int nbr_el; /* Number of scalar signals. */ struct ghw_record_element *el; }; - + +struct ghw_subtype_record +{ + enum ghdl_rtik kind; + const char *name; + + struct ghw_type_record *base; +}; + union ghw_type { enum ghdl_rtik kind; @@ -229,6 +237,7 @@ union ghw_type struct ghw_type_physical ph; struct ghw_subtype_scalar ss; struct ghw_subtype_array sa; + struct ghw_subtype_record sr; struct ghw_type_array ar; struct ghw_type_record rec; }; diff --git a/src/grt/grt-disp_rti.adb b/src/grt/grt-disp_rti.adb index bf77e56dc..898300c26 100644 --- a/src/grt/grt-disp_rti.adb +++ b/src/grt/grt-disp_rti.adb @@ -259,26 +259,7 @@ package body Grt.Disp_Rti is end if; Put (Stream, El.Name); Put (" => "); - if Is_Sig then - El_Addr := Obj + El.Sig_Off; - else - El_Addr := Obj + El.Val_Off; - end if; - 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; + Record_To_Element_Base (Obj, El, Is_Sig, El_Addr); Disp_Value (Stream, El.Eltype, Ctxt, El_Addr, Bounds, Is_Sig); end loop; Put (")"); @@ -868,25 +849,7 @@ package body Grt.Disp_Rti is Disp_Subtype_Indication (Obj_Type, Ctxt, Addr); Put (" := "); - -- FIXME: put this into a function. - 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; + Object_To_Base_Bounds (Obj_Type, Addr, Addr, Bounds); Disp_Value (stdout, Obj_Type, Ctxt, Addr, Bounds, Is_Sig); New_Line; end Disp_Object; diff --git a/src/grt/grt-ghw.ads b/src/grt/grt-ghw.ads index 6dfc2c648..6ceb937d1 100644 --- a/src/grt/grt-ghw.ads +++ b/src/grt/grt-ghw.ads @@ -59,4 +59,5 @@ package Grt.Ghw is Ghw_Rtik_Type_Record : constant Ghw_Rtik := 32; Ghw_Rtik_Subtype_Scalar : constant Ghw_Rtik := 34; Ghw_Rtik_Subtype_Array : constant Ghw_Rtik := 35; + Ghw_Rtik_Subtype_Record : constant Ghw_Rtik := 38; end Grt.Ghw; diff --git a/src/grt/grt-rtis_utils.adb b/src/grt/grt-rtis_utils.adb index e520e5435..2c603106f 100644 --- a/src/grt/grt-rtis_utils.adb +++ b/src/grt/grt-rtis_utils.adb @@ -151,6 +151,59 @@ package body Grt.Rtis_Utils is Append (Vstr, Enum_Rti.Names (Val)); end Get_Enum_Value; + procedure Object_To_Base_Bounds (Obj_Type : Ghdl_Rti_Access; + Obj_Loc : Address; + Addr : out Address; + Bounds : out Address) is + begin + -- FIXME: put this into a function. + Bounds := Null_Address; + Addr := Obj_Loc; + 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 (Obj_Loc).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 (Obj_Loc).Bounds; + Addr := To_Ghdl_Uc_Array_Acc (Obj_Loc).Base; + when others => + null; + end case; + end Object_To_Base_Bounds; + + procedure Record_To_Element_Base (Obj : Address; + El : Ghdl_Rtin_Element_Acc; + Is_Sig : Boolean; + Addr : out Address) is + begin + if Is_Sig then + Addr := Obj + El.Sig_Off; + else + Addr := Obj + El.Val_Off; + end if; + 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 + Addr := Obj + To_Ghdl_Index_Acc (Addr).all; + end if; + when Ghdl_Rtik_Type_Array + | Ghdl_Rtik_Type_Unbounded_Record + | Ghdl_Rtik_Subtype_Unbounded_Record => + -- Element is an offset. + Addr := Obj + To_Ghdl_Index_Acc (Addr).all; + when others => + null; + end case; + end Record_To_Element_Base; procedure Foreach_Scalar (Ctxt : Rti_Context; Obj_Type : Ghdl_Rti_Access; @@ -160,6 +213,7 @@ package body Grt.Rtis_Utils is is -- Current address. Addr : Address; + Bounds : Address; Name : Vstring; @@ -268,7 +322,6 @@ package body Grt.Rtis_Utils is end Pos_To_Vstring; 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); @@ -278,6 +331,7 @@ package body Grt.Rtis_Utils is Rng : Ghdl_Range_Ptr; Len : Ghdl_Index_Type; P : Natural; + Cur_Bounds : Address; begin P := Length (Name); if Index = 0 then @@ -289,29 +343,21 @@ package body Grt.Rtis_Utils is Extract_Range (Bounds, Base_Type, Rng); Len := Range_To_Length (Rng, Base_Type); + Cur_Bounds := Bounds; for I in 1 .. Len loop + Bounds := Cur_Bounds; Pos_To_Vstring (Name, Base_Type, Rng, I - 1); if Index = Last_Index then Append (Name, ')'); Handle_Any (El_Rti); else - Handle_Array_1 (Arr_Rti, Bounds, Index + 1); + Handle_Array_1 (Arr_Rti, Index + 1); end if; Truncate (Name, P + 1); end loop; Truncate (Name, P); end Handle_Array_1; - procedure Handle_Array (Rti : Ghdl_Rtin_Type_Array_Acc; - Vals : Ghdl_Uc_Array_Acc) - is - Bounds : Address; - begin - Addr := Vals.Base; - Bounds := Vals.Bounds; - Handle_Array_1 (Rti, Bounds, 0); - end Handle_Array; - procedure Handle_Record (Rti : Ghdl_Rtin_Type_Record_Acc) is El : Ghdl_Rtin_Element_Acc; @@ -324,14 +370,7 @@ package body Grt.Rtis_Utils is Last_Addr := Addr; for I in 1 .. Rti.Nbrel loop El := To_Ghdl_Rtin_Element_Acc (Rti.Elements (I - 1)); - if Is_Sig then - Addr := Obj_Addr + El.Sig_Off; - else - Addr := Obj_Addr + El.Val_Off; - end if; - if Rti_Complex_Type (El.Eltype) then - Addr := Obj_Addr + To_Ghdl_Index_Acc (Addr).all; - end if; + Record_To_Element_Base (Obj_Addr, El, Is_Sig, Addr); Append (Name, '.'); Append (Name, El.Name); Handle_Any (El.Eltype); @@ -354,18 +393,18 @@ package body Grt.Rtis_Utils is | Ghdl_Rtik_Type_B1 => Handle_Scalar (Rti); when Ghdl_Rtik_Type_Array => - Handle_Array (To_Ghdl_Rtin_Type_Array_Acc (Rti), - To_Ghdl_Uc_Array_Acc (Addr)); + Handle_Array_1 (To_Ghdl_Rtin_Type_Array_Acc (Rti), 0); when Ghdl_Rtik_Subtype_Array => declare 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; + Prev_Bounds : constant Address := Bounds; begin Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt); - Handle_Array_1 (Bt, Bounds, 0); + Handle_Array_1 (Bt, 0); + Bounds := Prev_Bounds; end; -- when Ghdl_Rtik_Type_File => -- declare @@ -379,16 +418,24 @@ package body Grt.Rtis_Utils is -- end; when Ghdl_Rtik_Type_Record => Handle_Record (To_Ghdl_Rtin_Type_Record_Acc (Rti)); + 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); + Prev_Bounds : constant Address := Bounds; + begin + Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, Ctxt); + Handle_Record (Bt); + Bounds := Prev_Bounds; + end; when others => Internal_Error ("grt.rtis_utils.foreach_scalar.handle_any"); end case; end Handle_Any; begin - if Rti_Complex_Type (Obj_Type) then - Addr := To_Addr_Acc (Obj_Addr).all; - else - Addr := Obj_Addr; - end if; + Object_To_Base_Bounds (Obj_Type, Obj_Addr, Addr, Bounds); Handle_Any (Obj_Type); Free (Name); end Foreach_Scalar; diff --git a/src/grt/grt-rtis_utils.ads b/src/grt/grt-rtis_utils.ads index eecf390a2..71d9e963b 100644 --- a/src/grt/grt-rtis_utils.ads +++ b/src/grt/grt-rtis_utils.ads @@ -62,6 +62,19 @@ package Grt.Rtis_Utils is Is_Sig : Boolean; Param : Param_Type); + -- Convert object address OBJ_LOC (got from RTIs) to ADDR and BOUNDS. + -- Deals with complex types and fat pointers. + procedure Object_To_Base_Bounds (Obj_Type : Ghdl_Rti_Access; + Obj_Loc : Address; + Addr : out Address; + Bounds : out Address); + + -- Get address of element EL for record at OBJ. + procedure Record_To_Element_Base (Obj : Address; + El : Ghdl_Rtin_Element_Acc; + Is_Sig : Boolean; + Addr : out Address); + procedure Get_Value (Str : in out Vstring; Value : Value_Union; Type_Rti : Ghdl_Rti_Access); diff --git a/src/grt/grt-vcd.adb b/src/grt/grt-vcd.adb index ca0d7c6e5..7a0abde52 100644 --- a/src/grt/grt-vcd.adb +++ b/src/grt/grt-vcd.adb @@ -47,6 +47,7 @@ with Grt.C; use Grt.C; with Grt.Hooks; use Grt.Hooks; with Grt.Rtis; use Grt.Rtis; with Grt.Rtis_Addr; use Grt.Rtis_Addr; +with Grt.Rtis_Utils; use Grt.Rtis_Utils; with Grt.Rtis_Types; use Grt.Rtis_Types; with Grt.Vstrings; with Grt.Wave_Opt; use Grt.Wave_Opt; @@ -325,6 +326,7 @@ package body Grt.Vcd is Rti : Ghdl_Rti_Access; Error : AvhpiErrorT; Sig_Addr : Address; + Bounds : Address; Kind : Vcd_Var_Type; Irange : Ghdl_Range_Ptr; @@ -339,42 +341,46 @@ package body Grt.Vcd is Rti := Avhpi_Get_Rti (Sig_Type); Sig_Addr := Avhpi_Get_Address (Sig); - if Rti_Complex_Type (Rti) then - Sig_Addr := To_Addr_Acc (Sig_Addr).all; - end if; + Object_To_Base_Bounds (Rti, Sig_Addr, Sig_Addr, Bounds); - Kind := Vcd_Bad; - Irange := null; case Rti.Kind is when Ghdl_Rtik_Type_B1 | Ghdl_Rtik_Type_E8 | Ghdl_Rtik_Subtype_Scalar => Kind := Rti_To_Vcd_Kind (Rti); + Irange := null; when Ghdl_Rtik_Subtype_Array => declare St : constant Ghdl_Rtin_Subtype_Composite_Acc := To_Ghdl_Rtin_Subtype_Composite_Acc (Rti); + Arr_Rti : constant Ghdl_Rtin_Type_Array_Acc := + To_Ghdl_Rtin_Type_Array_Acc (St.Basetype); + Idx_Rti : constant Ghdl_Rti_Access := + Get_Base_Type (Arr_Rti.Indexes (0)); begin - Kind := Rti_To_Vcd_Kind (St.Basetype); - Irange := To_Ghdl_Range_Ptr - (Loc_To_Addr (St.Common.Depth, St.Bounds, - Avhpi_Get_Context (Sig))); + Kind := Rti_To_Vcd_Kind (Arr_Rti); + Bounds := Loc_To_Addr (St.Common.Depth, St.Bounds, + Avhpi_Get_Context (Sig)); + Extract_Range (Bounds, Idx_Rti, Irange); end; when Ghdl_Rtik_Type_Array => declare - Uc : Ghdl_Uc_Array_Acc; + Arr_Rti : constant Ghdl_Rtin_Type_Array_Acc := + To_Ghdl_Rtin_Type_Array_Acc (Rti); + Idx_Rti : constant Ghdl_Rti_Access := + Get_Base_Type (Arr_Rti.Indexes (0)); begin - Kind := Rti_To_Vcd_Kind (To_Ghdl_Rtin_Type_Array_Acc (Rti)); - Uc := To_Ghdl_Uc_Array_Acc (Sig_Addr); - Sig_Addr := Uc.Base; - Irange := To_Ghdl_Range_Ptr (Uc.Bounds); + Kind := Rti_To_Vcd_Kind (Arr_Rti); + Extract_Range (Bounds, Idx_Rti, Irange); end; when others => - null; + Kind := Vcd_Bad; end case; -- Do not allow null-array. - if Irange /= null and then Irange.I32.Len = 0 then + if Kind = Vcd_Bad + or else (Irange /= null and then Irange.I32.Len = 0) + then Info := (Vtype => Vcd_Bad, Val => Vcd_Effective, Ptr => Null_Address); return; end if; diff --git a/src/grt/grt-waves.adb b/src/grt/grt-waves.adb index 43ae4ec73..8e2751268 100644 --- a/src/grt/grt-waves.adb +++ b/src/grt/grt-waves.adb @@ -637,9 +637,9 @@ package body Grt.Waves is end; when Ghdl_Rtik_Type_Array => declare - Arr : Ghdl_Rtin_Type_Array_Acc; + Arr : constant Ghdl_Rtin_Type_Array_Acc := + To_Ghdl_Rtin_Type_Array_Acc (Rti); begin - Arr := To_Ghdl_Rtin_Type_Array_Acc (Rti); Create_String_Id (Arr.Name); Create_Type (Arr.Element, N_Ctxt); for I in 1 .. Arr.Nbr_Dim loop @@ -648,9 +648,9 @@ package body Grt.Waves is end; when Ghdl_Rtik_Subtype_Scalar => declare - Sub : Ghdl_Rtin_Subtype_Scalar_Acc; + Sub : constant Ghdl_Rtin_Subtype_Scalar_Acc := + To_Ghdl_Rtin_Subtype_Scalar_Acc (Rti); begin - Sub := To_Ghdl_Rtin_Subtype_Scalar_Acc (Rti); Create_String_Id (Sub.Name); Create_Type (Sub.Basetype, N_Ctxt); end; @@ -690,6 +690,14 @@ package body Grt.Waves is Create_Type (El.Eltype, N_Ctxt); end loop; end; + when Ghdl_Rtik_Subtype_Record => + declare + Rec : constant Ghdl_Rtin_Subtype_Composite_Acc := + To_Ghdl_Rtin_Subtype_Composite_Acc (Rti); + begin + Create_String_Id (Rec.Name); + Create_Type (Rec.Basetype, N_Ctxt); + end; when others => Internal_Error ("wave.create_type"); -- Internal_Error ("wave.create_type: does not handle " & @@ -1200,6 +1208,8 @@ package body Grt.Waves is return Ghw_Rtik_Type_Array; when Ghdl_Rtik_Type_Record => return Ghw_Rtik_Type_Record; + when Ghdl_Rtik_Subtype_Record => + return Ghw_Rtik_Subtype_Record; when Ghdl_Rtik_Subtype_Scalar => return Ghw_Rtik_Subtype_Scalar; when Ghdl_Rtik_Type_I32 => @@ -1302,9 +1312,9 @@ package body Grt.Waves is when Ghdl_Rtik_Type_B1 | Ghdl_Rtik_Type_E8 => declare - Enum : Ghdl_Rtin_Type_Enum_Acc; + Enum : constant Ghdl_Rtin_Type_Enum_Acc := + To_Ghdl_Rtin_Type_Enum_Acc (Rti); begin - Enum := To_Ghdl_Rtin_Type_Enum_Acc (Rti); Write_String_Id (Enum.Name); Wave_Put_ULEB128 (Ghdl_E32 (Enum.Nbr)); for I in 1 .. Enum.Nbr loop @@ -1333,9 +1343,9 @@ package body Grt.Waves is end; when Ghdl_Rtik_Type_Array => declare - Arr : Ghdl_Rtin_Type_Array_Acc; + Arr : constant Ghdl_Rtin_Type_Array_Acc := + To_Ghdl_Rtin_Type_Array_Acc (Rti); begin - Arr := To_Ghdl_Rtin_Type_Array_Acc (Rti); Write_String_Id (Arr.Name); Write_Type_Id (Arr.Element, Ctxt); Wave_Put_ULEB128 (Ghdl_E32 (Arr.Nbr_Dim)); @@ -1345,10 +1355,10 @@ package body Grt.Waves is end; when Ghdl_Rtik_Type_Record => declare - Rec : Ghdl_Rtin_Type_Record_Acc; + Rec : constant Ghdl_Rtin_Type_Record_Acc := + To_Ghdl_Rtin_Type_Record_Acc (Rti); El : Ghdl_Rtin_Element_Acc; begin - Rec := To_Ghdl_Rtin_Type_Record_Acc (Rti); Write_String_Id (Rec.Name); Wave_Put_ULEB128 (Ghdl_E32 (Rec.Nbrel)); for I in 1 .. Rec.Nbrel loop @@ -1357,11 +1367,19 @@ package body Grt.Waves is Write_Type_Id (El.Eltype, Ctxt); end loop; end; + when Ghdl_Rtik_Subtype_Record => + declare + Arr : constant Ghdl_Rtin_Subtype_Composite_Acc := + To_Ghdl_Rtin_Subtype_Composite_Acc (Rti); + begin + Write_String_Id (Arr.Name); + Write_Type_Id (Arr.Basetype, Ctxt); + end; when Ghdl_Rtik_Subtype_Scalar => declare - Sub : Ghdl_Rtin_Subtype_Scalar_Acc; + Sub : constant Ghdl_Rtin_Subtype_Scalar_Acc := + To_Ghdl_Rtin_Subtype_Scalar_Acc (Rti); begin - Sub := To_Ghdl_Rtin_Subtype_Scalar_Acc (Rti); Write_String_Id (Sub.Name); Write_Type_Id (Sub.Basetype, Ctxt); Write_Range @@ -1374,18 +1392,18 @@ package body Grt.Waves is | Ghdl_Rtik_Type_I64 | Ghdl_Rtik_Type_F64 => declare - Base : Ghdl_Rtin_Type_Scalar_Acc; + Base : constant Ghdl_Rtin_Type_Scalar_Acc := + To_Ghdl_Rtin_Type_Scalar_Acc (Rti); begin - Base := To_Ghdl_Rtin_Type_Scalar_Acc (Rti); Write_String_Id (Base.Name); end; when Ghdl_Rtik_Type_P32 | Ghdl_Rtik_Type_P64 => declare - Base : Ghdl_Rtin_Type_Physical_Acc; + Base : constant Ghdl_Rtin_Type_Physical_Acc := + To_Ghdl_Rtin_Type_Physical_Acc (Rti); Unit : Ghdl_Rti_Access; begin - Base := To_Ghdl_Rtin_Type_Physical_Acc (Rti); Write_String_Id (Base.Name); Wave_Put_ULEB128 (Ghdl_U32 (Base.Nbr)); for I in 1 .. Base.Nbr loop |