annotate gcc/ada/libgnarl/s-tasdeb.adb @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ------------------------------------------------------------------------------
kono
parents:
diff changeset
2 -- --
kono
parents:
diff changeset
3 -- GNAT RUN-TIME LIBRARY (GNARL) COMPONENTS --
kono
parents:
diff changeset
4 -- --
kono
parents:
diff changeset
5 -- S Y S T E M . T A S K I N G . D E B U G --
kono
parents:
diff changeset
6 -- --
kono
parents:
diff changeset
7 -- B o d y --
kono
parents:
diff changeset
8 -- --
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
9 -- Copyright (C) 1997-2019, Free Software Foundation, Inc. --
111
kono
parents:
diff changeset
10 -- --
kono
parents:
diff changeset
11 -- GNARL is free software; you can redistribute it and/or modify it under --
kono
parents:
diff changeset
12 -- terms of the GNU General Public License as published by the Free Soft- --
kono
parents:
diff changeset
13 -- ware Foundation; either version 3, or (at your option) any later ver- --
kono
parents:
diff changeset
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
kono
parents:
diff changeset
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
kono
parents:
diff changeset
16 -- or FITNESS FOR A PARTICULAR PURPOSE. --
kono
parents:
diff changeset
17 -- --
kono
parents:
diff changeset
18 -- As a special exception under Section 7 of GPL version 3, you are granted --
kono
parents:
diff changeset
19 -- additional permissions described in the GCC Runtime Library Exception, --
kono
parents:
diff changeset
20 -- version 3.1, as published by the Free Software Foundation. --
kono
parents:
diff changeset
21 -- --
kono
parents:
diff changeset
22 -- You should have received a copy of the GNU General Public License and --
kono
parents:
diff changeset
23 -- a copy of the GCC Runtime Library Exception along with this program; --
kono
parents:
diff changeset
24 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
kono
parents:
diff changeset
25 -- <http://www.gnu.org/licenses/>. --
kono
parents:
diff changeset
26 -- --
kono
parents:
diff changeset
27 -- GNARL was developed by the GNARL team at Florida State University. --
kono
parents:
diff changeset
28 -- Extensive contributions were provided by Ada Core Technologies, Inc. --
kono
parents:
diff changeset
29 -- --
kono
parents:
diff changeset
30 ------------------------------------------------------------------------------
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 -- This package encapsulates all direct interfaces to task debugging services
kono
parents:
diff changeset
33 -- that are needed by gdb with gnat mode.
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 -- Note : This file *must* be compiled with debugging information
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 -- Do not add any dependency to GNARL packages since this package is used
kono
parents:
diff changeset
38 -- in both normal and restricted (ravenscar) environments.
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 pragma Restriction_Warnings (No_Secondary_Stack);
kono
parents:
diff changeset
41 -- We wish to avoid secondary stack usage here, because (e.g.) Trace is called
kono
parents:
diff changeset
42 -- at delicate times, such as during task termination after the secondary
kono
parents:
diff changeset
43 -- stack has been deallocated. It's just a warning, so we don't require
kono
parents:
diff changeset
44 -- partition-wide consistency.
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 with System.CRTL;
kono
parents:
diff changeset
47 with System.Storage_Elements; use System.Storage_Elements;
kono
parents:
diff changeset
48 with System.Task_Primitives;
kono
parents:
diff changeset
49 with System.Task_Primitives.Operations;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 package body System.Tasking.Debug is
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 package STPO renames System.Task_Primitives.Operations;
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 type Trace_Flag_Set is array (Character) of Boolean;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 Trace_On : Trace_Flag_Set := ('A' .. 'Z' => False, others => True);
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 Stderr_Fd : constant := 2;
kono
parents:
diff changeset
60 -- File descriptor for standard error
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 -----------------------
kono
parents:
diff changeset
63 -- Local Subprograms --
kono
parents:
diff changeset
64 -----------------------
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 procedure Write (Fd : Integer; S : String; Count : Integer);
kono
parents:
diff changeset
67 -- Write Count characters of S to the file descriptor Fd
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 procedure Put (S : String);
kono
parents:
diff changeset
70 -- Display S on standard error
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 procedure Put_Line (S : String := "");
kono
parents:
diff changeset
73 -- Display S on standard error with an additional line terminator
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 procedure Put_Task_Image (T : Task_Id);
kono
parents:
diff changeset
76 -- Display relevant characters from T.Common.Task_Image on standard error
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 procedure Put_Task_Id_Image (T : Task_Id);
kono
parents:
diff changeset
79 -- Display address in hexadecimal form on standard error
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 ------------------------
kono
parents:
diff changeset
82 -- Continue_All_Tasks --
kono
parents:
diff changeset
83 ------------------------
kono
parents:
diff changeset
84
kono
parents:
diff changeset
85 procedure Continue_All_Tasks is
kono
parents:
diff changeset
86 C : Task_Id;
kono
parents:
diff changeset
87 Dummy : Boolean;
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 begin
kono
parents:
diff changeset
90 STPO.Lock_RTS;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 C := All_Tasks_List;
kono
parents:
diff changeset
93 while C /= null loop
kono
parents:
diff changeset
94 Dummy := STPO.Continue_Task (C);
kono
parents:
diff changeset
95 C := C.Common.All_Tasks_Link;
kono
parents:
diff changeset
96 end loop;
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 STPO.Unlock_RTS;
kono
parents:
diff changeset
99 end Continue_All_Tasks;
kono
parents:
diff changeset
100
kono
parents:
diff changeset
101 --------------------
kono
parents:
diff changeset
102 -- Get_User_State --
kono
parents:
diff changeset
103 --------------------
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 function Get_User_State return Long_Integer is
kono
parents:
diff changeset
106 begin
kono
parents:
diff changeset
107 return STPO.Self.User_State;
kono
parents:
diff changeset
108 end Get_User_State;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 ----------------
kono
parents:
diff changeset
111 -- List_Tasks --
kono
parents:
diff changeset
112 ----------------
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 procedure List_Tasks is
kono
parents:
diff changeset
115 C : Task_Id;
kono
parents:
diff changeset
116 begin
kono
parents:
diff changeset
117 C := All_Tasks_List;
kono
parents:
diff changeset
118 while C /= null loop
kono
parents:
diff changeset
119 Print_Task_Info (C);
kono
parents:
diff changeset
120 C := C.Common.All_Tasks_Link;
kono
parents:
diff changeset
121 end loop;
kono
parents:
diff changeset
122 end List_Tasks;
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 ------------------------
kono
parents:
diff changeset
125 -- Print_Current_Task --
kono
parents:
diff changeset
126 ------------------------
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 procedure Print_Current_Task is
kono
parents:
diff changeset
129 begin
kono
parents:
diff changeset
130 Print_Task_Info (STPO.Self);
kono
parents:
diff changeset
131 end Print_Current_Task;
kono
parents:
diff changeset
132
kono
parents:
diff changeset
133 ---------------------
kono
parents:
diff changeset
134 -- Print_Task_Info --
kono
parents:
diff changeset
135 ---------------------
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 procedure Print_Task_Info (T : Task_Id) is
kono
parents:
diff changeset
138 Entry_Call : Entry_Call_Link;
kono
parents:
diff changeset
139 Parent : Task_Id;
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 begin
kono
parents:
diff changeset
142 if T = null then
kono
parents:
diff changeset
143 Put_Line ("null task");
kono
parents:
diff changeset
144 return;
kono
parents:
diff changeset
145 end if;
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 Put_Task_Image (T);
kono
parents:
diff changeset
148 Put (": " & Task_States'Image (T.Common.State));
kono
parents:
diff changeset
149 Parent := T.Common.Parent;
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 if Parent = null then
kono
parents:
diff changeset
152 Put (", parent: <none>");
kono
parents:
diff changeset
153 else
kono
parents:
diff changeset
154 Put (", parent: ");
kono
parents:
diff changeset
155 Put_Task_Image (Parent);
kono
parents:
diff changeset
156 end if;
kono
parents:
diff changeset
157
kono
parents:
diff changeset
158 Put (", prio:" & T.Common.Current_Priority'Img);
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 if not T.Callable then
kono
parents:
diff changeset
161 Put (", not callable");
kono
parents:
diff changeset
162 end if;
kono
parents:
diff changeset
163
kono
parents:
diff changeset
164 if T.Aborting then
kono
parents:
diff changeset
165 Put (", aborting");
kono
parents:
diff changeset
166 end if;
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 if T.Deferral_Level /= 0 then
kono
parents:
diff changeset
169 Put (", abort deferred");
kono
parents:
diff changeset
170 end if;
kono
parents:
diff changeset
171
kono
parents:
diff changeset
172 if T.Common.Call /= null then
kono
parents:
diff changeset
173 Entry_Call := T.Common.Call;
kono
parents:
diff changeset
174 Put (", serving:");
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 while Entry_Call /= null loop
kono
parents:
diff changeset
177 Put_Task_Id_Image (Entry_Call.Self);
kono
parents:
diff changeset
178 Entry_Call := Entry_Call.Acceptor_Prev_Call;
kono
parents:
diff changeset
179 end loop;
kono
parents:
diff changeset
180 end if;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 if T.Open_Accepts /= null then
kono
parents:
diff changeset
183 Put (", accepting:");
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 for J in T.Open_Accepts'Range loop
kono
parents:
diff changeset
186 Put (T.Open_Accepts (J).S'Img);
kono
parents:
diff changeset
187 end loop;
kono
parents:
diff changeset
188
kono
parents:
diff changeset
189 if T.Terminate_Alternative then
kono
parents:
diff changeset
190 Put (" or terminate");
kono
parents:
diff changeset
191 end if;
kono
parents:
diff changeset
192 end if;
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 if T.User_State /= 0 then
kono
parents:
diff changeset
195 Put (", state:" & T.User_State'Img);
kono
parents:
diff changeset
196 end if;
kono
parents:
diff changeset
197
kono
parents:
diff changeset
198 Put_Line;
kono
parents:
diff changeset
199 end Print_Task_Info;
kono
parents:
diff changeset
200
kono
parents:
diff changeset
201 ---------
kono
parents:
diff changeset
202 -- Put --
kono
parents:
diff changeset
203 ---------
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 procedure Put (S : String) is
kono
parents:
diff changeset
206 begin
kono
parents:
diff changeset
207 Write (Stderr_Fd, S, S'Length);
kono
parents:
diff changeset
208 end Put;
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 --------------
kono
parents:
diff changeset
211 -- Put_Line --
kono
parents:
diff changeset
212 --------------
kono
parents:
diff changeset
213
kono
parents:
diff changeset
214 procedure Put_Line (S : String := "") is
kono
parents:
diff changeset
215 begin
kono
parents:
diff changeset
216 Write (Stderr_Fd, S & ASCII.LF, S'Length + 1);
kono
parents:
diff changeset
217 end Put_Line;
kono
parents:
diff changeset
218
kono
parents:
diff changeset
219 -----------------------
kono
parents:
diff changeset
220 -- Put_Task_Id_Image --
kono
parents:
diff changeset
221 -----------------------
kono
parents:
diff changeset
222
kono
parents:
diff changeset
223 procedure Put_Task_Id_Image (T : Task_Id) is
kono
parents:
diff changeset
224 Address_Image_Length : constant :=
kono
parents:
diff changeset
225 13 + (if Standard'Address_Size = 64 then 10 else 0);
kono
parents:
diff changeset
226 -- Length of string to be printed for address of task
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 H : constant array (0 .. 15) of Character := "0123456789ABCDEF";
kono
parents:
diff changeset
229 -- Table of hex digits
kono
parents:
diff changeset
230
kono
parents:
diff changeset
231 S : String (1 .. Address_Image_Length);
kono
parents:
diff changeset
232 P : Natural;
kono
parents:
diff changeset
233 N : Integer_Address;
kono
parents:
diff changeset
234 U : Natural := 0;
kono
parents:
diff changeset
235
kono
parents:
diff changeset
236 begin
kono
parents:
diff changeset
237 if T = null then
kono
parents:
diff changeset
238 Put ("Null_Task_Id");
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 else
kono
parents:
diff changeset
241 S (S'Last) := '#';
kono
parents:
diff changeset
242 P := Address_Image_Length - 1;
kono
parents:
diff changeset
243 N := To_Integer (T.all'Address);
kono
parents:
diff changeset
244 while P > 3 loop
kono
parents:
diff changeset
245 if U = 4 then
kono
parents:
diff changeset
246 S (P) := '_';
kono
parents:
diff changeset
247 P := P - 1;
kono
parents:
diff changeset
248 U := 1;
kono
parents:
diff changeset
249 else
kono
parents:
diff changeset
250 U := U + 1;
kono
parents:
diff changeset
251 end if;
kono
parents:
diff changeset
252
kono
parents:
diff changeset
253 S (P) := H (Integer (N mod 16));
kono
parents:
diff changeset
254 P := P - 1;
kono
parents:
diff changeset
255 N := N / 16;
kono
parents:
diff changeset
256 end loop;
kono
parents:
diff changeset
257
kono
parents:
diff changeset
258 S (1 .. 3) := "16#";
kono
parents:
diff changeset
259 Put (S);
kono
parents:
diff changeset
260 end if;
kono
parents:
diff changeset
261 end Put_Task_Id_Image;
kono
parents:
diff changeset
262
kono
parents:
diff changeset
263 --------------------
kono
parents:
diff changeset
264 -- Put_Task_Image --
kono
parents:
diff changeset
265 --------------------
kono
parents:
diff changeset
266
kono
parents:
diff changeset
267 procedure Put_Task_Image (T : Task_Id) is
kono
parents:
diff changeset
268 begin
kono
parents:
diff changeset
269 -- In case T.Common.Task_Image_Len is uninitialized junk, we check that
kono
parents:
diff changeset
270 -- it is in range, to make this more robust.
kono
parents:
diff changeset
271
kono
parents:
diff changeset
272 if T.Common.Task_Image_Len in T.Common.Task_Image'Range then
kono
parents:
diff changeset
273 Put (T.Common.Task_Image (1 .. T.Common.Task_Image_Len));
kono
parents:
diff changeset
274 else
kono
parents:
diff changeset
275 Put (T.Common.Task_Image);
kono
parents:
diff changeset
276 end if;
kono
parents:
diff changeset
277 end Put_Task_Image;
kono
parents:
diff changeset
278
kono
parents:
diff changeset
279 ----------------------
kono
parents:
diff changeset
280 -- Resume_All_Tasks --
kono
parents:
diff changeset
281 ----------------------
kono
parents:
diff changeset
282
kono
parents:
diff changeset
283 procedure Resume_All_Tasks (Thread_Self : OS_Interface.Thread_Id) is
kono
parents:
diff changeset
284 C : Task_Id;
kono
parents:
diff changeset
285 Dummy : Boolean;
kono
parents:
diff changeset
286
kono
parents:
diff changeset
287 begin
kono
parents:
diff changeset
288 STPO.Lock_RTS;
kono
parents:
diff changeset
289
kono
parents:
diff changeset
290 C := All_Tasks_List;
kono
parents:
diff changeset
291 while C /= null loop
kono
parents:
diff changeset
292 Dummy := STPO.Resume_Task (C, Thread_Self);
kono
parents:
diff changeset
293 C := C.Common.All_Tasks_Link;
kono
parents:
diff changeset
294 end loop;
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 STPO.Unlock_RTS;
kono
parents:
diff changeset
297 end Resume_All_Tasks;
kono
parents:
diff changeset
298
kono
parents:
diff changeset
299 ---------------
kono
parents:
diff changeset
300 -- Set_Trace --
kono
parents:
diff changeset
301 ---------------
kono
parents:
diff changeset
302
kono
parents:
diff changeset
303 procedure Set_Trace (Flag : Character; Value : Boolean := True) is
kono
parents:
diff changeset
304 begin
kono
parents:
diff changeset
305 Trace_On (Flag) := Value;
kono
parents:
diff changeset
306 end Set_Trace;
kono
parents:
diff changeset
307
kono
parents:
diff changeset
308 --------------------
kono
parents:
diff changeset
309 -- Set_User_State --
kono
parents:
diff changeset
310 --------------------
kono
parents:
diff changeset
311
kono
parents:
diff changeset
312 procedure Set_User_State (Value : Long_Integer) is
kono
parents:
diff changeset
313 begin
kono
parents:
diff changeset
314 STPO.Self.User_State := Value;
kono
parents:
diff changeset
315 end Set_User_State;
kono
parents:
diff changeset
316
kono
parents:
diff changeset
317 ------------------------
kono
parents:
diff changeset
318 -- Signal_Debug_Event --
kono
parents:
diff changeset
319 ------------------------
kono
parents:
diff changeset
320
kono
parents:
diff changeset
321 procedure Signal_Debug_Event
kono
parents:
diff changeset
322 (Event_Kind : Event_Kind_Type;
kono
parents:
diff changeset
323 Task_Value : Task_Id)
kono
parents:
diff changeset
324 is
kono
parents:
diff changeset
325 begin
kono
parents:
diff changeset
326 null;
kono
parents:
diff changeset
327 end Signal_Debug_Event;
kono
parents:
diff changeset
328
kono
parents:
diff changeset
329 --------------------
kono
parents:
diff changeset
330 -- Stop_All_Tasks --
kono
parents:
diff changeset
331 --------------------
kono
parents:
diff changeset
332
kono
parents:
diff changeset
333 procedure Stop_All_Tasks is
kono
parents:
diff changeset
334 C : Task_Id;
kono
parents:
diff changeset
335 Dummy : Boolean;
kono
parents:
diff changeset
336
kono
parents:
diff changeset
337 begin
kono
parents:
diff changeset
338 STPO.Lock_RTS;
kono
parents:
diff changeset
339
kono
parents:
diff changeset
340 C := All_Tasks_List;
kono
parents:
diff changeset
341 while C /= null loop
kono
parents:
diff changeset
342 Dummy := STPO.Stop_Task (C);
kono
parents:
diff changeset
343 C := C.Common.All_Tasks_Link;
kono
parents:
diff changeset
344 end loop;
kono
parents:
diff changeset
345
kono
parents:
diff changeset
346 STPO.Unlock_RTS;
kono
parents:
diff changeset
347 end Stop_All_Tasks;
kono
parents:
diff changeset
348
kono
parents:
diff changeset
349 ----------------------------
kono
parents:
diff changeset
350 -- Stop_All_Tasks_Handler --
kono
parents:
diff changeset
351 ----------------------------
kono
parents:
diff changeset
352
kono
parents:
diff changeset
353 procedure Stop_All_Tasks_Handler is
kono
parents:
diff changeset
354 begin
kono
parents:
diff changeset
355 STPO.Stop_All_Tasks;
kono
parents:
diff changeset
356 end Stop_All_Tasks_Handler;
kono
parents:
diff changeset
357
kono
parents:
diff changeset
358 -----------------------
kono
parents:
diff changeset
359 -- Suspend_All_Tasks --
kono
parents:
diff changeset
360 -----------------------
kono
parents:
diff changeset
361
kono
parents:
diff changeset
362 procedure Suspend_All_Tasks (Thread_Self : OS_Interface.Thread_Id) is
kono
parents:
diff changeset
363 C : Task_Id;
kono
parents:
diff changeset
364 Dummy : Boolean;
kono
parents:
diff changeset
365
kono
parents:
diff changeset
366 begin
kono
parents:
diff changeset
367 STPO.Lock_RTS;
kono
parents:
diff changeset
368
kono
parents:
diff changeset
369 C := All_Tasks_List;
kono
parents:
diff changeset
370 while C /= null loop
kono
parents:
diff changeset
371 Dummy := STPO.Suspend_Task (C, Thread_Self);
kono
parents:
diff changeset
372 C := C.Common.All_Tasks_Link;
kono
parents:
diff changeset
373 end loop;
kono
parents:
diff changeset
374
kono
parents:
diff changeset
375 STPO.Unlock_RTS;
kono
parents:
diff changeset
376 end Suspend_All_Tasks;
kono
parents:
diff changeset
377
kono
parents:
diff changeset
378 ------------------------
kono
parents:
diff changeset
379 -- Task_Creation_Hook --
kono
parents:
diff changeset
380 ------------------------
kono
parents:
diff changeset
381
kono
parents:
diff changeset
382 procedure Task_Creation_Hook (Thread : OS_Interface.Thread_Id) is
kono
parents:
diff changeset
383 pragma Inspection_Point (Thread);
kono
parents:
diff changeset
384 -- gdb needs to access the thread parameter in order to implement
kono
parents:
diff changeset
385 -- the multitask mode under VxWorks.
kono
parents:
diff changeset
386
kono
parents:
diff changeset
387 begin
kono
parents:
diff changeset
388 null;
kono
parents:
diff changeset
389 end Task_Creation_Hook;
kono
parents:
diff changeset
390
kono
parents:
diff changeset
391 ---------------------------
kono
parents:
diff changeset
392 -- Task_Termination_Hook --
kono
parents:
diff changeset
393 ---------------------------
kono
parents:
diff changeset
394
kono
parents:
diff changeset
395 procedure Task_Termination_Hook is
kono
parents:
diff changeset
396 begin
kono
parents:
diff changeset
397 null;
kono
parents:
diff changeset
398 end Task_Termination_Hook;
kono
parents:
diff changeset
399
kono
parents:
diff changeset
400 -----------
kono
parents:
diff changeset
401 -- Trace --
kono
parents:
diff changeset
402 -----------
kono
parents:
diff changeset
403
kono
parents:
diff changeset
404 procedure Trace
kono
parents:
diff changeset
405 (Self_Id : Task_Id;
kono
parents:
diff changeset
406 Msg : String;
kono
parents:
diff changeset
407 Flag : Character;
kono
parents:
diff changeset
408 Other_Id : Task_Id := null)
kono
parents:
diff changeset
409 is
kono
parents:
diff changeset
410 begin
kono
parents:
diff changeset
411 if Trace_On (Flag) then
kono
parents:
diff changeset
412 Put_Task_Id_Image (Self_Id);
kono
parents:
diff changeset
413 Put (":" & Flag & ":");
kono
parents:
diff changeset
414 Put_Task_Image (Self_Id);
kono
parents:
diff changeset
415 Put (":");
kono
parents:
diff changeset
416
kono
parents:
diff changeset
417 if Other_Id /= null then
kono
parents:
diff changeset
418 Put_Task_Id_Image (Other_Id);
kono
parents:
diff changeset
419 Put (":");
kono
parents:
diff changeset
420 end if;
kono
parents:
diff changeset
421
kono
parents:
diff changeset
422 Put_Line (Msg);
kono
parents:
diff changeset
423 end if;
kono
parents:
diff changeset
424 end Trace;
kono
parents:
diff changeset
425
kono
parents:
diff changeset
426 -----------
kono
parents:
diff changeset
427 -- Write --
kono
parents:
diff changeset
428 -----------
kono
parents:
diff changeset
429
kono
parents:
diff changeset
430 procedure Write (Fd : Integer; S : String; Count : Integer) is
kono
parents:
diff changeset
431 Discard : System.CRTL.ssize_t;
kono
parents:
diff changeset
432 -- Ignore write errors here; this is just debugging output, and there's
kono
parents:
diff changeset
433 -- nothing to be done about errors anyway.
kono
parents:
diff changeset
434 begin
kono
parents:
diff changeset
435 Discard :=
kono
parents:
diff changeset
436 System.CRTL.write
kono
parents:
diff changeset
437 (Fd, S'Address, System.CRTL.size_t (Count));
kono
parents:
diff changeset
438 end Write;
kono
parents:
diff changeset
439
kono
parents:
diff changeset
440 -----------------
kono
parents:
diff changeset
441 -- Master_Hook --
kono
parents:
diff changeset
442 -----------------
kono
parents:
diff changeset
443
kono
parents:
diff changeset
444 procedure Master_Hook
kono
parents:
diff changeset
445 (Dependent : Task_Id;
kono
parents:
diff changeset
446 Parent : Task_Id;
kono
parents:
diff changeset
447 Master_Level : Integer)
kono
parents:
diff changeset
448 is
kono
parents:
diff changeset
449 pragma Inspection_Point (Dependent);
kono
parents:
diff changeset
450 pragma Inspection_Point (Parent);
kono
parents:
diff changeset
451 pragma Inspection_Point (Master_Level);
kono
parents:
diff changeset
452 begin
kono
parents:
diff changeset
453 null;
kono
parents:
diff changeset
454 end Master_Hook;
kono
parents:
diff changeset
455
kono
parents:
diff changeset
456 ---------------------------
kono
parents:
diff changeset
457 -- Master_Completed_Hook --
kono
parents:
diff changeset
458 ---------------------------
kono
parents:
diff changeset
459
kono
parents:
diff changeset
460 procedure Master_Completed_Hook
kono
parents:
diff changeset
461 (Self_ID : Task_Id;
kono
parents:
diff changeset
462 Master_Level : Integer)
kono
parents:
diff changeset
463 is
kono
parents:
diff changeset
464 pragma Inspection_Point (Self_ID);
kono
parents:
diff changeset
465 pragma Inspection_Point (Master_Level);
kono
parents:
diff changeset
466 begin
kono
parents:
diff changeset
467 null;
kono
parents:
diff changeset
468 end Master_Completed_Hook;
kono
parents:
diff changeset
469
kono
parents:
diff changeset
470 end System.Tasking.Debug;