aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTristan Gingold <tgingold@free.fr>2023-01-30 18:28:22 +0100
committerTristan Gingold <tgingold@free.fr>2023-01-30 18:28:22 +0100
commit87f5a8f7351e1a0ccc1ea40322673434d19582f9 (patch)
tree6a0419d6e70d93cdedd61966b958e50ce1a7b066
parentc16b1428ade6fb56d285767c1e7774454c800e54 (diff)
downloadghdl-87f5a8f7351e1a0ccc1ea40322673434d19582f9.tar.gz
ghdl-87f5a8f7351e1a0ccc1ea40322673434d19582f9.tar.bz2
ghdl-87f5a8f7351e1a0ccc1ea40322673434d19582f9.zip
simul: improve info sig and info time
-rw-r--r--src/simul/simul-vhdl_debug.adb130
1 files changed, 78 insertions, 52 deletions
diff --git a/src/simul/simul-vhdl_debug.adb b/src/simul/simul-vhdl_debug.adb
index d4dde12f7..6ae5976ff 100644
--- a/src/simul/simul-vhdl_debug.adb
+++ b/src/simul/simul-vhdl_debug.adb
@@ -361,6 +361,9 @@ package body Simul.Vhdl_Debug is
type Info_Signal_Options is record
Value : Boolean;
+ Conn : Boolean;
+ Types : Boolean;
+ Sources : Boolean;
Drivers : Boolean;
Actions : Boolean;
end record;
@@ -411,66 +414,75 @@ package body Simul.Vhdl_Debug is
when others =>
raise Internal_Error;
end case;
- New_Line;
- Put (" type: ");
- Debug_Type_Short (S.Typ);
- Put (", len: ");
- Put_Uns32 (S.Typ.W);
+ if Opts.Value = False then
+ Put (" = ");
+ Disp_Memtyp ((S.Typ, S.Val), Get_Type (S.Decl));
+ end if;
New_Line;
- if S.Kind in Mode_Signal_User then
- Nbr_Conn_Drv := 0;
- Conn := S.Connect;
- while Conn /= No_Connect_Index loop
- declare
- C : Connect_Entry renames Connect_Table.Table (Conn);
- begin
- if C.Formal.Base = Idx then
- if C.Drive_Formal then
- Nbr_Conn_Drv := Nbr_Conn_Drv + 1;
- end if;
- Conn := C.Formal_Link;
- else
- pragma Assert (C.Actual.Base = Idx);
- if C.Drive_Actual then
- Nbr_Conn_Drv := Nbr_Conn_Drv + 1;
+ if Opts.Types then
+ Put (" type: ");
+ Debug_Type_Short (S.Typ);
+ Put (", len: ");
+ Put_Uns32 (S.Typ.W);
+ New_Line;
+ end if;
+
+ if Opts.Conn then
+ if S.Kind in Mode_Signal_User then
+ Nbr_Conn_Drv := 0;
+ Conn := S.Connect;
+ while Conn /= No_Connect_Index loop
+ declare
+ C : Connect_Entry renames Connect_Table.Table (Conn);
+ begin
+ if C.Formal.Base = Idx then
+ if C.Drive_Formal then
+ Nbr_Conn_Drv := Nbr_Conn_Drv + 1;
+ end if;
+ Conn := C.Formal_Link;
+ else
+ pragma Assert (C.Actual.Base = Idx);
+ if C.Drive_Actual then
+ Nbr_Conn_Drv := Nbr_Conn_Drv + 1;
+ end if;
+ Conn := C.Actual_Link;
end if;
- Conn := C.Actual_Link;
- end if;
- end;
- end loop;
+ end;
+ end loop;
- Nbr_Drv := 0;
- Driver := S.Drivers;
- while Driver /= No_Driver_Index loop
- Nbr_Drv := Nbr_Drv + 1;
- Driver := Drivers_Table.Table (Driver).Prev_Sig;
- end loop;
- Put (" nbr drivers: ");
- Put_Int32 (Nbr_Drv);
- Put (", nbr conn srcs: ");
- Put_Int32 (Nbr_Conn_Drv);
- Put (", ");
- else
- Put (" ");
- end if;
+ Nbr_Drv := 0;
+ Driver := S.Drivers;
+ while Driver /= No_Driver_Index loop
+ Nbr_Drv := Nbr_Drv + 1;
+ Driver := Drivers_Table.Table (Driver).Prev_Sig;
+ end loop;
+ Put (" nbr drivers: ");
+ Put_Int32 (Nbr_Drv);
+ Put (", nbr conn srcs: ");
+ Put_Int32 (Nbr_Conn_Drv);
+ Put (", ");
+ else
+ Put (" ");
+ end if;
- Nbr_Sens := 0;
- Sens := S.Sensitivity;
- while Sens /= No_Sensitivity_Index loop
- Nbr_Sens := Nbr_Sens + 1;
- Sens := Sensitivity_Table.Table (Sens).Prev_Sig;
- end loop;
+ Nbr_Sens := 0;
+ Sens := S.Sensitivity;
+ while Sens /= No_Sensitivity_Index loop
+ Nbr_Sens := Nbr_Sens + 1;
+ Sens := Sensitivity_Table.Table (Sens).Prev_Sig;
+ end loop;
- Put ("nbr sensitivity: ");
- Put_Int32 (Nbr_Sens);
+ Put ("nbr sensitivity: ");
+ Put_Int32 (Nbr_Sens);
- Put (", collapsed_by: ");
- Put_Uns32 (Uns32 (S.Collapsed_By));
- New_Line;
+ Put (", collapsed_by: ");
+ Put_Uns32 (Uns32 (S.Collapsed_By));
+ New_Line;
+ end if;
- if Boolean'(True) and then S.Kind in Mode_Signal_User then
+ if Opts.Sources and then S.Kind in Mode_Signal_User then
Put (" nbr sources (drv + conn : total):");
New_Line;
for I in 0 .. S.Typ.W - 1 loop
@@ -486,7 +498,7 @@ package body Simul.Vhdl_Debug is
end loop;
end if;
- if Opts.Value then
+ if Opts.Conn then
if S.Kind in Mode_Signal_User then
Driver := S.Drivers;
while Driver /= No_Driver_Index loop
@@ -531,7 +543,9 @@ package body Simul.Vhdl_Debug is
Sens := D.Prev_Sig;
end;
end loop;
+ end if;
+ if Opts.Value then
Put ("value (");
Put_Addr (S.Val.all'Address);
Put ("): ");
@@ -582,6 +596,9 @@ package body Simul.Vhdl_Debug is
Put_Line (" -v disp values");
Put_Line (" -d disp drivers");
Put_Line (" -a disp actions");
+ Put_Line (" -c disp connections");
+ Put_Line (" -t disp types");
+ Put_Line (" -s disp sources");
return;
elsif Line (F .. L) = "-v" then
Opts.Value := True;
@@ -589,6 +606,12 @@ package body Simul.Vhdl_Debug is
Opts.Drivers := True;
elsif Line (F .. L) = "-a" then
Opts.Actions := True;
+ elsif Line (F .. L) = "-c" then
+ Opts.Conn := True;
+ elsif Line (F .. L) = "-s" then
+ Opts.Sources := True;
+ elsif Line (F .. L) = "-t" then
+ Opts.Types := True;
elsif Line (F) in '0' .. '9' then
To_Num (Line (F .. L), Idx, Valid);
if not Valid
@@ -748,6 +771,9 @@ package body Simul.Vhdl_Debug is
Put_Fp64 (Fp64 (Current_Time_AMS));
end if;
New_Line;
+ Put ("delta: ");
+ Put_Uns32 (Uns32 (Current_Delta));
+ New_Line;
Put ("next time: ");
Put_Time (Grt.Processes.Next_Time);
New_Line;