Commit 6128aad4 by Arnaud Charlet

[multiple changes]

2014-07-18  Thomas Quinot  <quinot@adacore.com>

	* g-memdum.adb, g-memdum.ads (Dump): New parameter Prefix, defaulted
	to Absolute_Address.

2014-07-18  Eric Botcazou  <ebotcazou@adacore.com>

	* opt.ads (Suppress_Back_Annotation): Remove as unused.
	* fe.h (Back_Annotate_Rep_Info): Likewise.
	(Global_Discard_Names): Likewise.

From-SVN: r212799
parent 623267dc
2014-07-18 Thomas Quinot <quinot@adacore.com>
* g-memdum.adb, g-memdum.ads (Dump): New parameter Prefix, defaulted
to Absolute_Address.
2014-07-18 Eric Botcazou <ebotcazou@adacore.com>
* opt.ads (Suppress_Back_Annotation): Remove as unused.
* fe.h (Back_Annotate_Rep_Info): Likewise.
(Global_Discard_Names): Likewise.
2014-07-18 Robert Dewar <dewar@adacore.com> 2014-07-18 Robert Dewar <dewar@adacore.com>
* sem_ch13.adb (Is_Type_Ref): Check that type name is not * sem_ch13.adb (Is_Type_Ref): Check that type name is not
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
-- -- -- --
-- B o d y -- -- B o d y --
-- -- -- --
-- Copyright (C) 2003-2010, AdaCore -- -- Copyright (C) 2003-2014, AdaCore --
-- -- -- --
-- GNAT is free software; you can redistribute it and/or modify it under -- -- 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- -- -- terms of the GNU General Public License as published by the Free Soft- --
...@@ -30,6 +30,7 @@ ...@@ -30,6 +30,7 @@
------------------------------------------------------------------------------ ------------------------------------------------------------------------------
with System; use System; with System; use System;
with System.Img_BIU; use System.Img_BIU;
with System.Storage_Elements; use System.Storage_Elements; with System.Storage_Elements; use System.Storage_Elements;
with GNAT.IO; use GNAT.IO; with GNAT.IO; use GNAT.IO;
...@@ -43,10 +44,18 @@ package body GNAT.Memory_Dump is ...@@ -43,10 +44,18 @@ package body GNAT.Memory_Dump is
-- Dump -- -- Dump --
---------- ----------
procedure Dump (Addr : System.Address; Count : Natural) is procedure Dump
(Addr : Address;
Count : Natural;
Prefix : Prefix_Type := Absolute_Address)
is
Ctr : Natural := Count; Ctr : Natural := Count;
-- Count of bytes left to output -- Count of bytes left to output
Offset_Buf : String (1 .. Standard'Address_Size / 4 + 4);
Offset_Last : Natural;
-- Buffer for prefix in Offset mode
Adr : Address := Addr; Adr : Address := Addr;
-- Current address -- Current address
...@@ -56,14 +65,12 @@ package body GNAT.Memory_Dump is ...@@ -56,14 +65,12 @@ package body GNAT.Memory_Dump is
C : Character; C : Character;
-- Character at current storage address -- Character at current storage address
AIL : constant := Address_Image_Length - 4 + 2; AIL : Natural;
-- Number of chars in initial address + colon + space -- Number of chars in prefix (including colon and space)
Line_Len : constant Natural := AIL + 3 * 16 + 2 + 16; Line_Len : Natural;
-- Line length for entire line -- Line length for entire line
Line_Buf : String (1 .. Line_Len);
Hex : constant array (0 .. 15) of Character := "0123456789ABCDEF"; Hex : constant array (0 .. 15) of Character := "0123456789ABCDEF";
type Char_Ptr is access all Character; type Char_Ptr is access all Character;
...@@ -71,53 +78,89 @@ package body GNAT.Memory_Dump is ...@@ -71,53 +78,89 @@ package body GNAT.Memory_Dump is
function To_Char_Ptr is new Ada.Unchecked_Conversion (Address, Char_Ptr); function To_Char_Ptr is new Ada.Unchecked_Conversion (Address, Char_Ptr);
begin begin
while Ctr /= 0 loop case Prefix is
when Absolute_Address =>
AIL := Address_Image_Length - 4 + 2;
when Offset =>
Offset_Last := Offset_Buf'First - 1;
Set_Image_Based_Integer (Ctr, 16, 0, Offset_Buf, Offset_Last);
AIL := Offset_Last - 4 + 2;
when None =>
AIL := 0;
end case;
Line_Len := AIL + 3 * 16 + 2 + 16;
declare
Line_Buf : String (1 .. Line_Len);
begin
while Ctr /= 0 loop
-- Start of line processing
if N = 0 then
case Prefix is
when Absolute_Address =>
declare
S : constant String := Image (Adr);
begin
Line_Buf (1 .. AIL) := S (4 .. S'Length - 1) & ": ";
end;
when Offset =>
declare
Last : Natural := 0;
Len : Natural;
begin
Set_Image_Based_Integer
(Count - Ctr, 16, 0, Offset_Buf, Last);
Len := Last - 4;
Line_Buf (1 .. AIL - Len - 2) := (others => '0');
Line_Buf (AIL - Len - 1 .. AIL - 2) :=
Offset_Buf (4 .. Last - 1);
Line_Buf (AIL - 1 .. AIL) := ": ";
end;
when None =>
null;
end case;
-- Start of line processing
if N = 0 then
declare
S : constant String := Image (Adr);
begin
Line_Buf (1 .. AIL) := S (4 .. S'Length - 1) & ": ";
Line_Buf (AIL + 1 .. Line_Buf'Last) := (others => ' '); Line_Buf (AIL + 1 .. Line_Buf'Last) := (others => ' ');
Line_Buf (AIL + 3 * 16 + 1) := '"'; Line_Buf (AIL + 3 * 16 + 1) := '"';
end; end if;
end if;
-- Add one character to current line -- Add one character to current line
C := To_Char_Ptr (Adr).all; C := To_Char_Ptr (Adr).all;
Adr := Adr + 1; Adr := Adr + 1;
Ctr := Ctr - 1; Ctr := Ctr - 1;
Line_Buf (AIL + 3 * N + 1) := Hex (Character'Pos (C) / 16); Line_Buf (AIL + 3 * N + 1) := Hex (Character'Pos (C) / 16);
Line_Buf (AIL + 3 * N + 2) := Hex (Character'Pos (C) mod 16); Line_Buf (AIL + 3 * N + 2) := Hex (Character'Pos (C) mod 16);
if C < ' ' or else C = Character'Val (16#7F#) then if C < ' ' or else C = Character'Val (16#7F#) then
C := '?'; C := '?';
end if; end if;
Line_Buf (AIL + 3 * 16 + 2 + N) := C; Line_Buf (AIL + 3 * 16 + 2 + N) := C;
N := N + 1; N := N + 1;
-- End of line processing -- End of line processing
if N = 16 then if N = 16 then
Line_Buf (Line_Buf'Last) := '"'; Line_Buf (Line_Buf'Last) := '"';
GNAT.IO.Put_Line (Line_Buf); GNAT.IO.Put_Line (Line_Buf);
N := 0; N := 0;
end if; end if;
end loop; end loop;
-- Deal with possible last partial line -- Deal with possible last partial line
if N /= 0 then if N /= 0 then
Line_Buf (AIL + 3 * 16 + 2 + N) := '"'; Line_Buf (AIL + 3 * 16 + 2 + N) := '"';
GNAT.IO.Put_Line (Line_Buf (1 .. AIL + 3 * 16 + 2 + N)); GNAT.IO.Put_Line (Line_Buf (1 .. AIL + 3 * 16 + 2 + N));
end if; end if;
end;
return;
end Dump; end Dump;
end GNAT.Memory_Dump; end GNAT.Memory_Dump;
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
-- -- -- --
-- S p e c -- -- S p e c --
-- -- -- --
-- Copyright (C) 2003-2010, AdaCore -- -- Copyright (C) 2003-2014, AdaCore --
-- -- -- --
-- GNAT is free software; you can redistribute it and/or modify it under -- -- 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- -- -- terms of the GNU General Public License as published by the Free Soft- --
...@@ -38,7 +38,12 @@ with System; ...@@ -38,7 +38,12 @@ with System;
package GNAT.Memory_Dump is package GNAT.Memory_Dump is
pragma Preelaborate; pragma Preelaborate;
procedure Dump (Addr : System.Address; Count : Natural); type Prefix_Type is (Absolute_Address, Offset, None);
procedure Dump
(Addr : System.Address;
Count : Natural;
Prefix : Prefix_Type := Absolute_Address);
-- Dumps indicated number (Count) of bytes, starting at the address given -- Dumps indicated number (Count) of bytes, starting at the address given
-- by Addr. The coding of this routine in its current form assumes the -- by Addr. The coding of this routine in its current form assumes the
-- case of a byte addressable machine (and is therefore inapplicable to -- case of a byte addressable machine (and is therefore inapplicable to
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment