summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ada/ChangeLog14
-rw-r--r--gcc/ada/a-calend.adb4
-rw-r--r--gcc/ada/a-numaux-darwin.adb4
-rw-r--r--gcc/ada/a-numaux-darwin.ads9
-rw-r--r--gcc/ada/a-numaux-libc-x86.ads13
-rw-r--r--gcc/ada/a-numaux-vxworks.ads17
-rw-r--r--gcc/ada/a-numaux-x86.adb7
-rw-r--r--gcc/ada/a-numaux-x86.ads11
-rw-r--r--gcc/ada/a-numaux.ads9
-rw-r--r--gcc/ada/checks.adb13
-rw-r--r--gcc/ada/einfo.adb29
-rw-r--r--gcc/ada/einfo.ads15
-rw-r--r--gcc/ada/elists.adb15
-rw-r--r--gcc/ada/elists.ads7
-rw-r--r--gcc/ada/exp_ch6.adb145
-rw-r--r--gcc/ada/exp_dbug.adb14
-rw-r--r--gcc/ada/exp_dbug.ads25
-rw-r--r--gcc/ada/exp_smem.adb14
-rw-r--r--gcc/ada/freeze.adb5
-rw-r--r--gcc/ada/gnat1drv.adb5
-rw-r--r--gcc/ada/gnat_rm.texi61
-rw-r--r--gcc/ada/gnatcmd.adb2
-rw-r--r--gcc/ada/inline.adb24
-rw-r--r--gcc/ada/mlib-tgt.ads6
-rw-r--r--gcc/ada/opt.adb4
-rw-r--r--gcc/ada/opt.ads31
-rw-r--r--gcc/ada/rtsfind.ads101
-rw-r--r--gcc/ada/s-auxdec.ads10
-rw-r--r--gcc/ada/s-fatgen.adb5
-rw-r--r--gcc/ada/s-fatgen.ads6
-rw-r--r--gcc/ada/s-os_lib.adb15
-rw-r--r--gcc/ada/s-shasto.ads6
-rw-r--r--gcc/ada/s-stalib.ads6
-rw-r--r--gcc/ada/sem.adb8
-rw-r--r--gcc/ada/sem_attr.adb39
-rw-r--r--gcc/ada/sem_ch12.adb11
-rw-r--r--gcc/ada/sem_prag.adb123
-rw-r--r--gcc/ada/sem_prag.ads10
-rw-r--r--gcc/ada/sem_util.adb18
-rw-r--r--gcc/ada/snames.ads-tmpl8
-rw-r--r--gcc/ada/stand.ads3
-rw-r--r--gcc/ada/switch-b.adb14
-rw-r--r--gcc/ada/system.ads3
-rw-r--r--gcc/ada/targparm.adb8
-rw-r--r--gcc/ada/targparm.ads14
45 files changed, 145 insertions, 766 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index a9856c83896..4e5bbb5bf84 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,17 @@
+2014-08-01 Robert Dewar <dewar@adacore.com>
+
+ * a-numaux-vxworks.ads, a-numaux-x86.adb, a-numaux-x86.ads,
+ a-numaux-darwin.adb, a-numaux-darwin.ads, a-numaux.ads,
+ a-numaux-libc-x86.ads: Fix bad package header comments.
+ * elists.ads, elists.adb (Append_New_Elmt): New procedure.
+ * gnat_rm.texi, a-calend.adb, gnatcmd.adb, einfo.adb, einfo.ads,
+ checks.adb, sem_prag.adb, sem_prag.ads, rtsfind.ads, freeze.adb,
+ sem_util.adb, sem_attr.adb, exp_dbug.adb, exp_dbug.ads, gnat1drv.adb,
+ targparm.adb, targparm.ads, exp_ch6.adb, switch-b.adb, s-shasto.ads,
+ stand.ads, s-auxdec.ads, opt.adb, opt.ads, mlib-tgt.ads, s-fatgen.adb,
+ s-fatgen.ads, system.ads, snames.ads-tmpl, s-stalib.ads,
+ s-os_lib.adb: Remove VMS-specific code.
+
2014-08-01 Arnaud Charlet <charlet@adacore.com>
* exp_attr.adb (Is_Inline_Floating_Point_Attribute): Revert to
diff --git a/gcc/ada/a-calend.adb b/gcc/ada/a-calend.adb
index 0043a91e9fe..7c582ade3a0 100644
--- a/gcc/ada/a-calend.adb
+++ b/gcc/ada/a-calend.adb
@@ -6,7 +6,7 @@
-- --
-- B o d y --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -69,7 +69,7 @@ package body Ada.Calendar is
-- by Integer in various routines. One ramification of this model is that
-- the caller site must perform validity checks on returned results.
-- The end result of this model is the lack of target specific files per
- -- child of Ada.Calendar (a-calfor, a-calfor-vms, a-calfor-vxwors, etc).
+ -- child of Ada.Calendar (e.g. a-calfor).
-----------------------
-- Local Subprograms --
diff --git a/gcc/ada/a-numaux-darwin.adb b/gcc/ada/a-numaux-darwin.adb
index 1444603d683..2e9ffd91c11 100644
--- a/gcc/ada/a-numaux-darwin.adb
+++ b/gcc/ada/a-numaux-darwin.adb
@@ -7,7 +7,7 @@
-- B o d y --
-- (Apple OS X Version) --
-- --
--- Copyright (C) 1998-2009, Free Software Foundation, Inc. --
+-- Copyright (C) 1998-2014, 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- --
@@ -30,8 +30,6 @@
-- --
------------------------------------------------------------------------------
--- File a-numaux.adb <- a-numaux-darwin.adb
-
package body Ada.Numerics.Aux is
-----------------------
diff --git a/gcc/ada/a-numaux-darwin.ads b/gcc/ada/a-numaux-darwin.ads
index 2f58ed83866..011ae592ce4 100644
--- a/gcc/ada/a-numaux-darwin.ads
+++ b/gcc/ada/a-numaux-darwin.ads
@@ -30,12 +30,9 @@
-- --
------------------------------------------------------------------------------
--- This version is for use with normal Unix math functions, except for
--- sine/cosine which have been implemented directly in Ada to get the required
--- accuracy in OS X. Alternative packages are used on VxWorks (no need for the
--- -lm Linker_Options), and on the x86 (where we have two versions one using
--- inline ASM, and one importing from the C long routines that take 80-bit
--- arguments).
+-- This version is for use on OS X. It uses the normal Unix math functions,
+-- except for sine/cosine which have been implemented directly in Ada to get
+-- the required accuracy.
package Ada.Numerics.Aux is
pragma Pure;
diff --git a/gcc/ada/a-numaux-libc-x86.ads b/gcc/ada/a-numaux-libc-x86.ads
index 3261c111c43..3b793c6240e 100644
--- a/gcc/ada/a-numaux-libc-x86.ads
+++ b/gcc/ada/a-numaux-libc-x86.ads
@@ -7,7 +7,7 @@
-- S p e c --
-- (C Library Version for x86) --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -30,16 +30,7 @@
-- --
------------------------------------------------------------------------------
--- This package provides the basic computational interface for the generic
--- elementary functions. The C library version interfaces with the routines
--- in the C mathematical library, and is thus quite portable, although it may
--- not necessarily meet the requirements for accuracy in the numerics annex.
--- One advantage of using this package is that it will interface directly to
--- hardware instructions, such as the those provided on the Intel x86.
-
--- Note: there are two versions of this package. One using the 80-bit x86
--- long double format (which is this version), and one using 64-bit IEEE
--- double (see file a-numaux.ads).
+-- This version is for the x86 using the 80-bit x86 long double format
package Ada.Numerics.Aux is
pragma Pure;
diff --git a/gcc/ada/a-numaux-vxworks.ads b/gcc/ada/a-numaux-vxworks.ads
index ce567ad6586..5fdf778b345 100644
--- a/gcc/ada/a-numaux-vxworks.ads
+++ b/gcc/ada/a-numaux-vxworks.ads
@@ -7,7 +7,7 @@
-- S p e c --
-- (C Library Version, VxWorks) --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -30,23 +30,12 @@
-- --
------------------------------------------------------------------------------
--- This package provides the basic computational interface for the generic
--- elementary functions. The C library version interfaces with the routines
--- in the C mathematical library, and is thus quite portable, although it may
--- not necessarily meet the requirements for accuracy in the numerics annex.
--- One advantage of using this package is that it will interface directly to
--- hardware instructions, such as the those provided on the Intel x86.
-
--- Note: there are two versions of this package. One using the normal IEEE
--- 64-bit double format (which is this version), and one using 80-bit x86
--- long double (see file 4onumaux.ads).
+-- Version for use on VxWorks (where we have no libm.a library), so the pragma
+-- Linker_Options ("-lm") is omitted in this version.
package Ada.Numerics.Aux is
pragma Pure;
- -- This version omits the pragma linker_options ("-lm") since there is
- -- no libm.a library for VxWorks.
-
type Double is digits 15;
-- Type Double is the type used to call the C routines
diff --git a/gcc/ada/a-numaux-x86.adb b/gcc/ada/a-numaux-x86.adb
index 811485d859b..5f245a2c37b 100644
--- a/gcc/ada/a-numaux-x86.adb
+++ b/gcc/ada/a-numaux-x86.adb
@@ -7,7 +7,7 @@
-- B o d y --
-- (Machine Version for x86) --
-- --
--- Copyright (C) 1998-2009, Free Software Foundation, Inc. --
+-- Copyright (C) 1998-2014, 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- --
@@ -30,11 +30,6 @@
-- --
------------------------------------------------------------------------------
--- File a-numaux.adb <- 86numaux.adb
-
--- This version of Numerics.Aux is for the IEEE Double Extended floating
--- point format on x86.
-
with System.Machine_Code; use System.Machine_Code;
package body Ada.Numerics.Aux is
diff --git a/gcc/ada/a-numaux-x86.ads b/gcc/ada/a-numaux-x86.ads
index 7211fbb64ce..bf8b49c02ef 100644
--- a/gcc/ada/a-numaux-x86.ads
+++ b/gcc/ada/a-numaux-x86.ads
@@ -7,7 +7,7 @@
-- S p e c --
-- (Machine Version for x86) --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -30,14 +30,7 @@
-- --
------------------------------------------------------------------------------
--- This package provides the basic computational interface for the generic
--- elementary functions. This implementation is based on the glibc assembly
--- sources for the x86 glibc math library.
-
--- Note: there are two versions of this package. One using the 80-bit x86
--- long double format (which is this version), and one using 64-bit IEEE
--- double (see file a-numaux.ads). The latter version imports the C
--- routines directly.
+-- Version for the x86, using 64-bit IEEE format with inline asm statements
package Ada.Numerics.Aux is
pragma Pure;
diff --git a/gcc/ada/a-numaux.ads b/gcc/ada/a-numaux.ads
index 7f265dd043e..f69fdc10da1 100644
--- a/gcc/ada/a-numaux.ads
+++ b/gcc/ada/a-numaux.ads
@@ -38,9 +38,12 @@
-- hardware instructions, such as the those provided on the Intel x86.
-- This version here is for use with normal Unix math functions. Alternative
--- packages are used VxWorks (no need for the -lm Linker_Options), and on the
--- x86 (where we have two versions one using inline ASM, and one importing
--- from the C long routines that take 80-bit arguments).
+-- versions are provided for special situations:
+
+-- a-numaux-darwin For OS/X (special handling of sin/cos for accuracy)
+-- a-numaux-libc-x86 For the x86, using 80-bit long double format
+-- a-numaux-x86 For the x86, using 64-bit IEEE (inline asm statements)
+-- a-numaux-vxworks For use on VxWorks (where we have no libm.a library)
package Ada.Numerics.Aux is
pragma Pure;
diff --git a/gcc/ada/checks.adb b/gcc/ada/checks.adb
index facf85ba5eb..bf27d4ef3a2 100644
--- a/gcc/ada/checks.adb
+++ b/gcc/ada/checks.adb
@@ -8524,14 +8524,7 @@ package body Checks is
function Range_Checks_Suppressed (E : Entity_Id) return Boolean is
begin
if Present (E) then
-
- -- Note: for now we always suppress range checks on Vax float types,
- -- since Gigi does not know how to generate these checks.
-
- if Vax_Float (E) then
- return True;
-
- elsif Kill_Range_Checks (E) then
+ if Kill_Range_Checks (E) then
return True;
elsif Checks_May_Be_Suppressed (E) then
@@ -8576,9 +8569,7 @@ package body Checks is
declare
Typ : constant Entity_Id := Etype (Expr);
begin
- if Vax_Float (Typ) then
- return True;
- elsif Checks_May_Be_Suppressed (Typ)
+ if Checks_May_Be_Suppressed (Typ)
and then (Is_Check_Suppressed (Typ, Range_Check)
or else
Is_Check_Suppressed (Typ, Validity_Check))
diff --git a/gcc/ada/einfo.adb b/gcc/ada/einfo.adb
index 038fe398bf5..7e0eaaaf0fe 100644
--- a/gcc/ada/einfo.adb
+++ b/gcc/ada/einfo.adb
@@ -115,7 +115,6 @@ package body Einfo is
-- RM_Size Uint13
-- Alignment Uint14
- -- First_Optional_Parameter Node14
-- Normalized_Position Uint14
-- Shadow_Entities List14
@@ -1266,12 +1265,6 @@ package body Einfo is
return Node17 (Id);
end First_Literal;
- function First_Optional_Parameter (Id : E) return E is
- begin
- pragma Assert (Ekind_In (Id, E_Function, E_Procedure));
- return Node14 (Id);
- end First_Optional_Parameter;
-
function First_Private_Entity (Id : E) return E is
begin
pragma Assert (Ekind_In (Id, E_Package, E_Generic_Package)
@@ -4004,12 +3997,6 @@ package body Einfo is
Set_Node17 (Id, V);
end Set_First_Literal;
- procedure Set_First_Optional_Parameter (Id : E; V : E) is
- begin
- pragma Assert (Ekind_In (Id, E_Function, E_Procedure));
- Set_Node14 (Id, V);
- end Set_First_Optional_Parameter;
-
procedure Set_First_Private_Entity (Id : E; V : E) is
begin
pragma Assert (Ekind_In (Id, E_Package, E_Generic_Package)
@@ -8178,18 +8165,6 @@ package body Einfo is
end if;
end Underlying_Type;
- ---------------
- -- Vax_Float --
- ---------------
-
- -- To be removed ???
-
- function Vax_Float (Id : E) return B is
- pragma Unreferenced (Id);
- begin
- return False;
- end Vax_Float;
-
------------------------
-- Write_Entity_Flags --
------------------------
@@ -8891,10 +8866,6 @@ package body Einfo is
E_Loop_Parameter =>
Write_Str ("Alignment");
- when E_Function |
- E_Procedure =>
- Write_Str ("First_Optional_Parameter");
-
when E_Component |
E_Discriminant =>
Write_Str ("Normalized_Position");
diff --git a/gcc/ada/einfo.ads b/gcc/ada/einfo.ads
index 4cda0444584..11f61222883 100644
--- a/gcc/ada/einfo.ads
+++ b/gcc/ada/einfo.ads
@@ -1278,13 +1278,6 @@ package Einfo is
-- Note that this field is set in enumeration subtypes, but it still
-- points to the first literal of the base type in this case.
--- First_Optional_Parameter (Node14)
--- Defined in (non-generic) function and procedure entities. Set to a
--- non-null value only if a pragma Import_Function, Import_Procedure
--- or Import_Valued_Procedure specifies a First_Optional_Parameter
--- argument, in which case this field points to the parameter entity
--- corresponding to the specified parameter.
-
-- First_Private_Entity (Node16)
-- Defined in all entities containing private parts (packages, protected
-- types and subtypes, task types and subtypes). The entities on the
@@ -5615,7 +5608,6 @@ package Einfo is
-- Safe_Last_Value (synth)
-- Type_Low_Bound (synth)
-- Type_High_Bound (synth)
- -- Vax_Float (synth)
-- (plus type attributes)
-- E_Function
@@ -5626,7 +5618,6 @@ package Einfo is
-- Protected_Body_Subprogram (Node11)
-- Next_Inlined_Subprogram (Node12)
-- Elaboration_Entity (Node13) (not implicit /=)
- -- First_Optional_Parameter (Node14) (non-generic case only)
-- DT_Position (Uint15)
-- DTC_Entity (Node16)
-- First_Entity (Node17)
@@ -5926,7 +5917,6 @@ package Einfo is
-- Protected_Body_Subprogram (Node11)
-- Next_Inlined_Subprogram (Node12)
-- Elaboration_Entity (Node13)
- -- First_Optional_Parameter (Node14) (non-generic case only)
-- DT_Position (Uint15)
-- DTC_Entity (Node16)
-- First_Entity (Node17)
@@ -6537,7 +6527,6 @@ package Einfo is
function First_Exit_Statement (Id : E) return N;
function First_Index (Id : E) return N;
function First_Literal (Id : E) return E;
- function First_Optional_Parameter (Id : E) return E;
function First_Private_Entity (Id : E) return E;
function First_Rep_Item (Id : E) return N;
function Float_Rep (Id : E) return F;
@@ -6866,7 +6855,6 @@ package Einfo is
function Used_As_Generic_Actual (Id : E) return B;
function Uses_Lock_Free (Id : E) return B;
function Uses_Sec_Stack (Id : E) return B;
- function Vax_Float (Id : E) return B;
function Warnings_Off (Id : E) return B;
function Warnings_Off_Used (Id : E) return B;
function Warnings_Off_Used_Unmodified (Id : E) return B;
@@ -7172,7 +7160,6 @@ package Einfo is
procedure Set_First_Exit_Statement (Id : E; V : N);
procedure Set_First_Index (Id : E; V : N);
procedure Set_First_Literal (Id : E; V : E);
- procedure Set_First_Optional_Parameter (Id : E; V : E);
procedure Set_First_Private_Entity (Id : E; V : E);
procedure Set_First_Rep_Item (Id : E; V : N);
procedure Set_Float_Rep (Id : E; V : F);
@@ -7921,7 +7908,6 @@ package Einfo is
pragma Inline (First_Exit_Statement);
pragma Inline (First_Index);
pragma Inline (First_Literal);
- pragma Inline (First_Optional_Parameter);
pragma Inline (First_Private_Entity);
pragma Inline (First_Rep_Item);
pragma Inline (Freeze_Node);
@@ -8402,7 +8388,6 @@ package Einfo is
pragma Inline (Set_First_Exit_Statement);
pragma Inline (Set_First_Index);
pragma Inline (Set_First_Literal);
- pragma Inline (Set_First_Optional_Parameter);
pragma Inline (Set_First_Private_Entity);
pragma Inline (Set_First_Rep_Item);
pragma Inline (Set_Freeze_Node);
diff --git a/gcc/ada/elists.adb b/gcc/ada/elists.adb
index 7e62ce49f69..fbfb9e7b46b 100644
--- a/gcc/ada/elists.adb
+++ b/gcc/ada/elists.adb
@@ -6,7 +6,7 @@
-- --
-- B o d y --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -138,6 +138,19 @@ package body Elists is
end if;
end Append_Elmt;
+ ---------------------
+ -- Append_New_Elmt --
+ ---------------------
+
+ procedure Append_New_Elmt (N : Node_Or_Entity_Id; To : in out Elist_Id) is
+ begin
+ if To = No_Elist then
+ To := New_Elmt_List;
+ end if;
+
+ Append_Elmt (N, To);
+ end Append_New_Elmt;
+
------------------------
-- Append_Unique_Elmt --
------------------------
diff --git a/gcc/ada/elists.ads b/gcc/ada/elists.ads
index f0331362ea3..3353b9cd17f 100644
--- a/gcc/ada/elists.ads
+++ b/gcc/ada/elists.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -126,6 +126,11 @@ package Elists is
-- Appends N at the end of To, allocating a new element. N must be a
-- non-empty node or entity Id, and To must be an Elist (not No_Elist).
+ procedure Append_New_Elmt (N : Node_Or_Entity_Id; To : in out Elist_Id);
+ pragma Inline (Append_New_Elmt);
+ -- Like Append_Elmt if Elist_Id is not No_List, but if Elist_Id is No_List,
+ -- then first assigns it an empty element list and then does the append.
+
procedure Append_Unique_Elmt (N : Node_Or_Entity_Id; To : Elist_Id);
-- Like Append_Elmt, except that a check is made to see if To already
-- contains N and if so the call has no effect.
diff --git a/gcc/ada/exp_ch6.adb b/gcc/ada/exp_ch6.adb
index 4550986fdd7..50bc11a5546 100644
--- a/gcc/ada/exp_ch6.adb
+++ b/gcc/ada/exp_ch6.adb
@@ -1976,7 +1976,6 @@ package body Exp_Ch6 is
-- Rewrite call to predefined operator as operator
-- Replace actuals to in-out parameters that are numeric conversions,
-- with explicit assignment to temporaries before and after the call.
- -- Remove optional actuals if First_Optional_Parameter specified.
-- Note that the list of actuals has been filled with default expressions
-- during semantic analysis of the call. Only the extra actuals required
@@ -4022,150 +4021,6 @@ package body Exp_Ch6 is
Establish_Transient_Scope (Call_Node, Sec_Stack => True);
end if;
end if;
-
- -- Test for First_Optional_Parameter, and if so, truncate parameter list
- -- if there are optional parameters at the trailing end.
- -- Note: we never delete procedures for call via a pointer.
-
- if (Ekind (Subp) = E_Procedure or else Ekind (Subp) = E_Function)
- and then Present (First_Optional_Parameter (Subp))
- then
- declare
- Last_Keep_Arg : Node_Id;
-
- begin
- -- Last_Keep_Arg will hold the last actual that should be kept.
- -- If it remains empty at the end, it means that all parameters
- -- are optional.
-
- Last_Keep_Arg := Empty;
-
- -- Find first optional parameter, must be present since we checked
- -- the validity of the parameter before setting it.
-
- Formal := First_Formal (Subp);
- Actual := First_Actual (Call_Node);
- while Formal /= First_Optional_Parameter (Subp) loop
- Last_Keep_Arg := Actual;
- Next_Formal (Formal);
- Next_Actual (Actual);
- end loop;
-
- -- We have Formal and Actual pointing to the first potentially
- -- droppable argument. We can drop all the trailing arguments
- -- whose actual matches the default. Note that we know that all
- -- remaining formals have defaults, because we checked that this
- -- requirement was met before setting First_Optional_Parameter.
-
- -- We use Fully_Conformant_Expressions to check for identity
- -- between formals and actuals, which may miss some cases, but
- -- on the other hand, this is only an optimization (if we fail
- -- to truncate a parameter it does not affect functionality).
- -- So if the default is 3 and the actual is 1+2, we consider
- -- them unequal, which hardly seems worrisome.
-
- while Present (Formal) loop
- if not Fully_Conformant_Expressions
- (Actual, Default_Value (Formal))
- then
- Last_Keep_Arg := Actual;
- end if;
-
- Next_Formal (Formal);
- Next_Actual (Actual);
- end loop;
-
- -- If no arguments, delete entire list, this is the easy case
-
- if No (Last_Keep_Arg) then
- Set_Parameter_Associations (Call_Node, No_List);
- Set_First_Named_Actual (Call_Node, Empty);
-
- -- Case where at the last retained argument is positional. This
- -- is also an easy case, since the retained arguments are already
- -- in the right form, and we don't need to worry about the order
- -- of arguments that get eliminated.
-
- elsif Is_List_Member (Last_Keep_Arg) then
- while Present (Next (Last_Keep_Arg)) loop
- Discard_Node (Remove_Next (Last_Keep_Arg));
- end loop;
-
- Set_First_Named_Actual (Call_Node, Empty);
-
- -- This is the annoying case where the last retained argument
- -- is a named parameter. Since the original arguments are not
- -- in declaration order, we may have to delete some fairly
- -- random collection of arguments.
-
- else
- declare
- Temp : Node_Id;
- Passoc : Node_Id;
-
- begin
- -- First step, remove all the named parameters from the
- -- list (they are still chained using First_Named_Actual
- -- and Next_Named_Actual, so we have not lost them).
-
- Temp := First (Parameter_Associations (Call_Node));
-
- -- Case of all parameters named, remove them all
-
- if Nkind (Temp) = N_Parameter_Association then
- -- Suppress warnings to avoid warning on possible
- -- infinite loop (because Call_Node is not modified).
-
- pragma Warnings (Off);
- while Is_Non_Empty_List
- (Parameter_Associations (Call_Node))
- loop
- Temp :=
- Remove_Head (Parameter_Associations (Call_Node));
- end loop;
- pragma Warnings (On);
-
- -- Case of mixed positional/named, remove named parameters
-
- else
- while Nkind (Next (Temp)) /= N_Parameter_Association loop
- Next (Temp);
- end loop;
-
- while Present (Next (Temp)) loop
- Remove (Next (Temp));
- end loop;
- end if;
-
- -- Now we loop through the named parameters, till we get
- -- to the last one to be retained, adding them to the list.
- -- Note that the Next_Named_Actual list does not need to be
- -- touched since we are only reordering them on the actual
- -- parameter association list.
-
- Passoc := Parent (First_Named_Actual (Call_Node));
- loop
- Temp := Relocate_Node (Passoc);
- Append_To
- (Parameter_Associations (Call_Node), Temp);
- exit when
- Last_Keep_Arg = Explicit_Actual_Parameter (Passoc);
- Passoc := Parent (Next_Named_Actual (Passoc));
- end loop;
-
- Set_Next_Named_Actual (Temp, Empty);
-
- loop
- Temp := Next_Named_Actual (Passoc);
- exit when No (Temp);
- Set_Next_Named_Actual
- (Passoc, Next_Named_Actual (Parent (Temp)));
- end loop;
- end;
-
- end if;
- end;
- end if;
end Expand_Call;
-------------------------------
diff --git a/gcc/ada/exp_dbug.adb b/gcc/ada/exp_dbug.adb
index d1439abbb48..c025f05f378 100644
--- a/gcc/ada/exp_dbug.adb
+++ b/gcc/ada/exp_dbug.adb
@@ -604,20 +604,6 @@ package body Exp_Dbug is
Add_Real_To_Buffer (Small_Value (E));
end if;
- -- Vax floating-point case
-
- elsif Vax_Float (E) then
- if Digits_Value (Base_Type (E)) = 6 then
- Get_External_Name (E, True, "XFF");
-
- elsif Digits_Value (Base_Type (E)) = 9 then
- Get_External_Name (E, True, "XFF");
-
- else
- pragma Assert (Digits_Value (Base_Type (E)) = 15);
- Get_External_Name (E, True, "XFG");
- end if;
-
-- Discrete case where bounds do not match size
elsif Is_Discrete_Type (E)
diff --git a/gcc/ada/exp_dbug.ads b/gcc/ada/exp_dbug.ads
index c687cdde9d5..eefc9c9c637 100644
--- a/gcc/ada/exp_dbug.ads
+++ b/gcc/ada/exp_dbug.ads
@@ -540,31 +540,6 @@ package Exp_Dbug is
-- delta. In this case, the first nn/dd rational value is for delta,
-- and the second value is for small.
- ------------------------------
- -- VAX Floating-Point Types --
- ------------------------------
-
- -- Vax floating-point types are represented at run time as integer
- -- types, which are treated specially by the code generator. Their
- -- type names are encoded with the following suffix:
-
- -- typ___XFF
- -- typ___XFD
- -- typ___XFG
-
- -- representing the Vax F Float, D Float, and G Float types. The
- -- debugger must treat these specially. In particular, printing these
- -- values can be achieved using the debug procedures that are provided
- -- in package System.Vax_Float_Operations:
-
- -- procedure Debug_Output_D (Arg : D);
- -- procedure Debug_Output_F (Arg : F);
- -- procedure Debug_Output_G (Arg : G);
-
- -- These three procedures take a Vax floating-point argument, and
- -- output a corresponding decimal representation to standard output
- -- with no terminating line return.
-
--------------------
-- Discrete Types --
--------------------
diff --git a/gcc/ada/exp_smem.adb b/gcc/ada/exp_smem.adb
index c264b50b5c3..387b32f71ea 100644
--- a/gcc/ada/exp_smem.adb
+++ b/gcc/ada/exp_smem.adb
@@ -212,17 +212,9 @@ package body Exp_Smem is
-- Mark object as locked in the current (transient) scope
- declare
- Locked_Shared_Objects : Elist_Id renames
- Scope_Stack.Table (Scope_Stack.Last).Locked_Shared_Objects;
-
- begin
- if Locked_Shared_Objects = No_Elist then
- Locked_Shared_Objects := New_Elmt_List;
- end if;
-
- Append_Elmt (Obj, To => Locked_Shared_Objects);
- end;
+ Append_New_Elmt
+ (Obj,
+ To => Scope_Stack.Table (Scope_Stack.Last).Locked_Shared_Objects);
-- First insert the Lock call before
diff --git a/gcc/ada/freeze.adb b/gcc/ada/freeze.adb
index 190813019a5..e499701a342 100644
--- a/gcc/ada/freeze.adb
+++ b/gcc/ada/freeze.adb
@@ -7233,9 +7233,8 @@ package body Freeze is
or else Nkind_In (Dcopy, N_Expanded_Name,
N_Integer_Literal,
N_Character_Literal,
- N_String_Literal)
- or else (Nkind (Dcopy) = N_Real_Literal
- and then not Vax_Float (Etype (Dcopy)))
+ N_String_Literal,
+ N_Real_Literal)
or else (Nkind (Dcopy) = N_Attribute_Reference
and then Attribute_Name (Dcopy) = Name_Null_Parameter)
or else Known_Null (Dcopy)
diff --git a/gcc/ada/gnat1drv.adb b/gcc/ada/gnat1drv.adb
index 2eb9d980336..6e6b5c53430 100644
--- a/gcc/ada/gnat1drv.adb
+++ b/gcc/ada/gnat1drv.adb
@@ -475,11 +475,6 @@ procedure Gnat1drv is
Ttypes.Bytes_Big_Endian := not Ttypes.Bytes_Big_Endian;
end if;
- -- Temporarily set True_VMS_Target to OpenVMS_On_Target. This is just
- -- temporary, we no longer deal with the debug flag -gnatdm here.
-
- Opt.True_VMS_Target := Targparm.OpenVMS_On_Target;
-
-- Activate front end layout if debug flag -gnatdF is set
if Debug_Flag_FF then
diff --git a/gcc/ada/gnat_rm.texi b/gcc/ada/gnat_rm.texi
index 05f79b8ee5f..24db2f2cd26 100644
--- a/gcc/ada/gnat_rm.texi
+++ b/gcc/ada/gnat_rm.texi
@@ -2883,13 +2883,7 @@ MECHANISM ::=
MECHANISM_ASSOCIATION ::=
[formal_parameter_NAME =>] MECHANISM_NAME
-MECHANISM_NAME ::=
- Value
-| Reference
-| Descriptor [([Class =>] CLASS_NAME)]
-| Short_Descriptor [([Class =>] CLASS_NAME)]
-
-CLASS_NAME ::= ubs | ubsb | uba | s | sb | a
+MECHANISM_NAME ::= Value | Reference
@end smallexample
@noindent
@@ -2917,13 +2911,6 @@ using positional notation to match parameters with subtype marks.
The form with an @code{'Access} attribute can be used to match an
anonymous access parameter.
-@cindex OpenVMS
-@cindex Passing by descriptor
-Passing by descriptor is supported only on the OpenVMS ports of GNAT@.
-The default behavior for Export_Function is to accept either 64bit or
-32bit descriptors unless short_descriptor is specified, then only 32bit
-descriptors are accepted.
-
@cindex Suppressing external name
Special treatment is given if the EXTERNAL is an explicit null
string or a static string expressions that evaluates to the null
@@ -2988,13 +2975,7 @@ MECHANISM ::=
MECHANISM_ASSOCIATION ::=
[formal_parameter_NAME =>] MECHANISM_NAME
-MECHANISM_NAME ::=
- Value
-| Reference
-| Descriptor [([Class =>] CLASS_NAME)]
-| Short_Descriptor [([Class =>] CLASS_NAME)]
-
-CLASS_NAME ::= ubs | ubsb | uba | s | sb | a
+MECHANISM_NAME ::= Value | Reference
@end smallexample
@noindent
@@ -3007,13 +2988,6 @@ not what is wanted, so it is usually appropriate to use this
pragma in conjunction with a @code{Export} or @code{Convention}
pragma that specifies the desired foreign convention.
-@cindex OpenVMS
-@cindex Passing by descriptor
-Passing by descriptor is supported only on the OpenVMS ports of GNAT@.
-The default behavior for Export_Procedure is to accept either 64bit or
-32bit descriptors unless short_descriptor is specified, then only 32bit
-descriptors are accepted.
-
@cindex Suppressing external name
Special treatment is given if the EXTERNAL is an explicit null
string or a static string expressions that evaluates to the null
@@ -3074,13 +3048,7 @@ MECHANISM ::=
MECHANISM_ASSOCIATION ::=
[formal_parameter_NAME =>] MECHANISM_NAME
-MECHANISM_NAME ::=
- Value
-| Reference
-| Descriptor [([Class =>] CLASS_NAME)]
-| Short_Descriptor [([Class =>] CLASS_NAME)]
-
-CLASS_NAME ::= ubs | ubsb | uba | s | sb | a
+MECHANISM_NAME ::= Value | Reference
@end smallexample
@noindent
@@ -3098,13 +3066,6 @@ with foreign language functions, so it is usually appropriate to use this
pragma in conjunction with a @code{Export} or @code{Convention}
pragma that specifies the desired foreign convention.
-@cindex OpenVMS
-@cindex Passing by descriptor
-Passing by descriptor is supported only on the OpenVMS ports of GNAT@.
-The default behavior for Export_Valued_Procedure is to accept either 64bit or
-32bit descriptors unless short_descriptor is specified, then only 32bit
-descriptors are accepted.
-
@cindex Suppressing external name
Special treatment is given if the EXTERNAL is an explicit null
string or a static string expressions that evaluates to the null
@@ -3608,8 +3569,7 @@ pragma Import_Function (
[, [Parameter_Types =>] PARAMETER_TYPES]
[, [Result_Type =>] SUBTYPE_MARK]
[, [Mechanism =>] MECHANISM]
- [, [Result_Mechanism =>] MECHANISM_NAME]
- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ [, [Result_Mechanism =>] MECHANISM_NAME]);
EXTERNAL_SYMBOL ::=
IDENTIFIER
@@ -3698,8 +3658,7 @@ pragma Import_Procedure (
[Internal =>] LOCAL_NAME
[, [External =>] EXTERNAL_SYMBOL]
[, [Parameter_Types =>] PARAMETER_TYPES]
- [, [Mechanism =>] MECHANISM]
- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ [, [Mechanism =>] MECHANISM]);
EXTERNAL_SYMBOL ::=
IDENTIFIER
@@ -3739,8 +3698,7 @@ pragma Import_Valued_Procedure (
[Internal =>] LOCAL_NAME
[, [External =>] EXTERNAL_SYMBOL]
[, [Parameter_Types =>] PARAMETER_TYPES]
- [, [Mechanism =>] MECHANISM]
- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ [, [Mechanism =>] MECHANISM]);
EXTERNAL_SYMBOL ::=
IDENTIFIER
@@ -6405,11 +6363,8 @@ pragma Short_Descriptors
@end smallexample
@noindent
-In VMS versions of the compiler, this configuration pragma causes all
-occurrences of the mechanism types Descriptor[_xxx] to be treated as
-Short_Descriptor[_xxx]. This is helpful in porting legacy applications from a
-32-bit environment to a 64-bit environment. This pragma is ignored for non-VMS
-versions.
+This pragma is provided for compatibility with other Ada implementations. It
+is recognized but ignored by all current versions of GNAT.
@node Pragma Simple_Storage_Pool_Type
@unnumberedsec Pragma Simple_Storage_Pool_Type
diff --git a/gcc/ada/gnatcmd.adb b/gcc/ada/gnatcmd.adb
index ffbeb951cae..354054f4b47 100644
--- a/gcc/ada/gnatcmd.adb
+++ b/gcc/ada/gnatcmd.adb
@@ -1180,7 +1180,7 @@ procedure GNATCmd is
for C in Command_List'Range loop
- -- No usage for VMS only command or for Sync
+ -- No usage for Sync
if C /= Sync then
if Targparm.AAMP_On_Target then
diff --git a/gcc/ada/inline.adb b/gcc/ada/inline.adb
index 04ca7ca6322..6434159b437 100644
--- a/gcc/ada/inline.adb
+++ b/gcc/ada/inline.adb
@@ -518,11 +518,7 @@ package body Inline is
procedure Register_Backend_Inlined_Subprogram (Subp : Entity_Id) is
begin
- if Backend_Inlined_Subps = No_Elist then
- Backend_Inlined_Subps := New_Elmt_List;
- end if;
-
- Append_Elmt (Subp, To => Backend_Inlined_Subps);
+ Append_New_Elmt (Subp, To => Backend_Inlined_Subps);
end Register_Backend_Inlined_Subprogram;
---------------------------------------------
@@ -531,11 +527,7 @@ package body Inline is
procedure Register_Backend_Not_Inlined_Subprogram (Subp : Entity_Id) is
begin
- if Backend_Not_Inlined_Subps = No_Elist then
- Backend_Not_Inlined_Subps := New_Elmt_List;
- end if;
-
- Append_Elmt (Subp, To => Backend_Not_Inlined_Subps);
+ Append_New_Elmt (Subp, To => Backend_Not_Inlined_Subps);
end Register_Backend_Not_Inlined_Subprogram;
-- Start of processing for Add_Inlined_Subprogram
@@ -2802,11 +2794,7 @@ package body Inline is
-- Register the call in the list of inlined calls
- if Inlined_Calls = No_Elist then
- Inlined_Calls := New_Elmt_List;
- end if;
-
- Append_Elmt (N, To => Inlined_Calls);
+ Append_New_Elmt (N, To => Inlined_Calls);
-- Use generic machinery to copy body of inlined subprogram, as if it
-- were an instantiation, resetting source locations appropriately, so
@@ -4027,11 +4015,7 @@ package body Inline is
procedure Register_Backend_Call (N : Node_Id) is
begin
- if Backend_Calls = No_Elist then
- Backend_Calls := New_Elmt_List;
- end if;
-
- Append_Elmt (N, To => Backend_Calls);
+ Append_New_Elmt (N, To => Backend_Calls);
end Register_Backend_Call;
--------------------------
diff --git a/gcc/ada/mlib-tgt.ads b/gcc/ada/mlib-tgt.ads
index cbb15d3ac1d..0260159bfeb 100644
--- a/gcc/ada/mlib-tgt.ads
+++ b/gcc/ada/mlib-tgt.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 2001-2009, AdaCore --
+-- Copyright (C) 2001-2014, AdaCore --
-- --
-- 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- --
@@ -132,8 +132,8 @@ package MLib.Tgt is
-- "libtoto.so" will be a symbolic link to "libtoto.so.2.1" which
-- will be the actual library file.
--
- -- Symbol_Data is used for some platforms, including VMS, to generate
- -- the symbols to be exported by the library.
+ -- Symbol_Data is used for some platforms, to generate the symbols to be
+ -- exported by the library (not certain if it is currently in use or not).
--
-- Note: Depending on the OS, some of the parameters may not be taken into
-- account. For example, on Linux, Interfaces, Symbol_Data and Auto_Init
diff --git a/gcc/ada/opt.adb b/gcc/ada/opt.adb
index 115500dfaa0..4144340c47a 100644
--- a/gcc/ada/opt.adb
+++ b/gcc/ada/opt.adb
@@ -63,7 +63,6 @@ package body Opt is
Optimize_Alignment_Config := Optimize_Alignment;
Persistent_BSS_Mode_Config := Persistent_BSS_Mode;
Polling_Required_Config := Polling_Required;
- Short_Descriptors_Config := Short_Descriptors;
SPARK_Mode_Config := SPARK_Mode;
SPARK_Mode_Pragma_Config := SPARK_Mode_Pragma;
Uneval_Old_Config := Uneval_Old;
@@ -103,7 +102,6 @@ package body Opt is
Optimize_Alignment_Local := Save.Optimize_Alignment_Local;
Persistent_BSS_Mode := Save.Persistent_BSS_Mode;
Polling_Required := Save.Polling_Required;
- Short_Descriptors := Save.Short_Descriptors;
SPARK_Mode := Save.SPARK_Mode;
SPARK_Mode_Pragma := Save.SPARK_Mode_Pragma;
Uneval_Old := Save.Uneval_Old;
@@ -144,7 +142,6 @@ package body Opt is
Save.Optimize_Alignment_Local := Optimize_Alignment_Local;
Save.Persistent_BSS_Mode := Persistent_BSS_Mode;
Save.Polling_Required := Polling_Required;
- Save.Short_Descriptors := Short_Descriptors;
Save.SPARK_Mode := SPARK_Mode;
Save.SPARK_Mode_Pragma := SPARK_Mode_Pragma;
Save.Uneval_Old := Uneval_Old;
@@ -244,7 +241,6 @@ package body Opt is
Fast_Math := Fast_Math_Config;
Optimize_Alignment := Optimize_Alignment_Config;
Polling_Required := Polling_Required_Config;
- Short_Descriptors := Short_Descriptors_Config;
end Set_Opt_Config_Switches;
---------------
diff --git a/gcc/ada/opt.ads b/gcc/ada/opt.ads
index 68d20f1d033..7993155402e 100644
--- a/gcc/ada/opt.ads
+++ b/gcc/ada/opt.ads
@@ -418,12 +418,9 @@ package Opt is
subtype Debug_Level_Value is Nat range 0 .. 3;
Debugger_Level : Debug_Level_Value := 0;
- -- GNATBIND
-- The value given to the -g parameter. The default value for -g with
- -- no value is 2. This is usually ignored by GNATBIND, except in the
- -- VMS version where it is passed as an argument to __gnat_initialize
- -- to trigger the activation of the remote debugging interface.
- -- Is this still true ???
+ -- no value is 2. This is not currently used but is retained for possible
+ -- future use.
Default_Exit_Status : Int := 0;
-- GNATBIND
@@ -709,11 +706,6 @@ package Opt is
-- GNAT
-- True if compiling in GNAT system mode (-gnatg switch)
- Heap_Size : Nat := 0;
- -- GNATBIND
- -- Heap size for memory allocations. Valid values are 32 and 64. Only
- -- available on VMS.
-
Identifier_Character_Set : Character;
-- GNAT
-- This variable indicates the character set to be used for identifiers.
@@ -1291,10 +1283,6 @@ package Opt is
-- GNAT
-- Set True if a pragma Short_Circuit_And_Or applies to the current unit.
- Short_Descriptors : Boolean := False;
- -- GNAT
- -- Set True if a pragma Short_Descriptors applies to the current unit.
-
type SPARK_Mode_Type is (None, Off, On);
-- Possible legal modes that can be set by aspect/pragma SPARK_Mode, as
-- well as the value None, which indicates no such pragma/aspect applies.
@@ -1463,12 +1451,6 @@ package Opt is
-- GNAT
-- Set to True (-gnatt) to generate output tree file
- True_VMS_Target : Boolean := False;
- -- Set True if we are on a VMS target. The setting of this flag reflects
- -- the true state of the compile, unlike Targparm.OpenVMS_On_Target which
- -- can also be true when debug flag m is set (-gnatdm). This is used in the
- -- few cases where we do NOT want -gnatdm to trigger the VMS behavior.
-
Try_Semantics : Boolean := False;
-- GNAT
-- Flag set to force attempt at semantic analysis, even if parser errors
@@ -1955,14 +1937,6 @@ package Opt is
-- flag is used to set the initial value for Polling_Required at the start
-- of analyzing each unit.
- Short_Descriptors_Config : Boolean;
- -- GNAT
- -- This is the value of the configuration switch that controls the use of
- -- Short_Descriptors for setting descriptor default sizes. It can be set
- -- True by the use of the pragma Short_Descriptors in the gnat.adc file.
- -- This flag is used to set the initial value for Short_Descriptors at the
- -- start of analyzing each unit.
-
SPARK_Mode_Config : SPARK_Mode_Type := None;
-- GNAT
-- The setting of SPARK_Mode from configuration pragmas
@@ -2143,7 +2117,6 @@ private
Optimize_Alignment_Local : Boolean;
Persistent_BSS_Mode : Boolean;
Polling_Required : Boolean;
- Short_Descriptors : Boolean;
SPARK_Mode : SPARK_Mode_Type;
SPARK_Mode_Pragma : Node_Id;
Uneval_Old : Character;
diff --git a/gcc/ada/rtsfind.ads b/gcc/ada/rtsfind.ads
index e1853fa21b0..f1a40821dd8 100644
--- a/gcc/ada/rtsfind.ads
+++ b/gcc/ada/rtsfind.ads
@@ -374,7 +374,6 @@ package Rtsfind is
System_Val_Real,
System_Val_Uns,
System_Val_WChar,
- System_Vax_Float_Operations,
System_Version_Control,
System_WCh_StW,
System_WCh_WtS,
@@ -1636,56 +1635,6 @@ package Rtsfind is
RE_Value_Wide_Character, -- System.Val_WChar
RE_Value_Wide_Wide_Character, -- System.Val_WChar
- RE_D, -- System.Vax_Float_Operations
- RE_F, -- System.Vax_Float_Operations
- RE_G, -- System.Vax_Float_Operations
- RE_Q, -- System.Vax_Float_Operations
- RE_S, -- System.Vax_Float_Operations
- RE_T, -- System.Vax_Float_Operations
-
- RE_D_To_G, -- System.Vax_Float_Operations
- RE_F_To_G, -- System.Vax_Float_Operations
- RE_F_To_Q, -- System.Vax_Float_Operations
- RE_F_To_S, -- System.Vax_Float_Operations
- RE_G_To_D, -- System.Vax_Float_Operations
- RE_G_To_F, -- System.Vax_Float_Operations
- RE_G_To_Q, -- System.Vax_Float_Operations
- RE_G_To_T, -- System.Vax_Float_Operations
- RE_Q_To_F, -- System.Vax_Float_Operations
- RE_Q_To_G, -- System.Vax_Float_Operations
- RE_S_To_F, -- System.Vax_Float_Operations
- RE_T_To_D, -- System.Vax_Float_Operations
- RE_T_To_G, -- System.Vax_Float_Operations
-
- RE_Abs_F, -- System.Vax_Float_Operations
- RE_Abs_G, -- System.Vax_Float_Operations
- RE_Add_F, -- System.Vax_Float_Operations
- RE_Add_G, -- System.Vax_Float_Operations
- RE_Div_F, -- System.Vax_Float_Operations
- RE_Div_G, -- System.Vax_Float_Operations
- RE_Mul_F, -- System.Vax_Float_Operations
- RE_Mul_G, -- System.Vax_Float_Operations
- RE_Neg_F, -- System.Vax_Float_Operations
- RE_Neg_G, -- System.Vax_Float_Operations
- RE_Return_D, -- System.Vax_Float_Operations
- RE_Return_F, -- System.Vax_Float_Operations
- RE_Return_G, -- System.Vax_Float_Operations
- RE_Sub_F, -- System.Vax_Float_Operations
- RE_Sub_G, -- System.Vax_Float_Operations
-
- RE_Eq_F, -- System.Vax_Float_Operations
- RE_Eq_G, -- System.Vax_Float_Operations
- RE_Le_F, -- System.Vax_Float_Operations
- RE_Le_G, -- System.Vax_Float_Operations
- RE_Lt_F, -- System.Vax_Float_Operations
- RE_Lt_G, -- System.Vax_Float_Operations
- RE_Ne_F, -- System.Vax_Float_Operations
- RE_Ne_G, -- System.Vax_Float_Operations
-
- RE_Valid_D, -- System.Vax_Float_Operations
- RE_Valid_F, -- System.Vax_Float_Operations
- RE_Valid_G, -- System.Vax_Float_Operations
-
RE_Version_String, -- System.Version_Control
RE_Get_Version_String, -- System.Version_Control
@@ -2921,56 +2870,6 @@ package Rtsfind is
RE_Value_Wide_Character => System_Val_WChar,
RE_Value_Wide_Wide_Character => System_Val_WChar,
- RE_D => System_Vax_Float_Operations,
- RE_F => System_Vax_Float_Operations,
- RE_G => System_Vax_Float_Operations,
- RE_Q => System_Vax_Float_Operations,
- RE_S => System_Vax_Float_Operations,
- RE_T => System_Vax_Float_Operations,
-
- RE_D_To_G => System_Vax_Float_Operations,
- RE_F_To_G => System_Vax_Float_Operations,
- RE_F_To_Q => System_Vax_Float_Operations,
- RE_F_To_S => System_Vax_Float_Operations,
- RE_G_To_D => System_Vax_Float_Operations,
- RE_G_To_F => System_Vax_Float_Operations,
- RE_G_To_Q => System_Vax_Float_Operations,
- RE_G_To_T => System_Vax_Float_Operations,
- RE_Q_To_F => System_Vax_Float_Operations,
- RE_Q_To_G => System_Vax_Float_Operations,
- RE_S_To_F => System_Vax_Float_Operations,
- RE_T_To_D => System_Vax_Float_Operations,
- RE_T_To_G => System_Vax_Float_Operations,
-
- RE_Abs_F => System_Vax_Float_Operations,
- RE_Abs_G => System_Vax_Float_Operations,
- RE_Add_F => System_Vax_Float_Operations,
- RE_Add_G => System_Vax_Float_Operations,
- RE_Div_F => System_Vax_Float_Operations,
- RE_Div_G => System_Vax_Float_Operations,
- RE_Mul_F => System_Vax_Float_Operations,
- RE_Mul_G => System_Vax_Float_Operations,
- RE_Neg_F => System_Vax_Float_Operations,
- RE_Neg_G => System_Vax_Float_Operations,
- RE_Return_D => System_Vax_Float_Operations,
- RE_Return_F => System_Vax_Float_Operations,
- RE_Return_G => System_Vax_Float_Operations,
- RE_Sub_F => System_Vax_Float_Operations,
- RE_Sub_G => System_Vax_Float_Operations,
-
- RE_Eq_F => System_Vax_Float_Operations,
- RE_Eq_G => System_Vax_Float_Operations,
- RE_Le_F => System_Vax_Float_Operations,
- RE_Le_G => System_Vax_Float_Operations,
- RE_Lt_F => System_Vax_Float_Operations,
- RE_Lt_G => System_Vax_Float_Operations,
- RE_Ne_F => System_Vax_Float_Operations,
- RE_Ne_G => System_Vax_Float_Operations,
-
- RE_Valid_D => System_Vax_Float_Operations,
- RE_Valid_F => System_Vax_Float_Operations,
- RE_Valid_G => System_Vax_Float_Operations,
-
RE_Version_String => System_Version_Control,
RE_Get_Version_String => System_Version_Control,
diff --git a/gcc/ada/s-auxdec.ads b/gcc/ada/s-auxdec.ads
index 6c585ccd92f..6ce87bd7f91 100644
--- a/gcc/ada/s-auxdec.ads
+++ b/gcc/ada/s-auxdec.ads
@@ -39,13 +39,7 @@ package System.Aux_DEC is
pragma Preelaborate;
subtype Short_Address is Address;
- -- In some versions of System.Aux_DEC, notably that for VMS on IA64, there
- -- are two address types (64-bit and 32-bit), and the name Short_Address
- -- is used for the short address form. To avoid difficulties (in regression
- -- tests and elsewhere) with units that reference Short_Address, it is
- -- provided for other targets as a synonym for the normal Address type,
- -- and, as in the case where the lengths are different, Address and
- -- Short_Address can be freely inter-converted.
+ -- For compatibility with systems having short and long addresses
type Integer_8 is range -2 ** (8 - 1) .. +2 ** (8 - 1) - 1;
for Integer_8'Size use 8;
@@ -112,7 +106,7 @@ package System.Aux_DEC is
type F_Float is digits 6;
type D_Float is digits 9;
type G_Float is digits 15;
- -- We provide the type names, but these will be IEEE, not VMS format
+ -- We provide the type names, but these will be IEEE format, not VAX format
-- Floating point type declarations for IEEE floating point data types
diff --git a/gcc/ada/s-fatgen.adb b/gcc/ada/s-fatgen.adb
index 259b9d1089f..01bb2b44a97 100644
--- a/gcc/ada/s-fatgen.adb
+++ b/gcc/ada/s-fatgen.adb
@@ -756,12 +756,7 @@ package body System.Fat_Gen is
-- Valid --
-----------
- -- Note: this routine does not work for VAX float. We compensate for this
- -- in Exp_Attr by using the Valid functions in Vax_Float_Operations rather
- -- than the corresponding instantiation of this function.
-
function Valid (X : not null access T) return Boolean is
-
IEEE_Emin : constant Integer := T'Machine_Emin - 1;
IEEE_Emax : constant Integer := T'Machine_Emax - 1;
diff --git a/gcc/ada/s-fatgen.ads b/gcc/ada/s-fatgen.ads
index 13e78850416..6c4e6f7b508 100644
--- a/gcc/ada/s-fatgen.ads
+++ b/gcc/ada/s-fatgen.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, 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- --
@@ -95,8 +95,6 @@ package System.Fat_Gen is
-- register, and the whole point of 'Valid is to prevent exceptions.
-- Note that the object of type T must have the natural alignment
-- for type T. See Unaligned_Valid for further discussion.
- --
- -- Note: this routine does not work for Vax_Float ???
function Unaligned_Valid (A : System.Address) return Boolean;
-- This version of Valid is used if the floating-point value to
@@ -114,8 +112,6 @@ package System.Fat_Gen is
-- not require strict alignment (e.g. the ia32/x86), since on a
-- target not requiring strict alignment, it is fine to pass a
-- non-aligned value to the standard Valid routine.
- --
- -- Note: this routine does not work for Vax_Float ???
private
pragma Inline (Machine);
diff --git a/gcc/ada/s-os_lib.adb b/gcc/ada/s-os_lib.adb
index 49d868f8620..8ea87f2699a 100644
--- a/gcc/ada/s-os_lib.adb
+++ b/gcc/ada/s-os_lib.adb
@@ -1851,6 +1851,7 @@ package body System.OS_Lib is
(Host_File : System.Address) return System.Address;
pragma Import
(C, To_Canonical_File_Spec, "__gnat_to_canonical_file_spec");
+ -- Convert possible foreign file syntax to canonical form
The_Name : String (1 .. Name'Length + 1);
Canonical_File_Addr : System.Address;
@@ -1978,19 +1979,19 @@ package body System.OS_Lib is
return "";
end if;
- -- First, convert VMS file spec to Unix file spec.
- -- If Name is not in VMS syntax, then this is equivalent
- -- to put Name at the beginning of Path_Buffer.
+ -- First, convert possible foreign file spec to Unix file spec. If no
+ -- conversion is required, all this does is put Name at the beginning
+ -- of Path_Buffer unchanged.
- VMS_Conversion : begin
+ File_Name_Conversion : begin
The_Name (1 .. Name'Length) := Name;
The_Name (The_Name'Last) := ASCII.NUL;
Canonical_File_Addr := To_Canonical_File_Spec (The_Name'Address);
Canonical_File_Len := Integer (CRTL.strlen (Canonical_File_Addr));
- -- If VMS syntax conversion has failed, return an empty string
- -- to indicate the failure.
+ -- If syntax conversion has failed, return an empty string to
+ -- indicate the failure.
if Canonical_File_Len = 0 then
return "";
@@ -2007,7 +2008,7 @@ package body System.OS_Lib is
End_Path := Canonical_File_Len;
Last := 1;
end;
- end VMS_Conversion;
+ end File_Name_Conversion;
-- Replace all '/' by Directory Separators (this is for Windows)
diff --git a/gcc/ada/s-shasto.ads b/gcc/ada/s-shasto.ads
index 0ef65cc59f2..51e49e8b543 100644
--- a/gcc/ada/s-shasto.ads
+++ b/gcc/ada/s-shasto.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 1998-2009, Free Software Foundation, Inc. --
+-- Copyright (C) 1998-2014, 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- --
@@ -36,10 +36,6 @@
-- provides a more general implementation not dedicated to file
-- storage.
--- This unit (and shared passive partitions) are supported on all
--- GNAT implementations except on OpenVMS (where problems arise from
--- trying to share files, and with version numbers of files)
-
-- --------------------------
-- -- Shared Storage Model --
-- --------------------------
diff --git a/gcc/ada/s-stalib.ads b/gcc/ada/s-stalib.ads
index 520fb3c92d1..c7f28fe1355 100644
--- a/gcc/ada/s-stalib.ads
+++ b/gcc/ada/s-stalib.ads
@@ -106,7 +106,6 @@ package System.Standard_Library is
Lang : Character;
-- A character indicating the language raising the exception.
-- Set to "A" for exceptions defined by an Ada program.
- -- Set to "V" for imported VMS exceptions.
-- Set to "C" for imported C++ exceptions.
Name_Length : Natural;
@@ -122,9 +121,8 @@ package System.Standard_Library is
-- identities and names.
Foreign_Data : Address;
- -- Data for imported exceptions. This represents the exception code
- -- for the handling of Import/Export_Exception for the VMS case.
- -- This represents the address of the RTTI for the C++ case.
+ -- Data for imported exceptions. Not used in the Ada case. This
+ -- represents the address of the RTTI for the C++ case.
Raise_Hook : Raise_Action;
-- This field can be used to place a "hook" on an exception. If the
diff --git a/gcc/ada/sem.adb b/gcc/ada/sem.adb
index 0da096ea7e1..eb3501ed3a6 100644
--- a/gcc/ada/sem.adb
+++ b/gcc/ada/sem.adb
@@ -1482,13 +1482,7 @@ package body Sem is
null;
else
- -- Initialize if first time
-
- if No (Comp_Unit_List) then
- Comp_Unit_List := New_Elmt_List;
- end if;
-
- Append_Elmt (Comp_Unit, Comp_Unit_List);
+ Append_New_Elmt (Comp_Unit, To => Comp_Unit_List);
if Debug_Unit_Walk then
Write_Str ("Appending ");
diff --git a/gcc/ada/sem_attr.adb b/gcc/ada/sem_attr.adb
index e0d2d9eec72..599212facb0 100644
--- a/gcc/ada/sem_attr.adb
+++ b/gcc/ada/sem_attr.adb
@@ -6264,11 +6264,7 @@ package body Sem_Attr is
-- Mark this component as processed
else
- if No (Comps) then
- Comps := New_Elmt_List;
- end if;
-
- Append_Elmt (Comp_Or_Discr, Comps);
+ Append_New_Elmt (Comp_Or_Discr, Comps);
end if;
end if;
@@ -6787,9 +6783,6 @@ package body Sem_Attr is
-- Computes the Fore value for the current attribute prefix, which is
-- known to be a static fixed-point type. Used by Fore and Width.
- function Is_VAX_Float (Typ : Entity_Id) return Boolean;
- -- Determine whether Typ denotes a VAX floating point type
-
function Mantissa return Uint;
-- Returns the Mantissa value for the prefix type
@@ -6921,16 +6914,6 @@ package body Sem_Attr is
return R;
end Fore_Value;
- ------------------
- -- Is_VAX_Float --
- ------------------
-
- function Is_VAX_Float (Typ : Entity_Id) return Boolean is
- pragma Unreferenced (Typ);
- begin
- return False;
- end Is_VAX_Float;
-
--------------
-- Mantissa --
--------------
@@ -7953,16 +7936,6 @@ package body Sem_Attr is
Fold_Uint (N, Expr_Value (Lo_Bound), Static);
end if;
- -- Replace VAX Float_Type'First with a reference to the temporary
- -- which represents the low bound of the type. This transformation
- -- is needed since the back end cannot evaluate 'First on VAX.
-
- elsif Is_VAX_Float (P_Type)
- and then Nkind (Lo_Bound) = N_Identifier
- then
- Rewrite (N, New_Occurrence_Of (Entity (Lo_Bound), Sloc (N)));
- Analyze (N);
-
else
Check_Concurrent_Discriminant (Lo_Bound);
end if;
@@ -8206,16 +8179,6 @@ package body Sem_Attr is
Fold_Uint (N, Expr_Value (Hi_Bound), Static);
end if;
- -- Replace VAX Float_Type'Last with a reference to the temporary
- -- which represents the high bound of the type. This transformation
- -- is needed since the back end cannot evaluate 'Last on VAX.
-
- elsif Is_VAX_Float (P_Type)
- and then Nkind (Hi_Bound) = N_Identifier
- then
- Rewrite (N, New_Occurrence_Of (Entity (Hi_Bound), Sloc (N)));
- Analyze (N);
-
else
Check_Concurrent_Discriminant (Hi_Bound);
end if;
diff --git a/gcc/ada/sem_ch12.adb b/gcc/ada/sem_ch12.adb
index 792757065d6..a776894aeac 100644
--- a/gcc/ada/sem_ch12.adb
+++ b/gcc/ada/sem_ch12.adb
@@ -1751,9 +1751,7 @@ package body Sem_Ch12 is
-- If this is a nested generic, preserve default for later
-- instantiations.
- if No (Match)
- and then Box_Present (Formal)
- then
+ if No (Match) and then Box_Present (Formal) then
Append_Elmt
(Defining_Unit_Name (Specification (Last (Assoc))),
Default_Actuals);
@@ -8919,12 +8917,7 @@ package body Sem_Ch12 is
and then Remove_Suffix (Prim_A, 'P') = Chars (Prim_G)
then
Set_Chars (Prim_A, Chars (Prim_G));
-
- if List = No_Elist then
- List := New_Elmt_List;
- end if;
-
- Append_Elmt (Prim_A, List);
+ Append_New_Elmt (Prim_A, To => List);
end if;
Next_Elmt (Prim_A_Elmt);
diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb
index 54f8f230fa6..586a84e1e5e 100644
--- a/gcc/ada/sem_prag.adb
+++ b/gcc/ada/sem_prag.adb
@@ -326,11 +326,7 @@ package body Sem_Prag is
procedure Add_Item (Item : Entity_Id; To_List : in out Elist_Id) is
begin
- if No (To_List) then
- To_List := New_Elmt_List;
- end if;
-
- Append_Elmt (Item, To_List);
+ Append_New_Elmt (Item, To => To_List);
end Add_Item;
-------------------------------
@@ -3248,8 +3244,7 @@ package body Sem_Prag is
Arg_Parameter_Types : Node_Id;
Arg_Result_Type : Node_Id := Empty;
Arg_Mechanism : Node_Id;
- Arg_Result_Mechanism : Node_Id := Empty;
- Arg_First_Optional_Parameter : Node_Id := Empty);
+ Arg_Result_Mechanism : Node_Id := Empty);
-- Common processing for all extended Import and Export pragmas applying
-- to subprograms. The caller omits any arguments that do not apply to
-- the pragma in question (for example, Arg_Result_Type can be non-Empty
@@ -7309,13 +7304,8 @@ package body Sem_Prag is
Arg_Parameter_Types : Node_Id;
Arg_Result_Type : Node_Id := Empty;
Arg_Mechanism : Node_Id;
- Arg_Result_Mechanism : Node_Id := Empty;
- Arg_First_Optional_Parameter : Node_Id := Empty)
+ Arg_Result_Mechanism : Node_Id := Empty)
is
- pragma Unreferenced (Arg_First_Optional_Parameter);
- -- We ignore the First_Optional_Parameter argument. It was only
- -- relevant for VMS anyway, and otherwise ignored.
-
Ent : Entity_Id;
Def_Id : Entity_Id;
Hom_Id : Entity_Id;
@@ -9317,9 +9307,9 @@ package body Sem_Prag is
if Warn_On_Export_Import
-- Only do this for something that was in the source. Not
- -- clear if this can be False now (there used for sure to
- -- be cases on VMS where it was False), but anyway the test
- -- is harmless if not needed, so it is retained.
+ -- clear if this can be False now (there used for sure to be
+ -- cases on some systems where it was False), but anyway the
+ -- test is harmless if not needed, so it is retained.
and then Comes_From_Source (Arg)
then
@@ -13535,9 +13525,6 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Export_Function => Export_Function : declare
Args : Args_List (1 .. 6);
@@ -13599,9 +13586,6 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Export_Object => Export_Object : declare
Args : Args_List (1 .. 3);
@@ -13655,9 +13639,6 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Export_Procedure => Export_Procedure : declare
Args : Args_List (1 .. 4);
@@ -13733,9 +13714,6 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Export_Valued_Procedure =>
Export_Valued_Procedure : declare
@@ -14071,10 +14049,8 @@ package body Sem_Prag is
-- pragma Ident (static_string_EXPRESSION)
- -- Note: pragma Comment shares this processing. Pragma Comment is
- -- identical to Ident, except that the restriction of the argument to
- -- 31 characters and the placement restrictions are not enforced for
- -- pragma Comment.
+ -- Note: pragma Comment shares this processing. Pragma Ident is
+ -- identical in effect to pragma Commment.
when Pragma_Ident | Pragma_Comment => Ident : declare
Str : Node_Id;
@@ -14086,13 +14062,6 @@ package body Sem_Prag is
Check_Arg_Is_OK_Static_Expression (Arg1, Standard_String);
Store_Note (N);
- -- For pragma Ident, preserve DEC compatibility by requiring the
- -- pragma to appear in a declarative part or package spec.
-
- if Prag_Id = Pragma_Ident then
- Check_Is_In_Decl_Part_Or_Package_Spec;
- end if;
-
Str := Expr_Value_S (Get_Pragma_Arg (Arg1));
declare
@@ -14116,15 +14085,10 @@ package body Sem_Prag is
if Present (CS) then
- -- For Ident, we do not permit multiple instances
-
- if Prag_Id = Pragma_Ident then
- Error_Pragma ("duplicate% pragma not permitted");
-
- -- For Comment, we concatenate the string, unless we want
- -- to preserve the tree structure for ASIS.
+ -- If we have multiple instances, concatenate them, but
+ -- not in ASIS, where we want the original tree.
- elsif not ASIS_Mode then
+ if not ASIS_Mode then
Start_String (Strval (CS));
Store_String_Char (' ');
Store_String_Chars (Strval (Str));
@@ -14141,15 +14105,6 @@ package body Sem_Prag is
elsif Nkind (GP) = N_Subunit then
null;
-
- -- Otherwise we have a misplaced pragma Ident, but we ignore
- -- this if we are in an instantiation, since it comes from
- -- a generic, and has no relevance to the instantiation.
-
- elsif Prag_Id = Pragma_Ident then
- if Instantiation_Location (Loc) = No_Location then
- Error_Pragma ("pragma% only allowed at outer level");
- end if;
end if;
end;
end Ident;
@@ -14338,8 +14293,7 @@ package body Sem_Prag is
-- [, [Parameter_Types =>] (PARAMETER_TYPES)]
-- [, [Result_Type =>] SUBTYPE_MARK]
-- [, [Mechanism =>] MECHANISM]
- -- [, [Result_Mechanism =>] MECHANISM_NAME]
- -- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ -- [, [Result_Mechanism =>] MECHANISM_NAME]);
-- EXTERNAL_SYMBOL ::=
-- IDENTIFIER
@@ -14363,20 +14317,16 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Import_Function => Import_Function : declare
- Args : Args_List (1 .. 7);
- Names : constant Name_List (1 .. 7) := (
+ Args : Args_List (1 .. 6);
+ Names : constant Name_List (1 .. 6) := (
Name_Internal,
Name_External,
Name_Parameter_Types,
Name_Result_Type,
Name_Mechanism,
- Name_Result_Mechanism,
- Name_First_Optional_Parameter);
+ Name_Result_Mechanism);
Internal : Node_Id renames Args (1);
External : Node_Id renames Args (2);
@@ -14384,7 +14334,6 @@ package body Sem_Prag is
Result_Type : Node_Id renames Args (4);
Mechanism : Node_Id renames Args (5);
Result_Mechanism : Node_Id renames Args (6);
- First_Optional_Parameter : Node_Id renames Args (7);
begin
GNAT_Pragma;
@@ -14395,8 +14344,7 @@ package body Sem_Prag is
Arg_Parameter_Types => Parameter_Types,
Arg_Result_Type => Result_Type,
Arg_Mechanism => Mechanism,
- Arg_Result_Mechanism => Result_Mechanism,
- Arg_First_Optional_Parameter => First_Optional_Parameter);
+ Arg_Result_Mechanism => Result_Mechanism);
end Import_Function;
-------------------
@@ -14440,8 +14388,7 @@ package body Sem_Prag is
-- [Internal =>] LOCAL_NAME
-- [, [External =>] EXTERNAL_SYMBOL]
-- [, [Parameter_Types =>] (PARAMETER_TYPES)]
- -- [, [Mechanism =>] MECHANISM]
- -- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ -- [, [Mechanism =>] MECHANISM]);
-- EXTERNAL_SYMBOL ::=
-- IDENTIFIER
@@ -14465,24 +14412,19 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Import_Procedure => Import_Procedure : declare
- Args : Args_List (1 .. 5);
- Names : constant Name_List (1 .. 5) := (
+ Args : Args_List (1 .. 4);
+ Names : constant Name_List (1 .. 4) := (
Name_Internal,
Name_External,
Name_Parameter_Types,
- Name_Mechanism,
- Name_First_Optional_Parameter);
+ Name_Mechanism);
Internal : Node_Id renames Args (1);
External : Node_Id renames Args (2);
Parameter_Types : Node_Id renames Args (3);
Mechanism : Node_Id renames Args (4);
- First_Optional_Parameter : Node_Id renames Args (5);
begin
GNAT_Pragma;
@@ -14491,8 +14433,7 @@ package body Sem_Prag is
Arg_Internal => Internal,
Arg_External => External,
Arg_Parameter_Types => Parameter_Types,
- Arg_Mechanism => Mechanism,
- Arg_First_Optional_Parameter => First_Optional_Parameter);
+ Arg_Mechanism => Mechanism);
end Import_Procedure;
-----------------------------
@@ -14503,8 +14444,7 @@ package body Sem_Prag is
-- [Internal =>] LOCAL_NAME
-- [, [External =>] EXTERNAL_SYMBOL]
-- [, [Parameter_Types =>] (PARAMETER_TYPES)]
- -- [, [Mechanism =>] MECHANISM]
- -- [, [First_Optional_Parameter =>] IDENTIFIER]);
+ -- [, [Mechanism =>] MECHANISM]);
-- EXTERNAL_SYMBOL ::=
-- IDENTIFIER
@@ -14528,25 +14468,20 @@ package body Sem_Prag is
-- MECHANISM_NAME ::=
-- Value
-- | Reference
- -- | Descriptor [([Class =>] CLASS_NAME)]
-
- -- CLASS_NAME ::= ubs | ubsb | uba | s | sb | a | nca
when Pragma_Import_Valued_Procedure =>
Import_Valued_Procedure : declare
- Args : Args_List (1 .. 5);
- Names : constant Name_List (1 .. 5) := (
+ Args : Args_List (1 .. 4);
+ Names : constant Name_List (1 .. 4) := (
Name_Internal,
Name_External,
Name_Parameter_Types,
- Name_Mechanism,
- Name_First_Optional_Parameter);
+ Name_Mechanism);
Internal : Node_Id renames Args (1);
External : Node_Id renames Args (2);
Parameter_Types : Node_Id renames Args (3);
Mechanism : Node_Id renames Args (4);
- First_Optional_Parameter : Node_Id renames Args (5);
begin
GNAT_Pragma;
@@ -14555,8 +14490,7 @@ package body Sem_Prag is
Arg_Internal => Internal,
Arg_External => External,
Arg_Parameter_Types => Parameter_Types,
- Arg_Mechanism => Mechanism,
- Arg_First_Optional_Parameter => First_Optional_Parameter);
+ Arg_Mechanism => Mechanism);
end Import_Valued_Procedure;
-----------------
@@ -18910,11 +18844,12 @@ package body Sem_Prag is
-- pragma Short_Descriptors;
+ -- Recognize and validate, but otherwise ignore
+
when Pragma_Short_Descriptors =>
GNAT_Pragma;
Check_Arg_Count (0);
Check_Valid_Configuration_Pragma;
- Short_Descriptors := True;
------------------------------
-- Simple_Storage_Pool_Type --
@@ -25354,7 +25289,7 @@ package body Sem_Prag is
Set_Body_References (State_Id, New_Elmt_List);
end if;
- Append_Elmt (Ref, Body_References (State_Id));
+ Append_Elmt (Ref, To => Body_References (State_Id));
exit;
end if;
end if;
diff --git a/gcc/ada/sem_prag.ads b/gcc/ada/sem_prag.ads
index a97595c0f4d..4d6b1c0407e 100644
--- a/gcc/ada/sem_prag.ads
+++ b/gcc/ada/sem_prag.ads
@@ -262,13 +262,11 @@ package Sem_Prag is
-- dealing with subprogram body stubs or expression functions.
procedure Set_Encoded_Interface_Name (E : Entity_Id; S : Node_Id);
- -- This routine is used to set an encoded interface name. The node S is an
- -- N_String_Literal node for the external name to be set, and E is an
+ -- This routine is used to set an encoded interface name. The node S is
+ -- an N_String_Literal node for the external name to be set, and E is an
-- entity whose Interface_Name field is to be set. In the normal case where
-- S contains a name that is a valid C identifier, then S is simply set as
- -- the value of the Interface_Name. Otherwise it is encoded. See the body
- -- for details of the encoding. This encoding is only done on VMS systems,
- -- since it seems pretty silly, but is needed to pass some dubious tests in
- -- the test suite.
+ -- the value of the Interface_Name. Otherwise it is encoded as needed by
+ -- particular operating systems. See the body for details of the encoding.
end Sem_Prag;
diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb
index f460898e5de..44435ca0812 100644
--- a/gcc/ada/sem_util.adb
+++ b/gcc/ada/sem_util.adb
@@ -1875,11 +1875,7 @@ package body Sem_Util is
return Abandon;
end if;
- if Writable_Actuals_List = No_Elist then
- Writable_Actuals_List := New_Elmt_List;
- end if;
-
- Append_Elmt (N, Writable_Actuals_List);
+ Append_New_Elmt (N, To => Writable_Actuals_List);
else
if Identifiers_List = No_Elist then
@@ -6128,9 +6124,7 @@ package body Sem_Util is
declare
Comp : constant Entity_Id := Defining_Identifier (Comp_Item);
begin
- if not Is_Tag (Comp)
- and then Chars (Comp) /= Name_uParent
- then
+ if not Is_Tag (Comp) and then Chars (Comp) /= Name_uParent then
Append_Elmt (Comp, Into);
end if;
end;
@@ -7410,9 +7404,7 @@ package body Sem_Util is
function Has_Denormals (E : Entity_Id) return Boolean is
begin
- return Is_Floating_Point_Type (E)
- and then Denorm_On_Target
- and then not Vax_Float (E);
+ return Is_Floating_Point_Type (E) and then Denorm_On_Target;
end Has_Denormals;
-------------------------------------------
@@ -8369,9 +8361,7 @@ package body Sem_Util is
function Has_Signed_Zeros (E : Entity_Id) return Boolean is
begin
- return Is_Floating_Point_Type (E)
- and then Signed_Zeros_On_Target
- and then not Vax_Float (E);
+ return Is_Floating_Point_Type (E) and then Signed_Zeros_On_Target;
end Has_Signed_Zeros;
-----------------------------
diff --git a/gcc/ada/snames.ads-tmpl b/gcc/ada/snames.ads-tmpl
index 12ff465269d..14cf1e265c4 100644
--- a/gcc/ada/snames.ads-tmpl
+++ b/gcc/ada/snames.ads-tmpl
@@ -342,10 +342,6 @@ package Snames is
-- Ada 83, Ada 95, and Ada 2005 mode as well, where they are technically
-- considered to be implementation dependent pragmas.
- -- The entries marked VMS are VMS specific pragmas that are recognized only
- -- in OpenVMS versions of GNAT. They are ignored in other versions with an
- -- appropriate warning.
-
-- The entries marked AAMP are AAMP specific pragmas that are recognized
-- only in GNAT for the AAMP. They are ignored in other versions with
-- appropriate warnings.
@@ -579,7 +575,7 @@ package Snames is
-- pragma.
Name_Provide_Shift_Operators : constant Name_Id := N + $; -- GNAT
- Name_Psect_Object : constant Name_Id := N + $; -- VMS
+ Name_Psect_Object : constant Name_Id := N + $; -- GNAT
Name_Pure : constant Name_Id := N + $;
Name_Pure_Function : constant Name_Id := N + $; -- GNAT
Name_Refined_Depends : constant Name_Id := N + $; -- GNAT
@@ -614,7 +610,7 @@ package Snames is
Name_Test_Case : constant Name_Id := N + $; -- GNAT
Name_Task_Info : constant Name_Id := N + $; -- GNAT
Name_Task_Name : constant Name_Id := N + $; -- GNAT
- Name_Task_Storage : constant Name_Id := N + $; -- VMS
+ Name_Task_Storage : constant Name_Id := N + $; -- GNAT
Name_Thread_Local_Storage : constant Name_Id := N + $; -- GNAT
Name_Time_Slice : constant Name_Id := N + $; -- GNAT
Name_Title : constant Name_Id := N + $; -- GNAT
diff --git a/gcc/ada/stand.ads b/gcc/ada/stand.ads
index 6bcd8cbeb75..e93e9b4b89b 100644
--- a/gcc/ada/stand.ads
+++ b/gcc/ada/stand.ads
@@ -443,8 +443,7 @@ package Stand is
-- Entity for universal real type. The bounds of this type correspond to
-- to the largest supported real type (i.e. Long_Long_Float). It is the
-- type used for runtime calculations in type universal real. Note that
- -- this type is always IEEE format, even if Long_Long_Float is Vax_Float
- -- (and in that case the bounds don't correspond exactly).
+ -- this type is always IEEE format.
Universal_Fixed : Entity_Id;
-- Entity for universal fixed type. This is a type with arbitrary
diff --git a/gcc/ada/switch-b.adb b/gcc/ada/switch-b.adb
index db6407abd72..880540eca3e 100644
--- a/gcc/ada/switch-b.adb
+++ b/gcc/ada/switch-b.adb
@@ -262,20 +262,6 @@ package body Switch.B is
Ptr := Ptr + 1;
Usage_Requested := True;
- -- Processing for H switch
-
- when 'H' =>
- if Ptr = Max then
- Bad_Switch (Switch_Chars);
- end if;
-
- Ptr := Ptr + 1;
- Scan_Nat (Switch_Chars, Max, Ptr, Heap_Size, C);
-
- if Heap_Size /= 32 and then Heap_Size /= 64 then
- Bad_Switch (Switch_Chars);
- end if;
-
-- Processing for i switch
when 'i' =>
diff --git a/gcc/ada/system.ads b/gcc/ada/system.ads
index 7f6f13b1a1e..9206c1f685d 100644
--- a/gcc/ada/system.ads
+++ b/gcc/ada/system.ads
@@ -7,7 +7,7 @@
-- S p e c --
-- (Compiler Version) --
-- --
--- Copyright (C) 1992-2013, Free Software Foundation, Inc. --
+-- Copyright (C) 1992-2014, Free Software Foundation, Inc. --
-- --
-- This specification is derived from the Ada Reference Manual for use with --
-- GNAT. The copyright notice above, and the license provisions that follow --
@@ -148,7 +148,6 @@ private
Frontend_Layout : constant Boolean := False;
Machine_Overflows : constant Boolean := False;
Machine_Rounds : constant Boolean := True;
- OpenVMS : constant Boolean := False;
Preallocated_Stacks : constant Boolean := False;
Signed_Zeros : constant Boolean := True;
Stack_Check_Default : constant Boolean := False;
diff --git a/gcc/ada/targparm.adb b/gcc/ada/targparm.adb
index b161466c417..84ed2028d6e 100644
--- a/gcc/ada/targparm.adb
+++ b/gcc/ada/targparm.adb
@@ -67,8 +67,6 @@ package body Targparm is
SNZ, -- Signed_Zeros
SSL, -- Suppress_Standard_Library
UAM, -- Use_Ada_Main_Program_Name
- VMS, -- OpenVMS
- VXF, -- VAX Float
ZCD); -- ZCX_By_Default
Targparm_Flags : array (Targparm_Tags) of Boolean := (others => False);
@@ -105,8 +103,6 @@ package body Targparm is
SNZ_Str : aliased constant Source_Buffer := "Signed_Zeros";
SSL_Str : aliased constant Source_Buffer := "Suppress_Standard_Library";
UAM_Str : aliased constant Source_Buffer := "Use_Ada_Main_Program_Name";
- VMS_Str : aliased constant Source_Buffer := "OpenVMS";
- VXF_Str : aliased constant Source_Buffer := "VAX_Float";
ZCD_Str : aliased constant Source_Buffer := "ZCX_By_Default";
-- The following defines a set of pointers to the above strings,
@@ -143,8 +139,6 @@ package body Targparm is
SNZ_Str'Access,
SSL_Str'Access,
UAM_Str'Access,
- VMS_Str'Access,
- VXF_Str'Access,
ZCD_Str'Access);
-----------------------
@@ -678,8 +672,6 @@ package body Targparm is
when SSL => Suppress_Standard_Library_On_Target := Result;
when SNZ => Signed_Zeros_On_Target := Result;
when UAM => Use_Ada_Main_Program_Name_On_Target := Result;
- when VMS => OpenVMS_On_Target := Result;
- when VXF => VAX_Float_On_Target := Result;
when ZCD => ZCX_By_Default_On_Target := Result;
goto Line_Loop_Continue;
diff --git a/gcc/ada/targparm.ads b/gcc/ada/targparm.ads
index 21f2d6db416..2fcc9a36005 100644
--- a/gcc/ada/targparm.ads
+++ b/gcc/ada/targparm.ads
@@ -179,13 +179,13 @@ package Targparm is
-- The default values here are used if no value is found in system.ads.
-- This should normally happen if the special version of system.ads used
- -- by the compiler itself is in use or if the value is only relevant to
- -- a particular target (e.g. OpenVMS, AAMP). The default values are
- -- suitable for use in normal environments. This approach allows the
- -- possibility of new versions of the compiler (possibly with new system
- -- parameters added) being used to compile older versions of the compiler
- -- sources, as well as avoiding duplicating values in all system-*.ads
- -- files for flags that are used on a few platforms only.
+ -- by the compiler itself is in use or if the value is only relevant to a
+ -- particular target (e.g. AAMP). The default values are suitable for use
+ -- in normal environments. This approach allows the possibility of new
+ -- versions of the compiler (possibly with new system parameters added)
+ -- being used to compile older versions of the compiler sources, as well as
+ -- avoiding duplicating values in all system-*.ads files for flags that are
+ -- used on a few platforms only.
-- All these parameters should be regarded as read only by all clients
-- of the package. The only way they get modified is by calling the