aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorBob Duff <duff@adacore.com>2021-03-01 17:35:17 -0500
committerPierre-Marie de Rodat <derodat@adacore.com>2021-06-15 06:19:18 -0400
commit5fdd694a74ca51b6f4fa2317c7527a1eaf1e7f57 (patch)
tree21ec37bbb9e0d534027ddb841af497646d8bb870 /gcc
parenta7cadd18606c9c3ce2776b6f876ca98849b24b84 (diff)
downloadgcc-5fdd694a74ca51b6f4fa2317c7527a1eaf1e7f57.zip
gcc-5fdd694a74ca51b6f4fa2317c7527a1eaf1e7f57.tar.gz
gcc-5fdd694a74ca51b6f4fa2317c7527a1eaf1e7f57.tar.bz2
[Ada] Variable-sized node types: improve error messages
gcc/ada/ * gen_il-gen.adb (To_Bit_Offset): Use 'Base to avoid overflow in computations in Last_Bit when Offset = 'Last. (Choose_Offset): Give a better error message when we run out of fields. In particular, point out that Gen_IL.Internals.Bit_Offset'Last needs to be increased.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ada/gen_il-gen.adb10
1 files changed, 6 insertions, 4 deletions
diff --git a/gcc/ada/gen_il-gen.adb b/gcc/ada/gen_il-gen.adb
index 6349841..3666289 100644
--- a/gcc/ada/gen_il-gen.adb
+++ b/gcc/ada/gen_il-gen.adb
@@ -860,9 +860,9 @@ package body Gen_IL.Gen is
function Field_Size (F : Field_Enum) return Bit_Offset is
(Field_Size (Field_Table (F).Field_Type));
- function To_Bit_Offset (F : Field_Enum; Offset : Field_Offset)
- return Bit_Offset is
- (Bit_Offset (Offset) * Field_Size (F));
+ function To_Bit_Offset (F : Field_Enum; Offset : Field_Offset'Base)
+ return Bit_Offset'Base is
+ (Bit_Offset'Base (Offset) * Field_Size (F));
function First_Bit (F : Field_Enum; Offset : Field_Offset)
return Bit_Offset is
(To_Bit_Offset (F, Offset));
@@ -964,7 +964,9 @@ package body Gen_IL.Gen is
end if;
end loop;
- raise Illegal with "No available field offset for " & Image (F);
+ raise Illegal with "No available field offset for " & Image (F) &
+ "; need to increase Gen_IL.Internals.Bit_Offset'Last (" &
+ Image (Gen_IL.Internals.Bit_Offset'Last) & " is too small)";
end Choose_Offset;
Num_Concrete_Have_Field : array (Field_Enum) of Type_Count :=