Commit 7f335c64 by Olivier Hainque Committed by Arnaud Charlet

2008-04-08 Olivier Hainque <hainque@adacore.com>

	* s-intman-vxworks.ads, s-intman-vxworks.adb
	(Map_And_Raise_Exception): Remove. Was an import of only part of the
	required services already implemented elsewhere.
	(Notify_Exception): Delete body, import __gnat_error_handler instead.
	(Initialize): Add SA_SIGINFO to the sa_flags, to get the sigcontext
	argument passed to the handler, which we need for ZCX propagation
	purposes.

From-SVN: r134016
parent c54ec67c
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
-- -- -- --
-- B o d y -- -- B o d y --
-- -- -- --
-- Copyright (C) 1992-2007, Free Software Foundation, Inc. -- -- Copyright (C) 1992-2008, Free Software Foundation, Inc. --
-- -- -- --
-- GNARL is free software; you can redistribute it and/or modify it under -- -- GNARL is free software; you can redistribute it and/or modify it under --
-- terms of the GNU General Public License as published by the Free Soft- -- -- terms of the GNU General Public License as published by the Free Soft- --
...@@ -49,8 +49,11 @@ package body System.Interrupt_Management is ...@@ -49,8 +49,11 @@ package body System.Interrupt_Management is
Exception_Action : aliased struct_sigaction; Exception_Action : aliased struct_sigaction;
-- Keep this variable global so that it is initialized only once -- Keep this variable global so that it is initialized only once
procedure Map_And_Raise_Exception (signo : Signal); procedure Notify_Exception
pragma Import (C, Map_And_Raise_Exception, "__gnat_map_signal"); (signo : Signal;
siginfo : System.Address;
sigcontext : System.Address);
pragma Import (C, Notify_Exception, "__gnat_error_handler");
-- Map signal to Ada exception and raise it. Different versions -- Map signal to Ada exception and raise it. Different versions
-- of VxWorks need different mappings. -- of VxWorks need different mappings.
...@@ -71,28 +74,6 @@ package body System.Interrupt_Management is ...@@ -71,28 +74,6 @@ package body System.Interrupt_Management is
-- 's' Interrupt_State pragma set state to System (use "default" -- 's' Interrupt_State pragma set state to System (use "default"
-- system handler) -- system handler)
procedure Notify_Exception (signo : Signal);
-- Identify the Ada exception to be raised using
-- the information when the system received a synchronous signal.
----------------------
-- Notify_Exception --
----------------------
procedure Notify_Exception (signo : Signal) is
Mask : aliased sigset_t;
Result : int;
pragma Unreferenced (Result);
begin
Result := pthread_sigmask (SIG_SETMASK, null, Mask'Access);
Result := sigdelset (Mask'Access, signo);
Result := pthread_sigmask (SIG_SETMASK, Mask'Access, null);
Map_And_Raise_Exception (signo);
end Notify_Exception;
--------------------------- ---------------------------
-- Initialize_Interrupts -- -- Initialize_Interrupts --
--------------------------- ---------------------------
...@@ -118,10 +99,12 @@ package body System.Interrupt_Management is ...@@ -118,10 +99,12 @@ package body System.Interrupt_Management is
---------------- ----------------
Initialized : Boolean := False; Initialized : Boolean := False;
-- Set to True once Initialize is called, further calls have no effect
procedure Initialize is procedure Initialize is
mask : aliased sigset_t; mask : aliased sigset_t;
Result : int; Result : int;
begin begin
if Initialized then if Initialized then
return; return;
...@@ -135,7 +118,7 @@ package body System.Interrupt_Management is ...@@ -135,7 +118,7 @@ package body System.Interrupt_Management is
Abort_Task_Interrupt := SIGABRT; Abort_Task_Interrupt := SIGABRT;
Exception_Action.sa_handler := Notify_Exception'Address; Exception_Action.sa_handler := Notify_Exception'Address;
Exception_Action.sa_flags := SA_ONSTACK; Exception_Action.sa_flags := SA_ONSTACK + SA_SIGINFO;
Result := sigemptyset (mask'Access); Result := sigemptyset (mask'Access);
pragma Assert (Result = 0); pragma Assert (Result = 0);
......
...@@ -103,9 +103,9 @@ package System.Interrupt_Management is ...@@ -103,9 +103,9 @@ package System.Interrupt_Management is
-- each task. -- each task.
procedure Initialize; procedure Initialize;
-- Initialize the various variables defined in this package. -- Initialize the various variables defined in this package. This procedure
-- This procedure must be called before accessing any object from this -- must be called before accessing any object from this package and can be
-- package and can be called multiple times. -- called multiple times (only the first call has any effect).
private private
type Interrupt_Mask is new System.OS_Interface.sigset_t; type Interrupt_Mask is new System.OS_Interface.sigset_t;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment