From: Eric Botcazou Date: Tue, 29 Nov 2022 17:44:33 +0000 (+0100) Subject: ada: Further adjustments to User's Guide for PIE default X-Git-Tag: upstream/13.1.0~2801 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f82d10a5485965788dad8258e8946c34d90953a0;p=platform%2Fupstream%2Fgcc.git ada: Further adjustments to User's Guide for PIE default gcc/ada/ * doc/gnat_ugn/gnat_and_program_execution.rst (Non-Symbolic Traceback): Add compilation line. (Symbolic Traceback): Remove obsolete stuff. * doc/gnat_ugn/gnat_utility_programs.rst (gnatsymbolize): Adjust. * gnat_ugn.texi: Regenerate. --- diff --git a/gcc/ada/doc/gnat_ugn/gnat_and_program_execution.rst b/gcc/ada/doc/gnat_ugn/gnat_and_program_execution.rst index 45ecea75416..5dab2d45626 100644 --- a/gcc/ada/doc/gnat_ugn/gnat_and_program_execution.rst +++ b/gcc/ada/doc/gnat_ugn/gnat_and_program_execution.rst @@ -928,10 +928,9 @@ Ada facilities defined in ``Ada.Exceptions``. Here is a simple example: P2; end STB; -This program will output: - :: + $ gnatmake stb -g -bargs -E -largs -no-pie $ stb raised CONSTRAINT_ERROR : stb.adb:12 range check failed @@ -1070,7 +1069,7 @@ Here is an example: :: - $ gnatmake -g .\stb -bargs -E + $ gnatmake -g stb -bargs -E $ stb 0040149F in stb.p1 at stb.adb:8 @@ -1082,16 +1081,6 @@ Here is an example: 004011F1 in mainCRTStartup at crt1.c:222 77E892A4 in ?? at ??:0 -In the above example the ``.\`` syntax in the ``gnatmake`` command -is currently required by ``addr2line`` for files that are in -the current working directory. -Moreover, the exact sequence of linker options may vary from platform -to platform. -The above :switch:`-largs` section is for Windows platforms. By contrast, -under Unix there is no need for the :switch:`-largs` section. -Differences across platforms are due to details of linker implementation. - - .. rubric:: Tracebacks From Anywhere in a Program It is possible to get a symbolic stack traceback diff --git a/gcc/ada/doc/gnat_ugn/gnat_utility_programs.rst b/gcc/ada/doc/gnat_ugn/gnat_utility_programs.rst index f2d42e96bd4..7df45d518aa 100644 --- a/gcc/ada/doc/gnat_ugn/gnat_utility_programs.rst +++ b/gcc/ada/doc/gnat_ugn/gnat_utility_programs.rst @@ -2154,6 +2154,7 @@ building specialized scripts. with GNAT.IO; use GNAT.IO; with GNAT.Traceback; use GNAT.Traceback; with GNAT.Debug_Utilities; + package body Pck is procedure Call_Me_Third is TB : Tracebacks_Array (1 .. 5); @@ -2177,10 +2178,25 @@ building specialized scripts. Call_Me_Second; end Call_Me_First; end Pck; + + with GNAT.IO; use GNAT.IO; + with GNAT.Debug_Utilities; + with GNAT.Traceback; + with System; + with Pck; use Pck; procedure Foo is + LA : constant System.Address := \ + GNAT.Traceback.Executable_Load_Address; + + use type System.Address; + begin + if LA /= System.Null_Address then + Put_Line ("Load address: " & GNAT.Debug_Utilities.Image_C (LA)); + end if; + Global_Val := 123; Call_Me_First; end Foo; diff --git a/gcc/ada/gnat_ugn.texi b/gcc/ada/gnat_ugn.texi index 5224a1201b8..dfe44b0937c 100644 --- a/gcc/ada/gnat_ugn.texi +++ b/gcc/ada/gnat_ugn.texi @@ -19,7 +19,7 @@ @copying @quotation -GNAT User's Guide for Native Platforms , Nov 28, 2022 +GNAT User's Guide for Native Platforms , Dec 01, 2022 AdaCore @@ -19200,13 +19200,9 @@ begin P2; end STB; @end example -@end quotation - -This program will output: - -@quotation @example +$ gnatmake stb -g -bargs -E -largs -no-pie $ stb raised CONSTRAINT_ERROR : stb.adb:12 range check failed @@ -19350,7 +19346,7 @@ end STB; @end example @example -$ gnatmake -g .\stb -bargs -E +$ gnatmake -g stb -bargs -E $ stb 0040149F in stb.p1 at stb.adb:8 @@ -19364,15 +19360,6 @@ $ stb @end example @end quotation -In the above example the @code{.\} syntax in the @code{gnatmake} command -is currently required by @code{addr2line} for files that are in -the current working directory. -Moreover, the exact sequence of linker options may vary from platform -to platform. -The above @code{-largs} section is for Windows platforms. By contrast, -under Unix there is no need for the @code{-largs} section. -Differences across platforms are due to details of linker implementation. - @subsubheading Tracebacks From Anywhere in a Program