aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorArnaud Charlet <charlet@adacore.com>2018-05-30 08:56:54 +0000
committerPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2018-05-30 08:56:54 +0000
commit88ad52c90d5aa992fbbcba44f91faccdc02150ef (patch)
tree3544e336a5da00b41c23294179f3959cb031291e /gcc
parent8ed508fe7fce89d1798a3cabf227d3e1c1d5cf85 (diff)
downloadgcc-88ad52c90d5aa992fbbcba44f91faccdc02150ef.zip
gcc-88ad52c90d5aa992fbbcba44f91faccdc02150ef.tar.gz
gcc-88ad52c90d5aa992fbbcba44f91faccdc02150ef.tar.bz2
[Ada] Ignore out of range values for System.Priority in CodePeer mode
2018-05-30 Arnaud Charlet <charlet@adacore.com> gcc/ada/ * checks.adb (Apply_Scalar_Range_Check): * sem_eval.adb (Check_Non_Static_Context, Out_Of_Range): Ignore out of range values for System.Priority in CodePeer mode since the actual target compiler may provide a wider range. From-SVN: r260929
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/ChangeLog7
-rw-r--r--gcc/ada/checks.adb11
-rw-r--r--gcc/ada/sem_eval.adb18
3 files changed, 31 insertions, 5 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 729caee..026d3ef 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,10 @@
+2018-05-30 Arnaud Charlet <charlet@adacore.com>
+
+ * checks.adb (Apply_Scalar_Range_Check):
+ * sem_eval.adb (Check_Non_Static_Context, Out_Of_Range): Ignore out of
+ range values for System.Priority in CodePeer mode since the actual
+ target compiler may provide a wider range.
+
2018-05-30 Ed Schonberg <schonberg@adacore.com>
* exp_unst.adb: Search specification of main unit as well, for
diff --git a/gcc/ada/checks.adb b/gcc/ada/checks.adb
index 9fb775f..8fc81e9 100644
--- a/gcc/ada/checks.adb
+++ b/gcc/ada/checks.adb
@@ -3065,7 +3065,16 @@ package body Checks is
-- If definitely not in range, warn
elsif Lov > Hi or else Hiv < Lo then
- Bad_Value;
+ -- Ignore out of range values for System.Priority in
+ -- CodePeer mode since the actual target compiler may
+ -- provide a wider range.
+
+ if not CodePeer_Mode
+ or else Target_Typ /= RTE (RE_Priority)
+ then
+ Bad_Value;
+ end if;
+
return;
-- Otherwise we don't know
diff --git a/gcc/ada/sem_eval.adb b/gcc/ada/sem_eval.adb
index 48e141d..b216dab 100644
--- a/gcc/ada/sem_eval.adb
+++ b/gcc/ada/sem_eval.adb
@@ -574,8 +574,16 @@ package body Sem_Eval is
null;
elsif Is_Out_Of_Range (N, T, Assume_Valid => True) then
- Apply_Compile_Time_Constraint_Error
- (N, "value not in range of}<<", CE_Range_Check_Failed);
+ -- Ignore out of range values for System.Priority in CodePeer
+ -- mode since the actual target compiler may provide a wider
+ -- range.
+
+ if CodePeer_Mode and then T = RTE (RE_Priority) then
+ Set_Do_Range_Check (N, False);
+ else
+ Apply_Compile_Time_Constraint_Error
+ (N, "value not in range of}<<", CE_Range_Check_Failed);
+ end if;
elsif Checks_On then
Enable_Range_Check (N);
@@ -5437,9 +5445,11 @@ package body Sem_Eval is
First_Rep_Item (Parent (N)));
Rewrite (N, Make_Integer_Literal (Sloc (N), Uint_1));
- -- All cases except the special array case
+ -- All cases except the special array case.
+ -- No message if we are dealing with System.Priority values in
+ -- CodePeer mode where the target runtime may have more priorities.
- else
+ elsif not CodePeer_Mode or else Etype (N) /= RTE (RE_Priority) then
Apply_Compile_Time_Constraint_Error
(N, "value not in range of}", CE_Range_Check_Failed);
end if;