summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorcharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2015-10-20 12:21:37 +0000
committercharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2015-10-20 12:21:37 +0000
commit136298d5b687e8447705190bd48f00e4f0c6913c (patch)
treec36d888547dab7791e17fd4bfe05b11f59fb05c4 /gcc
parent49d539cdd72e395c3454b800c44d779099e3d43b (diff)
downloadgcc-136298d5b687e8447705190bd48f00e4f0c6913c.tar.gz
2015-10-20 Steve Baird <baird@adacore.com>
* pprint.adb: Code clean up. 2015-10-20 Bob Duff <duff@adacore.com> * a-cfinve.ads, a-coboho.ads: Improve comments. * a-coboho.adb (Size_In_Storage_Elements): Improve error message in case of "Size is too big" exception. 2015-10-20 Bob Duff <duff@adacore.com> * a-contai.ads: Remove check names (moved to snames.ads-tmpl). * snames.ads-tmpl: Add check names that were previously in a-contai.ads, so they are now visible in configuration files. * types.ads: Add checks corresponding to snames.ads-tmpl. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@229069 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/ChangeLog17
-rw-r--r--gcc/ada/a-cfinve.ads8
-rw-r--r--gcc/ada/a-coboho.adb36
-rw-r--r--gcc/ada/a-coboho.ads13
-rw-r--r--gcc/ada/a-contai.ads9
-rw-r--r--gcc/ada/pprint.adb2
-rw-r--r--gcc/ada/snames.ads-tmpl2
-rw-r--r--gcc/ada/types.ads4
8 files changed, 61 insertions, 30 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index aa6d6ee6fa5..ea3417e9e1b 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,20 @@
+2015-10-20 Steve Baird <baird@adacore.com>
+
+ * pprint.adb: Code clean up.
+
+2015-10-20 Bob Duff <duff@adacore.com>
+
+ * a-cfinve.ads, a-coboho.ads: Improve comments.
+ * a-coboho.adb (Size_In_Storage_Elements): Improve error message
+ in case of "Size is too big" exception.
+
+2015-10-20 Bob Duff <duff@adacore.com>
+
+ * a-contai.ads: Remove check names (moved to snames.ads-tmpl).
+ * snames.ads-tmpl: Add check names that were previously in
+ a-contai.ads, so they are now visible in configuration files.
+ * types.ads: Add checks corresponding to snames.ads-tmpl.
+
2015-10-20 Ed Schonberg <schonberg@adacore.com>
* sem_ch5.adb (Analyze_Loop_Statement): Attach generated loop
diff --git a/gcc/ada/a-cfinve.ads b/gcc/ada/a-cfinve.ads
index 2fef4af7856..17f6f7c22d0 100644
--- a/gcc/ada/a-cfinve.ads
+++ b/gcc/ada/a-cfinve.ads
@@ -41,8 +41,12 @@ generic
type Element_Type (<>) is private;
Max_Size_In_Storage_Elements : Natural :=
Element_Type'Max_Size_In_Storage_Elements;
- -- This has the same meaning as in Ada.Containers.Bounded_Holders, with the
- -- same restrictions.
+ -- Maximum size of Vector elements in bytes. This has the same meaning as
+ -- in Ada.Containers.Bounded_Holders, with the same restrictions. Note that
+ -- setting this too small can lead to erroneous execution; see comments in
+ -- Ada.Containers.Bounded_Holders. If Element_Type is class-wide, it is the
+ -- responsibility of clients to calculate the maximum size of all types in
+ -- the class.
with function "=" (Left, Right : Element_Type) return Boolean is <>;
diff --git a/gcc/ada/a-coboho.adb b/gcc/ada/a-coboho.adb
index 4ea0fa047aa..590e807dd32 100644
--- a/gcc/ada/a-coboho.adb
+++ b/gcc/ada/a-coboho.adb
@@ -6,7 +6,7 @@
-- --
-- B o d y --
-- --
--- Copyright (C) 2014, Free Software Foundation, Inc. --
+-- Copyright (C) 2015, 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- --
@@ -26,24 +26,34 @@
------------------------------------------------------------------------------
with Unchecked_Conversion;
-with Ada.Assertions; use Ada.Assertions;
package body Ada.Containers.Bounded_Holders is
pragma Annotate (CodePeer, Skip_Analysis);
- function Size_In_Storage_Elements (Element : Element_Type) return Natural is
- (Element'Size / System.Storage_Unit)
- with Pre =>
- (Element'Size mod System.Storage_Unit = 0 or else
- raise Assertion_Error with "Size must be a multiple of Storage_Unit")
- and then
- (Element'Size / System.Storage_Unit <= Max_Size_In_Storage_Elements
- or else raise Assertion_Error with "Size is too big");
+ function Size_In_Storage_Elements (Element : Element_Type) return Natural;
-- This returns the size of Element in storage units. It raises an
-- exception if the size is not a multiple of Storage_Unit, or if the size
-- is too big.
+ ------------------------------
+ -- Size_In_Storage_Elements --
+ ------------------------------
+
+ function Size_In_Storage_Elements (Element : Element_Type) return Natural is
+ Max_Size : Natural renames Max_Size_In_Storage_Elements;
+
+ begin
+ return S : constant Natural := Element'Size / System.Storage_Unit do
+ pragma Assert
+ (Element'Size mod System.Storage_Unit = 0,
+ "Size must be a multiple of Storage_Unit");
+
+ pragma Assert
+ (S <= Max_Size, "Size is too big:" & S'Img & " >" & Max_Size'Img);
+ end return;
+ end Size_In_Storage_Elements;
+
function Cast is new
Unchecked_Conversion (System.Address, Element_Access);
@@ -65,9 +75,9 @@ package body Ada.Containers.Bounded_Holders is
return Cast (Container'Address).all;
end Get;
- ---------------------
- -- Replace_Element --
- ---------------------
+ ---------
+ -- Set --
+ ---------
procedure Set (Container : in out Holder; New_Item : Element_Type) is
Storage : Storage_Array
diff --git a/gcc/ada/a-coboho.ads b/gcc/ada/a-coboho.ads
index 7e6933e22de..8764410d407 100644
--- a/gcc/ada/a-coboho.ads
+++ b/gcc/ada/a-coboho.ads
@@ -6,7 +6,7 @@
-- --
-- S p e c --
-- --
--- Copyright (C) 2014, Free Software Foundation, Inc. --
+-- Copyright (C) 2015, 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 --
@@ -51,9 +51,14 @@ package Ada.Containers.Bounded_Holders is
--
-- Each object of type Holder is allocated Max_Size_In_Storage_Elements
-- bytes. If you try to create a holder from an object of type Element_Type
- -- that is too big, an exception is raised. This applies to To_Holder and
- -- Replace_Element. If you pass an Element_Type object that is smaller than
- -- Max_Size_In_Storage_Elements, it works fine, but some space is wasted.
+ -- that is too big, an exception is raised (assuming assertions are
+ -- enabled). This applies to To_Holder and Set. If you pass an Element_Type
+ -- object that is smaller than Max_Size_In_Storage_Elements, it works fine,
+ -- but some space is wasted.
+ --
+ -- NOTE: If assertions are disabled, and you try to use an Element that is
+ -- too big, execution is erroneous, and anything can happen, such as
+ -- overwriting arbitrary memory locations.
--
-- Element_Type must not be an unconstrained array type. It can be a
-- class-wide type or a type with non-defaulted discriminants.
diff --git a/gcc/ada/a-contai.ads b/gcc/ada/a-contai.ads
index 5ae53ff875d..be8a808747b 100644
--- a/gcc/ada/a-contai.ads
+++ b/gcc/ada/a-contai.ads
@@ -13,15 +13,6 @@
-- --
------------------------------------------------------------------------------
-pragma Check_Name (Container_Checks);
-pragma Check_Name (Tampering_Check);
--- The above checks are not in the Ada RM. They are added in order to allow
--- suppression of checks within containers packages. Suppressing
--- Tampering_Check suppresses the tampering checks and associated machinery,
--- which is very expensive. Suppressing Container_Checks suppresses
--- Tampering_Check as well as all the other (not-so-expensive) containers
--- checks.
-
package Ada.Containers is
pragma Pure;
diff --git a/gcc/ada/pprint.adb b/gcc/ada/pprint.adb
index 102611fa371..cc0bfe5f970 100644
--- a/gcc/ada/pprint.adb
+++ b/gcc/ada/pprint.adb
@@ -713,11 +713,11 @@ package body Pprint is
end loop;
declare
+ Scn : Source_Ptr := Original_Location (Sloc (Left));
End_Sloc : constant Source_Ptr :=
Original_Location (Sloc (Right));
Src : constant Source_Buffer_Ptr :=
Source_Text (Get_Source_File_Index (Scn));
- Scn : Source_Ptr := Original_Location (Sloc (Left));
begin
if Scn > End_Sloc then
diff --git a/gcc/ada/snames.ads-tmpl b/gcc/ada/snames.ads-tmpl
index 881f36589f8..c0860e48544 100644
--- a/gcc/ada/snames.ads-tmpl
+++ b/gcc/ada/snames.ads-tmpl
@@ -1105,6 +1105,8 @@ package Snames is
Name_Storage_Check : constant Name_Id := N + $;
Name_Tag_Check : constant Name_Id := N + $;
Name_Validity_Check : constant Name_Id := N + $; -- GNAT
+ Name_Container_Checks : constant Name_Id := N + $; -- GNAT
+ Name_Tampering_Check : constant Name_Id := N + $; -- GNAT
Name_All_Checks : constant Name_Id := N + $;
Last_Check_Name : constant Name_Id := N + $;
diff --git a/gcc/ada/types.ads b/gcc/ada/types.ads
index af772fa70fc..8b21b10ca4d 100644
--- a/gcc/ada/types.ads
+++ b/gcc/ada/types.ads
@@ -679,11 +679,13 @@ package Types is
Storage_Check : constant := 15;
Tag_Check : constant := 16;
Validity_Check : constant := 17;
+ Container_Checks : constant := 18;
+ Tampering_Check : constant := 19;
-- Values used to represent individual predefined checks (including the
-- setting of Atomic_Synchronization, which is implemented internally using
-- a "check" whose name is Atomic_Synchronization).
- All_Checks : constant := 18;
+ All_Checks : constant := 20;
-- Value used to represent All_Checks value
subtype Predefined_Check_Id is Check_Id range 1 .. All_Checks;