diff options
Diffstat (limited to 'translate/grt')
-rw-r--r-- | translate/grt/grt-signals.adb | 76 | ||||
-rw-r--r-- | translate/grt/grt-signals.ads | 45 | ||||
-rw-r--r-- | translate/grt/grt-types.ads | 1 |
3 files changed, 86 insertions, 36 deletions
diff --git a/translate/grt/grt-signals.adb b/translate/grt/grt-signals.adb index 4443bd9..dfcda96 100644 --- a/translate/grt/grt-signals.adb +++ b/translate/grt/grt-signals.adb @@ -48,25 +48,26 @@ package body Grt.Signals is end Free_In; pragma Inline (Free_In); - function Is_Signal_Guarded (Sig : Ghdl_Signal_Ptr) return Boolean - is - begin - return (Sig.Rti.Common.Mode and Ghdl_Rti_Signal_Kind_Mask) - /= Ghdl_Rti_Signal_Kind_No; - end Is_Signal_Guarded; - + -- RTI for the current signal. Sig_Rti : Ghdl_Rtin_Object_Acc; + + -- Signal mode (and flags) for the current signal. + Sig_Mode : Mode_Signal_Type; + Sig_Has_Active : Boolean; + Sig_Kind : Kind_Signal_Type; + + -- Last created implicit signal. This is used to add dependencies on + -- the prefix. Last_Implicit_Signal : Ghdl_Signal_Ptr; + + -- Current signal resolver. Current_Resolv : Resolved_Signal_Acc := null; - function Get_Current_Mode_Signal return Mode_Signal_Type - is + function Get_Current_Mode_Signal return Mode_Signal_Type is begin - return Mode_Signal_Type'Val - (Sig_Rti.Common.Mode and Ghdl_Rti_Signal_Mode_Mask); + return Sig_Mode; end Get_Current_Mode_Signal; - procedure Ghdl_Signal_Name_Rti (Sig : Ghdl_Rti_Access; Ctxt : Ghdl_Rti_Access; Addr : Address) @@ -75,8 +76,30 @@ package body Grt.Signals is pragma Unreferenced (Addr); begin Sig_Rti := To_Ghdl_Rtin_Object_Acc (Sig); + Sig_Mode := Mode_Signal_Type'Val + (Sig.Mode and Ghdl_Rti_Signal_Mode_Mask); + Sig_Kind := Kind_Signal_Type'Val + ((Sig.Mode and Ghdl_Rti_Signal_Kind_Mask) + / Ghdl_Rti_Signal_Kind_Offset); + Sig_Has_Active := + (Sig_Rti.Common.Mode and Ghdl_Rti_Signal_Has_Active) /= 0; end Ghdl_Signal_Name_Rti; + procedure Ghdl_Signal_Set_Mode (Mode : Mode_Signal_Type; + Kind : Kind_Signal_Type; + Has_Active : Boolean) is + begin + Sig_Rti := null; + Sig_Mode := Mode; + Sig_Kind := Kind; + Sig_Has_Active := Has_Active; + end Ghdl_Signal_Set_Mode; + + function Is_Signal_Guarded (Sig : Ghdl_Signal_Ptr) return Boolean is + begin + return Sig.Sig_Kind /= Kind_Signal_No; + end Is_Signal_Guarded; + function To_Address is new Ada.Unchecked_Conversion (Source => Ghdl_Signal_Ptr, Target => Address); @@ -148,6 +171,7 @@ package body Grt.Signals is Event => False, Active => False, Has_Active => False, + Sig_Kind => Sig_Kind, Mode => Mode, Flags => (Propag => Propag_None, @@ -176,9 +200,7 @@ package body Grt.Signals is when Activity_All => Res.Has_Active := True; when Activity_Minimal => - if (Sig_Rti.Common.Mode and Ghdl_Rti_Signal_Has_Active) /= 0 then - Res.Has_Active := True; - end if; + Res.Has_Active := Sig_Has_Active; when Activity_None => Res.Has_Active := False; end case; @@ -237,11 +259,12 @@ package body Grt.Signals is -- LRM 4.3.1.2 Signal Declaration -- It is an error if, after the elaboration of a description, a -- signal has multiple sources and it is not a resolved signal. - Put ("for signal: "); - Disp_Signals.Put_Signal_Name (stderr, Sig); - New_Line (stderr); + if Sig.Rti /= null then + Put ("for signal: "); + Disp_Signals.Put_Signal_Name (stderr, Sig); + New_Line (stderr); + end if; Error ("several sources for unresolved signal"); - -- FIXME: display signal name. elsif Sig.S.Mode_Sig = Mode_Buffer and False then -- LRM 1.1.1.2 Ports -- A BUFFER port may have at most one source. @@ -1359,7 +1382,7 @@ package body Grt.Signals is Res := Create_Signal (Mode_B2, Value_Union'(Mode => Mode_B2, B2 => True), Mode, null, Null_Address); - + Sig_Rti := null; Last_Implicit_Signal := Res; if Mode /= Mode_Transaction then @@ -1429,6 +1452,7 @@ package body Grt.Signals is Res := Create_Signal (Mode_B2, Value_Union'(Mode => Mode_B2, B2 => Proc.all (This)), Mode_Guard, null, Null_Address); + Sig_Rti := null; Res.S.Guard_Func := Proc; Res.S.Guard_Instance := This; Last_Implicit_Signal := Res; @@ -1812,9 +1836,9 @@ package body Grt.Signals is end loop; -- if no driving sources and register, exit. - if Length = 0 and then Sig.Nbr_Ports = 0 - and then ((Sig.Rti.Common.Mode and Ghdl_Rti_Signal_Kind_Mask) - = Ghdl_Rti_Signal_Kind_Register) + if Length = 0 + and then Sig.Nbr_Ports = 0 + and then Sig.Sig_Kind = Kind_Signal_Register then return; end if; @@ -1828,11 +1852,6 @@ package body Grt.Signals is Sig.Nbr_Ports); end Compute_Resolved_Signal; - type Conversion_Func_Acc is access procedure (Instance : System.Address); - pragma Convention (C, Conversion_Func_Acc); - function To_Conversion_Func_Acc is new Ada.Unchecked_Conversion - (Source => System.Address, Target => Conversion_Func_Acc); - procedure Call_Conversion_Function (Conv : Sig_Conversion_Acc) is F : Conversion_Func_Acc; @@ -3305,6 +3324,7 @@ package body Grt.Signals is Event => False, Active => False, Has_Active => False, + Sig_Kind => Kind_Signal_No, Mode => Mode_B2, Flags => (Propag => Propag_None, diff --git a/translate/grt/grt-signals.ads b/translate/grt/grt-signals.ads index 76595c7..eac47a7 100644 --- a/translate/grt/grt-signals.ads +++ b/translate/grt/grt-signals.ads @@ -166,6 +166,12 @@ package Grt.Signals is type Resolved_Signal_Acc is access Resolved_Signal_Type; + type Conversion_Func_Acc is access procedure (Instance : System.Address); + pragma Convention (C, Conversion_Func_Acc); + + function To_Conversion_Func_Acc is new Ada.Unchecked_Conversion + (Source => System.Address, Target => Conversion_Func_Acc); + -- Signal conversion data. type Sig_Conversion_Type is record -- Function which performs the conversion. @@ -287,6 +293,11 @@ package Grt.Signals is Has_Active : Boolean; -- Internal fields. + -- NOTE: keep above fields (components) in sync with translation. + + -- Kind of the signal (none, bus or register). + Sig_Kind : Kind_Signal_Type; + -- Values mode of this signal. Mode : Mode_Type; @@ -468,16 +479,25 @@ package Grt.Signals is (Sig : Ghdl_Signal_Ptr; Proc : Process_Acc); -- Creating a signal: - -- 1) call Ghdl_Signal_Name_Rti (CTXT and ADDR are unused) to register - -- the RTI for the whole signal (in particular the mode and the - -- has_active flag) + -- 1a) call Ghdl_Signal_Name_Rti (CTXT and ADDR are unused) to register + -- the RTI for the whole signal (in particular the mode and the + -- has_active flag) + -- or + -- 1b) call Ghdl_Signal_Set_Mode to register the mode and the has_active + -- flag. In that case, the signal has no name. + -- -- 2) call Ghdl_Create_Signal_XXX for each non-composite element procedure Ghdl_Signal_Name_Rti (Sig : Ghdl_Rti_Access; Ctxt : Ghdl_Rti_Access; Addr : System.Address); + procedure Ghdl_Signal_Set_Mode (Mode : Mode_Signal_Type; + Kind : Kind_Signal_Type; + Has_Active : Boolean); + -- FIXME: document. + -- Merge RTI with SIG: adjust the has_active flag of SIG according to RTI. procedure Ghdl_Signal_Merge_Rti (Sig : Ghdl_Signal_Ptr; Rti : Ghdl_Rti_Access); @@ -641,13 +661,28 @@ package Grt.Signals is procedure Ghdl_Signal_Add_Source (Targ : Ghdl_Signal_Ptr; Src : Ghdl_Signal_Ptr); + -- The effective value of TARG is the effective value of SRC. + procedure Ghdl_Signal_Effective_Value (Targ : Ghdl_Signal_Ptr; + Src : Ghdl_Signal_Ptr); + + -- Conversions. In order to do conversion from A to B, an intermediate + -- signal T must be created. The flow is A -> T -> B. + -- The link from A -> T is a conversion, added by one of the two + -- following procedures. The type of A and T is different. + -- The link from T -> B is a normal connection: either an effective + -- one (for in conversion) or a source (for out conversion). + -- Add an in conversion (from SRC to DEST using function FUNC). + -- The effective value can be read and writen directly. procedure Ghdl_Signal_In_Conversion (Func : System.Address; Instance : System.Address; Src : Ghdl_Signal_Ptr; Src_Len : Ghdl_Index_Type; Dst : Ghdl_Signal_Ptr; Dst_Len : Ghdl_Index_Type); + + -- Add an out conversion. + -- The driving value can be read and writen directly. procedure Ghdl_Signal_Out_Conversion (Func : System.Address; Instance : System.Address; Src : Ghdl_Signal_Ptr; @@ -661,10 +696,6 @@ package Grt.Signals is Sig : System.Address; Nbr_Sig : Ghdl_Index_Type); - -- The effective value of TARG is the effective value of SRC. - procedure Ghdl_Signal_Effective_Value (Targ : Ghdl_Signal_Ptr; - Src : Ghdl_Signal_Ptr); - -- Create a new 'stable (VAL) signal. The prefixes are set by -- ghdl_signal_attribute_register_prefix. function Ghdl_Create_Stable_Signal (Val : Std_Time) return Ghdl_Signal_Ptr; diff --git a/translate/grt/grt-types.ads b/translate/grt/grt-types.ads index 1b6db8d..acefe33 100644 --- a/translate/grt/grt-types.ads +++ b/translate/grt/grt-types.ads @@ -277,7 +277,6 @@ package Grt.Types is -- Kind of a signal. type Kind_Signal_Type is (Kind_Signal_No, Kind_Signal_Register, Kind_Signal_Bus); - pragma Convention (C, Kind_Signal_Type); -- Note: we could use system.storage_elements, but unfortunatly, -- this doesn't work with pragma no_run_time (gnat 3.15p). |