summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2012-12-05 11:02:24 +0000
committercharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2012-12-05 11:02:24 +0000
commitae60423327046b7005194bdb19f50dd50cb786f9 (patch)
tree58acd4c116ae1b2b68b9482f60b3681d1ea78517
parent17bfc2d67f8d6ad5831ae43a874e15ca0cc1dc60 (diff)
downloadgcc-ae60423327046b7005194bdb19f50dd50cb786f9.tar.gz
2012-12-05 Thomas Quinot <quinot@adacore.com>
* exp_dist.adb: Minor reformatting. 2012-12-05 Tristan Gingold <gingold@adacore.com> * Make-generated.in: Remove the VMS host specific part, as VMS compilers aren't built anymore on VMS. 2012-12-05 Thomas Quinot <quinot@adacore.com> * sem.adb, errout.ads, atree.adb, atree.ads (Check_Error_Detected): Only return quietly if a serious error of configurable run time violation has been found. 2012-12-05 Yannick Moy <moy@adacore.com> * sem_res.adb (Resolve_Type_Conversion): In Alfa_Mode, do not apply conversion checks. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@194205 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ada/ChangeLog20
-rw-r--r--gcc/ada/Make-generated.in21
-rw-r--r--gcc/ada/atree.adb7
-rw-r--r--gcc/ada/atree.ads14
-rw-r--r--gcc/ada/errout.ads7
-rw-r--r--gcc/ada/exp_dist.adb6
-rw-r--r--gcc/ada/sem.adb1
-rw-r--r--gcc/ada/sem_res.adb3
8 files changed, 52 insertions, 27 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 8f486e4d7d9..365039f0bf3 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,23 @@
+2012-12-05 Thomas Quinot <quinot@adacore.com>
+
+ * exp_dist.adb: Minor reformatting.
+
+2012-12-05 Tristan Gingold <gingold@adacore.com>
+
+ * Make-generated.in: Remove the VMS host specific part, as VMS
+ compilers aren't built anymore on VMS.
+
+2012-12-05 Thomas Quinot <quinot@adacore.com>
+
+ * sem.adb, errout.ads, atree.adb, atree.ads (Check_Error_Detected):
+ Only return quietly if a serious error of configurable run time
+ violation has been found.
+
+2012-12-05 Yannick Moy <moy@adacore.com>
+
+ * sem_res.adb (Resolve_Type_Conversion): In Alfa_Mode, do not apply
+ conversion checks.
+
2012-12-05 Ed Schonberg <schonberg@adacore.com>
* exp_ch5.adb (Expand_N_Assignment_Statement): Handle properly
diff --git a/gcc/ada/Make-generated.in b/gcc/ada/Make-generated.in
index 57160ce19b2..1ddd0b54c33 100644
--- a/gcc/ada/Make-generated.in
+++ b/gcc/ada/Make-generated.in
@@ -66,16 +66,6 @@ $(ADA_GEN_SUBDIR)/stamp-nmake: $(ADA_GEN_SUBDIR)/sinfo.ads $(ADA_GEN_SUBDIR)/nma
$(MOVE_IF_CHANGE) $(ADA_GEN_SUBDIR)/bldtools/nmake/nmake.adb $(ADA_GEN_SUBDIR)/nmake.adb
touch $(ADA_GEN_SUBDIR)/stamp-nmake
-ifeq ($(strip $(filter-out alpha64 ia64 dec hp vms% openvms% alphavms%,$(subst -, ,$(host)))),)
-OSCONS_CPP=../../../$(DECC) -E /comment=as_is -DNATIVE \
- -DTARGET='""$(target)""' s-oscons-tmplt.c
-
-OSCONS_EXTRACT=../../../$(DECC) -DNATIVE \
- -DTARGET='""$(target)""' s-oscons-tmplt.c ; \
- ld -o s-oscons-tmplt.exe s-oscons-tmplt.obj; \
- ./s-oscons-tmplt.exe > s-oscons-tmplt.s
-
-else
# GCC_FOR_TARGET has paths relative to the gcc directory, so we need to adjust
# for running it from $(ADA_GEN_SUBDIR)/bldtools/oscons
OSCONS_CC=`echo "$(GCC_FOR_TARGET)" \
@@ -83,7 +73,16 @@ OSCONS_CC=`echo "$(GCC_FOR_TARGET)" \
OSCONS_CPP=$(OSCONS_CC) $(GNATLIBCFLAGS) -E -C \
-DTARGET=\"$(target)\" s-oscons-tmplt.c > s-oscons-tmplt.i
OSCONS_EXTRACT=$(OSCONS_CC) -S s-oscons-tmplt.i
-endif
+
+# Note: if you need to build with a non-GNU compiler, you could adapt the
+# following definitions (written for VMS DEC-C)
+#OSCONS_CPP=../../../$(DECC) -E /comment=as_is -DNATIVE \
+# -DTARGET='""$(target)""' s-oscons-tmplt.c
+#
+#OSCONS_EXTRACT=../../../$(DECC) -DNATIVE \
+# -DTARGET='""$(target)""' s-oscons-tmplt.c ; \
+# ld -o s-oscons-tmplt.exe s-oscons-tmplt.obj; \
+# ./s-oscons-tmplt.exe > s-oscons-tmplt.s
$(ADA_GEN_SUBDIR)/s-oscons.ads : $(ADA_GEN_SUBDIR)/s-oscons-tmplt.c $(ADA_GEN_SUBDIR)/gsocket.h $(ADA_GEN_SUBDIR)/xoscons.adb $(ADA_GEN_SUBDIR)/xutil.ads $(ADA_GEN_SUBDIR)/xutil.adb
-$(MKDIR) $(ADA_GEN_SUBDIR)/bldtools/oscons
diff --git a/gcc/ada/atree.adb b/gcc/ada/atree.adb
index d51e85d300c..a5c80dc8e36 100644
--- a/gcc/ada/atree.adb
+++ b/gcc/ada/atree.adb
@@ -567,9 +567,12 @@ package body Atree is
procedure Check_Error_Detected is
begin
-- An anomaly has been detected which is assumed to be a consequence of
- -- a previous error. Raise an exception if no error found previously.
+ -- a previous serious error or configurable run time violation. Raise
+ -- an exception if no such error has been detected.
- if Total_Errors_Detected = 0 then
+ if Serious_Errors_Detected = 0
+ and then Configurable_Run_Time_Violations = 0
+ then
raise Program_Error;
end if;
end Check_Error_Detected;
diff --git a/gcc/ada/atree.ads b/gcc/ada/atree.ads
index 8c434db6625..ac27b3fbae3 100644
--- a/gcc/ada/atree.ads
+++ b/gcc/ada/atree.ads
@@ -302,12 +302,20 @@ package Atree is
-- Number of warnings detected. Initialized to zero at the start of
-- compilation. Initialized for -gnatVa use, see comment above.
+ Configurable_Run_Time_Violations : Nat := 0;
+ -- Count of configurable run time violations so far. This is used to
+ -- suppress certain cascaded error messages when we know that we may not
+ -- have fully expanded some items, due to high integrity violations (i.e.
+ -- the use of constructs not permitted by the library in use, or improper
+ -- constructs in No_Run_Time mode).
+
procedure Check_Error_Detected;
-- When an anomaly is found in the tree, many semantic routines silently
-- bail out, assuming that the anomaly was caused by a previously detected
- -- error. This routine should be called in these cases, and will raise an
- -- exception if no error has been detected. This ensure that the anomaly
- -- is never allowed to go unnoticed.
+ -- serious error (or configurable run time violation). This routine should
+ -- be called in these cases, and will raise an exception if no such error
+ -- has been detected. This ensure that the anomaly is never allowed to go
+ -- unnoticed.
-------------------------------
-- Default Setting of Fields --
diff --git a/gcc/ada/errout.ads b/gcc/ada/errout.ads
index 2c6ab7d4ddd..0f746d989cc 100644
--- a/gcc/ada/errout.ads
+++ b/gcc/ada/errout.ads
@@ -39,13 +39,6 @@ with System;
package Errout is
- Configurable_Run_Time_Violations : Nat := 0;
- -- Count of configurable run time violations so far. This is used to
- -- suppress certain cascaded error messages when we know that we may not
- -- have fully expanded some items, due to high integrity violations (i.e.
- -- the use of constructs not permitted by the library in use, or improper
- -- constructs in No_Run_Time mode).
-
Current_Error_Source_File : Source_File_Index
renames Err_Vars.Current_Error_Source_File;
-- Id of current messages. Used to post file name when unit changes. This
diff --git a/gcc/ada/exp_dist.adb b/gcc/ada/exp_dist.adb
index c2396c1e568..92aa4270057 100644
--- a/gcc/ada/exp_dist.adb
+++ b/gcc/ada/exp_dist.adb
@@ -10077,7 +10077,7 @@ package body Exp_Dist is
-- Integer types (walk back to the base type)
elsif U_Type = RTE (RE_Integer_8) then
- Lib_RE := RE_TC_I8;
+ Lib_RE := RE_TC_I8;
elsif U_Type = RTE (RE_Integer_16) then
Lib_RE := RE_TC_I16;
@@ -10188,7 +10188,7 @@ package body Exp_Dist is
-- Make a return statement that calls TC_Build with the given
-- typecode kind, and the constructed parameters list.
- procedure Return_Alias_TypeCode (Base_TypeCode : Node_Id);
+ procedure Return_Alias_TypeCode (Base_TypeCode : Node_Id);
-- Return a typecode that is a TC_Alias for the given typecode
--------------------------
@@ -10258,7 +10258,7 @@ package body Exp_Dist is
---------------------------
procedure Return_Alias_TypeCode
- (Base_TypeCode : Node_Id)
+ (Base_TypeCode : Node_Id)
is
begin
Add_TypeCode_Parameter (Base_TypeCode, Parameters);
diff --git a/gcc/ada/sem.adb b/gcc/ada/sem.adb
index f3577790f4c..95b69428704 100644
--- a/gcc/ada/sem.adb
+++ b/gcc/ada/sem.adb
@@ -27,7 +27,6 @@ with Atree; use Atree;
with Debug; use Debug;
with Debug_A; use Debug_A;
with Elists; use Elists;
-with Errout; use Errout;
with Expander; use Expander;
with Fname; use Fname;
with Lib; use Lib;
diff --git a/gcc/ada/sem_res.adb b/gcc/ada/sem_res.adb
index 64199fa2cf6..dd07b3062e9 100644
--- a/gcc/ada/sem_res.adb
+++ b/gcc/ada/sem_res.adb
@@ -9552,11 +9552,14 @@ package body Sem_Res is
-- Skip these type conversion checks if universal fixed operands
-- operands involved, since range checks are handled separately for
-- these cases (in the appropriate Expand routines in unit Exp_Fixd).
+ -- Also skip type conversion checks in formal verification mode, as the
+ -- formal verification backend deals directly with these checks.
if Nkind (N) = N_Type_Conversion
and then not Is_Generic_Type (Root_Type (Target_Typ))
and then Target_Typ /= Universal_Fixed
and then Operand_Typ /= Universal_Fixed
+ and then not Alfa_Mode
then
Apply_Type_Conversion_Checks (N);
end if;