summaryrefslogtreecommitdiffstats
path: root/gcc/ada/s-vmexta.adb
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/ada/s-vmexta.adb')
-rw-r--r--gcc/ada/s-vmexta.adb87
1 files changed, 54 insertions, 33 deletions
diff --git a/gcc/ada/s-vmexta.adb b/gcc/ada/s-vmexta.adb
index b61955fb5d3..935ed1e7a39 100644
--- a/gcc/ada/s-vmexta.adb
+++ b/gcc/ada/s-vmexta.adb
@@ -6,7 +6,7 @@
-- --
-- B o d y --
-- --
--- Copyright (C) 1997-2002, Free Software Foundation, Inc. --
+-- Copyright (C) 1997-2004, Free Software Foundation, Inc. --
-- --
-- GNAT 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- --
@@ -38,7 +38,7 @@ pragma Elaborate_All (System.HTable);
package body System.VMS_Exception_Table is
- use System.Standard_Library;
+ use type SSL.Exception_Code;
type HTable_Headers is range 1 .. 37;
@@ -49,8 +49,8 @@ package body System.VMS_Exception_Table is
-- Ada exception.
type Exception_Code_Data is record
- Code : Natural;
- Except : Exception_Data_Ptr;
+ Code : SSL.Exception_Code;
+ Except : SSL.Exception_Data_Ptr;
HTable_Ptr : Exception_Code_Data_Ptr;
end record;
@@ -61,8 +61,8 @@ package body System.VMS_Exception_Table is
function Get_HT_Link (T : Exception_Code_Data_Ptr)
return Exception_Code_Data_Ptr;
- function Hash (F : Natural) return HTable_Headers;
- function Get_Key (T : Exception_Code_Data_Ptr) return Natural;
+ function Hash (F : SSL.Exception_Code) return HTable_Headers;
+ function Get_Key (T : Exception_Code_Data_Ptr) return SSL.Exception_Code;
package Exception_Code_HTable is new System.HTable.Static_HTable (
Header_Num => HTable_Headers,
@@ -71,16 +71,29 @@ package body System.VMS_Exception_Table is
Null_Ptr => null,
Set_Next => Set_HT_Link,
Next => Get_HT_Link,
- Key => Natural,
+ Key => SSL.Exception_Code,
Get_Key => Get_Key,
Hash => Hash,
Equal => "=");
+ ------------------
+ -- Base_Code_In --
+ ------------------
+
+ function Base_Code_In
+ (Code : SSL.Exception_Code) return SSL.Exception_Code
+ is
+ begin
+ return Code and not 2#0111#;
+ end Base_Code_In;
+
---------------------
-- Coded_Exception --
---------------------
- function Coded_Exception (X : Natural) return Exception_Data_Ptr is
+ function Coded_Exception
+ (X : SSL.Exception_Code) return SSL.Exception_Data_Ptr
+ is
Res : Exception_Code_Data_Ptr;
begin
@@ -98,8 +111,9 @@ package body System.VMS_Exception_Table is
-- Get_HT_Link --
-----------------
- function Get_HT_Link (T : Exception_Code_Data_Ptr)
- return Exception_Code_Data_Ptr is
+ function Get_HT_Link
+ (T : Exception_Code_Data_Ptr) return Exception_Code_Data_Ptr
+ is
begin
return T.HTable_Ptr;
end Get_HT_Link;
@@ -108,7 +122,9 @@ package body System.VMS_Exception_Table is
-- Get_Key --
-------------
- function Get_Key (T : Exception_Code_Data_Ptr) return Natural is
+ function Get_Key (T : Exception_Code_Data_Ptr)
+ return SSL.Exception_Code
+ is
begin
return T.Code;
end Get_Key;
@@ -117,39 +133,44 @@ package body System.VMS_Exception_Table is
-- Hash --
----------
- function Hash (F : Natural) return HTable_Headers is
+ function Hash
+ (F : SSL.Exception_Code) return HTable_Headers
+ is
+ Headers_Magnitude : constant SSL.Exception_Code :=
+ SSL.Exception_Code (HTable_Headers'Last - HTable_Headers'First + 1);
+
begin
- return HTable_Headers
- (F mod Natural (HTable_Headers'Last - HTable_Headers'First + 1) + 1);
+ return HTable_Headers (F mod Headers_Magnitude + 1);
end Hash;
----------------------------
-- Register_VMS_Exception --
----------------------------
- procedure Register_VMS_Exception (Code : Integer) is
- Excode : constant Integer := (Code / 8) * 8;
- -- Mask off lower 3 bits which are the severity
+ procedure Register_VMS_Exception
+ (Code : SSL.Exception_Code;
+ E : SSL.Exception_Data_Ptr)
+ is
+ -- We bind the exception data with the base code found in the
+ -- input value, that is with the severity bits masked off.
+
+ Excode : constant SSL.Exception_Code := Base_Code_In (Code);
begin
- -- This allocates an empty exception that gets filled in by
- -- __gnat_error_handler when the exception is raised. Allocating
- -- it here prevents having to allocate it each time the exception
- -- is raised.
+ -- The exception data registered here is mostly filled prior to this
+ -- call and by __gnat_error_handler when the exception is raised. We
+ -- still need to fill a couple of components for exceptions that will
+ -- be used as propagation filters (exception data pointer registered
+ -- as choices in the unwind tables): in some import/export cases, the
+ -- exception pointers for the choice and the propagated occurrence may
+ -- indeed be different for a single import code, and the personality
+ -- routine attempts to match the import codes in this case.
+
+ E.Lang := 'V';
+ E.Import_Code := Excode;
if Exception_Code_HTable.Get (Excode) = null then
- Exception_Code_HTable.Set
- (new Exception_Code_Data'
- (Excode,
- new Exception_Data'
- (Not_Handled_By_Others => False,
- Lang => 'V',
- Name_Length => 0,
- Full_Name => null,
- HTable_Ptr => null,
- Import_Code => 0,
- Raise_Hook => null),
- null));
+ Exception_Code_HTable.Set (new Exception_Code_Data'(Excode, E, null));
end if;
end Register_VMS_Exception;
OpenPOWER on IntegriCloud