Red Hat Developer Toolset 3 User Guide
Red Hat Developer Toolset 3 User Guide
0
User Guide
Jaromr Hradlek
Matt Newsome
Robert Krtk
Legal Notice
Co pyright 20 13, 20 14 Red Hat, Inc.
This do cument is licensed by Red Hat under the Creative Co mmo ns Attributio n-ShareAlike 3.0
Unpo rted License. If yo u distribute this do cument, o r a mo dified versio n o f it, yo u must pro vide
attributio n to Red Hat, Inc. and pro vide a link to the o riginal. If the do cument is mo dified, all Red
Hat trademarks must be remo ved.
Red Hat, as the licenso r o f this do cument, waives the right to enfo rce, and agrees no t to assert,
Sectio n 4 d o f CC-BY-SA to the fullest extent permitted by applicable law.
Red Hat, Red Hat Enterprise Linux, the Shado wman lo go , JBo ss, MetaMatrix, Fedo ra, the Infinity
Lo go , and RHCE are trademarks o f Red Hat, Inc., registered in the United States and o ther
co untries.
Linux is the registered trademark o f Linus To rvalds in the United States and o ther co untries.
Java is a registered trademark o f Oracle and/o r its affiliates.
XFS is a trademark o f Silico n Graphics Internatio nal Co rp. o r its subsidiaries in the United
States and/o r o ther co untries.
MySQL is a registered trademark o f MySQL AB in the United States, the Euro pean Unio n and
o ther co untries.
No de.js is an o fficial trademark o f Jo yent. Red Hat So ftware Co llectio ns is no t fo rmally
related to o r endo rsed by the o fficial Jo yent No de.js o pen so urce o r co mmercial pro ject.
The OpenStack Wo rd Mark and OpenStack Lo go are either registered trademarks/service
marks o r trademarks/service marks o f the OpenStack Fo undatio n, in the United States and o ther
co untries and are used with the OpenStack Fo undatio n's permissio n. We are no t affiliated with,
endo rsed o r spo nso red by the OpenStack Fo undatio n, o r the OpenStack co mmunity.
All o ther trademarks are the pro perty o f their respective o wners.
Abstract
Red Hat Develo per To o lset is a Red Hat o ffering fo r develo pers o n the Red Hat Enterprise Linux
platfo rm. The Red Hat Develo per To o lset User Guide pro vides an o verview o f this pro duct,
explains ho w to invo ke and use the Red Hat Develo per To o lset versio ns o f the to o ls, and links
to reso urces with mo re in-depth info rmatio n.
T able of Contents
. .art
P
. . .I.. Int
. . .roduct
. . . . . .ion
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4. . . . . . . . . .
. .hapt
C
. . . .er
. .1. .. Red
. . . . Hat
. . . .Developer
. . . . . . . . . T. oolset
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5. . . . . . . . . .
1.1. Ab o ut Red Hat Develo p er To o ls et
5
1.2. Main Features
6
1.3. Co mp atib ility
7
1.4. G etting Ac c es s to Red Hat Develo p er To o ls et
8
1.5. Ins talling Red Hat Develo p er To o ls et
10
1.6 . Up d ating Red Hat Develo p er To o ls et
12
1.7. Unins talling Red Hat Develo p er To o ls et
13
1.8 . Ad d itio nal Res o urc es
13
. .art
P
. . .II.. .Int
. . egrat
. . . . .ed
. . Development
. . . . . . . . . . . . .Environment
. . . . . . . . . . .s. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1. 5. . . . . . . . . .
. .hapt
C
. . . .er
. .2. .. Eclipse
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1. 6. . . . . . . . . .
2 .1. Ins talling Ec lip s e
2 .2. Us ing Ec lip s e
2 .3. Ad d itio nal Res o urc es
17
18
20
. .art
P
. . .III.
. . Development
. . . . . . . . . . . .T
. .ools
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2. 1. . . . . . . . . .
. .hapt
C
. . . .er
. .3.
. .G. NU
. . . .Compiler
. . . . . . . .Collect
. . . . . .ion
. . . (G
. . CC)
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2. 2. . . . . . . . . .
3 .1. G NU C Co mp iler
3 .2. G NU C+ + Co mp iler
22
24
26
28
. .hapt
C
. . . .er
. .4. .. binut
. . . . .ils
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
...........
4 .1. Ins talling b inutils
4 .2. Us ing the G NU As s emb ler
30
30
31
32
32
. .hapt
C
. . . .er
. .5.
. .elfut
. . . . ils
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
...........
5 .1. Ins talling elfutils
34
5 .2. Us ing elfutils
5 .3. Ad d itio nal Res o urc es
34
35
. .hapt
C
. . . .er
. .6. .. dwz
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
...........
6 .1. Ins talling d wz
36
6 .2. Us ing d wz
36
6 .3. Ad d itio nal Res o urc es
36
. .art
P
. . .IV.
. . Debugging
. . . . . . . . . . .T.ools
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
...........
. .hapt
C
. . . .er
. .7. .. G
. .NU
. . .Debugger
. . . . . . . . .(G
. .DB)
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
...........
7 .1. Ins talling the G NU Deb ug g er
39
7 .2. Prep aring a Pro g ram fo r Deb ug g ing
39
7 .3. Running the G NU Deb ug g er
40
7 .4. Lis ting So urc e Co d e
7 .5. Setting Breakp o ints
7 .6 . Starting Exec utio n
7 .7. Dis p laying Current Values
41
42
44
44
45
45
45
. .hapt
C
. . . .er
. .8. .. st
. .race
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .4. 7. . . . . . . . . .
8 .1. Ins talling s trac e
47
8 .2. Us ing s trac e
47
8 .3. Ad d itio nal Res o urc es
50
. .hapt
C
. . . .er
. .9. .. lt. race
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
...........
9 .1. Ins talling ltrac e
52
9 .2. Us ing ltrac e
52
9 .3. Ad d itio nal Res o urc es
55
. .hapt
C
. . . .er
. .1. 0. .. memst
. . . . . . omp
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
...........
10 .1. Ins talling mems to mp
10 .2. Us ing mems to mp
10 .3. Ad d itio nal Res o urc es
57
57
59
. .art
P
. . .V.. .Performance
. . . . . . . . . . . Monit
. . . . . oring
. . . . . .T.ools
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6. 0. . . . . . . . . .
. .hapt
C
. . . .er
. .1. 1. .. Syst
. . . . emT
. . . . ap
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6. 1. . . . . . . . . .
11.1. Ins talling Sys temTap
61
11.2. Us ing Sys temTap
11.3. Ad d itio nal Res o urc es
62
62
. .hapt
C
. . . .er
. .1. 2. .. Valgrind
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6. 4. . . . . . . . . .
12.1. Ins talling Valg rind
64
65
65
. .hapt
C
. . . .er
. .1. 3.
. .O
. .Profile
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6. 7. . . . . . . . . .
13.1. Ins talling O Pro file
13.2. Us ing O Pro file
67
67
68
. .hapt
C
. . . .er
. .1. 4. .. Dyninst
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7. 0. . . . . . . . . .
14.1. Ins talling Dynins t
14.2. Us ing Dynins t
70
70
75
. .art
P
. . .VI.
. .G
. .et
. .t ing
. . . .Help
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7. 7. . . . . . . . . .
. .hapt
C
. . . .er
. .1. 5.
. . Accessing
. . . . . . . . . .Red
. . . .Hat
. . . Product
. . . . . . . .Document
. . . . . . . . . at
. .ion
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7. 8. . . . . . . . . .
R ed Hat Develo p er To o ls et
R ed Hat Enterp ris e Linux
78
78
. .hapt
C
. . . .er
. .1. 6. .. Cont
. . . . .act
. . ing
. . . .G. lobal
. . . . . Support
. . . . . . . .Services
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .7. 9. . . . . . . . . .
16 .1. G athering Req uired Info rmatio n
16 .2. Es c alating an Is s ue
79
80
81
81
.Changes
. . . . . . . .in. .Version
. . . . . . .3.0
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .8. 2. . . . . . . . . .
A .1. Chang es in Ec lip s e
82
A .2. Chang es in G CC
85
110
112
A .5. Chang es in G DB
114
114
129
130
131
132
134
134
. . . . . . . . .Hist
Revision
. . . ory
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1. 36
...........
I.ndex
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .1. 36
...........
Part I. Introduction
Versio n
D escrip t io n
Eclipse
4.4
GCC
binutils
4.9.1
2.24
elfutils
0.159
dwz
0.11
GD B
7.8
ltrace
0.7.91
strace
4.8
memstomp
0.1.5
N ame
Versio n
D escrip t io n
SystemTap
2.5
Valgrind
3.9.0
OProfile
0.9.9
D yninst
8.2
[a] If yo u intend to d evelo p ap p lic atio ns fo r Red Hat JBo s s Mid d leware o r req uire s up p o rt fo r
O p enShift To o ls , it is rec o mmend ed that yo u us e Red Hat JBo s s Develo p er Stud io .
Red Hat D eveloper Toolset differs from Technology Preview compiler releases previously supplied
in Red Hat Enterprise Linux in two important respects:
1. Red Hat D eveloper Toolset can be used on multiple major and minor releases of Red Hat
Enterprise Linux, as detailed in Section 1.3, Compatibility .
2. Unlike Technology Preview compilers and other tools shipped in earlier Red Hat
Enterprise Linux, Red Hat D eveloper Toolset is fully supported under Red Hat
Enterprise Linux Subscription Level Agreements, is functionally complete, and is intended for
production use.
Important bug fixes and security errata are issued to Red Hat D eveloper Toolset subscribers in a
similar manner to Red Hat Enterprise Linux for two years from the release of each major version
release. A new major version of Red Hat D eveloper Toolset is released annually, providing
significant updates for existing components and adding major new components. A single minor
release, issued six months after each new major version release, provides a smaller update of bug
fixes, security errata, and new minor components.
Additionally, the Red Hat Enterprise Linux Application Compatibility Specification also applies to
Red Hat D eveloper Toolset (subject to some constraints on the use of newer C++11 language
features, detailed in Section A.2.1.5, ABI Compatibility ).
Important
Applications and libraries provided by Red Hat D eveloper Toolset do not replace the Red Hat
Enterprise Linux system versions, nor are they used in preference to the system versions.
Using a framework called So f t ware C o llect io n s, an additional set of developer tools is
installed into the /o pt directory and is explicitly enabled by the user on demand using the
scl utility.
Inter-procedural analysis (IPA) has been improved, and speculative devirtualization optimization
has been added.
Support for profiling code has been made more reliable.
The Intel AVX-512 target architecture is now supported, as well as a number of new Intel
microarchitectures.
Support for C11 has been improved, and ISO C11 atomics, generic selections, and thread-local
storage are now supported.
A subset of the functionality of C++11 auto is now provided in GNU C through a new extension,
__auto _type.
The C and C++ compilers now support the OpenMP 4.0 specification.
The g + + compiler offers improved support for various features of the C++ standard, including
generic lambdas, variable-length arrays, and digit separators.
The C++ runtime library C++11 support has been improved and now includes experimental
support for the upcoming ISO C++ standard, C++14.
G C C now adds support for Cilk+, an extension to the C and C++ languages for parallel
programming.
The version of the G N U D eb u g g er (G D B ) included in Red Hat D eveloper Toolset provides the
following new features:
Python scripting support has been enhanced in a number of ways.
Several new commands and enhancements in G D B /MI have been added.
Support for the CTF (Common Trace Format) has been added.
The btrace record target has been enhanced in a number of ways.
The remote protocol and G D B server, the G D B remote stub, have been enhanced in a number of
ways.
Additionally, the Red Hat D eveloper Toolset version of b in u t ils provides these features:
The o b jco p y utility now supports wildcards for section names in command line options.
The AVX-512 (512-bit Advanced Vector Extensions) are now supported.
For a full list of changes and features introduced in this release, see Appendix A, Changes in Version
3.0.
Important
Red Hat D eveloper Toolset 3.0 is only compatible with Red Hat Enterprise Linux Server 6.4
and higher and Red Hat Enterprise Linux Workstation 6.5 and higher. See Figure 1.1, Red Hat
D eveloper Toolset 3.0 Compatibility Matrix .
For each available subscription, this command displays its name, unique identifier,
expiration date, and other details related to your subscription. The pool ID is listed on a line
beginning with P o o l ID .
For a complete list of subscriptions that provide access to Red Hat D eveloper Toolset, see
https://access.redhat.com/solutions/472793.
2. Attach the appropriate subscription to your system by running the following command as
ro o t:
subscri pti o n-manag er attach --po o l = pool_id
Replace pool_id with the pool ID you determined in the previous step. To verify the list of
subscriptions your system has currently attached, at any time, run as ro o t:
subscri pti o n-manag er l i st --co nsumed
3. D etermine the exact name of the Red Hat Software Collections repository. To do so, type the
following at a shell prompt as ro o t to retrieve repository metadata and to display a list of
available Yu m repositories:
subscri pti o n-manag er repo s --l i st
The repository names depend on the specific version of Red Hat Enterprise Linux you are
using and are in the following format:
rhel-variant-rhscl-version-rpms
rhel-variant-rhscl-version-debug-rpms
rhel-variant-rhscl-version-source-rpms
rhel-server-rhscl-6-eus-rpms
rhel-server-rhscl-6-eus-source-rpms
rhel-server-rhscl-6-eus-debug-rpms
In addition, certain packages, such as devtoolset-3-gcc-plugin-devel, depend on packages that
are only available in the O p t io n al channel. The repository names with these packages use
the following format:
rhel-version-variant-optional-rpms
rhel-version-variant-optional-debug-rpms
rhel-version-variant-optional-source-rpms
Replace variant with the Red Hat Enterprise Linux system variant (server or wo rkstati o n),
and version with the Red Hat Enterprise Linux system version (6 or 7).
4. Enable the repositories from step no. 3 by running the following command as ro o t:
subscri pti o n-manag er repo s --enabl e repository
Replace repository with the name of the repository to enable.
Once the subscription is attached to the system, you can install Red Hat D eveloper Toolset as
described in Section 1.5, Installing Red Hat D eveloper Toolset . For more information on how to
register your system using Red Hat Subscription Management and associate it with subscriptions,
see the Red Hat Subscription Management collection of guides.
10
Important
Before installing Red Hat D eveloper Toolset, install all available Red Hat Enterprise Linux
updates.
Note
Note that the scl-utils package is not a part of Red Hat D eveloper Toolset 3.0, which is a
change from previous versions where the scl utility was installed along with the Red Hat
D eveloper Toolset software collection.
D escrip t io n
In st alled C o mp o n en t s
devtoolset-3-ide
Integrated D evelopment
Environment
Performance monitoring tools
Eclipse
devtoolset-3-perftools
devtoolset-3-toolchain
To install any of these meta packages, type the following at a shell prompt as ro o t:
yum i nstal l package_name
Replace package_name with a space-separated list of meta packages you want to install. For
example, to install only the Eclipse development environment and packages that depend on it, type
as ro o t:
~]# yum i nstal l d evto o l set-3-i d e
11
Alternatively, you can choose to install all available components as described in Section 1.5.1,
Installing All Available Components .
12
Important
Use of Red Hat D eveloper Toolset requires the removal of any earlier pre-release versions of it.
Additionally, it is not possible to update to Red Hat D eveloper Toolset 3.0 from a pre-release
version of Red Hat D eveloper Toolset, including beta releases. If you have previously installed
any pre-release version of Red Hat D eveloper Toolset, uninstall it from your system as
described in Section 1.7, Uninstalling Red Hat D eveloper Toolset and install the new version
as documented in Section 1.5, Installing Red Hat D eveloper Toolset .
13
Red Hat Enterprise Linux 6 D eployment Guide The Deployment Guide for Red Hat
Enterprise Linux 6 documents relevant information regarding the deployment, configuration, and
administration of Red Hat Enterprise Linux 6.
Red Hat Enterprise Linux 7 System Administrator's Guide The System Administrator's Guide for
Red Hat Enterprise Linux 7 documents relevant information regarding the deployment,
configuration, and administration of Red Hat Enterprise Linux 7.
See Also
Appendix A, Changes in Version 3.0 provides a comprehensive list of changes and improvements
over the Red Hat Enterprise Linux system versions of the GNU Compiler Collection, GNU
D ebugger, and binutils, as well as information about the language, ABI, and debugging
compatibility.
14
15
Chapter 2. Eclipse
Eclip se is a powerful development environment that provides tools for each phase of the
development process. It integrates a variety of disparate tools into a unified environment to create a
rich development experience, provides a fully configurable user interface, and features a pluggable
architecture that allows for an extension in a variety of ways. For instance, the Valg rin d plug-in
allows programmers to perform memory profiling, otherwise performed on the command line, through
the Eclip se user interface.
16
Chapt er 2 . Eclipse
Packag e
D escrip t io n
devtoolset-3-eclipse-cdt
devtoolset-3-eclipse-oprofile[a]
devtoolset-3-eclipse-perf[a]
The Perf plug-in, which integrates the p erf tool with Eclip se.
devtoolset-3-eclipse-rpm-editor [a]
The Eclipse Spec File Editor, which allows you to maintain RPM
spec files.
The SystemTap plug-in, which integrates Syst emT ap with
Eclip se.
The Valgrind plug-in, which integrates Valg rin d with Eclip se.
devtoolset-3-eclipse-emf
devtoolset-3-eclipse-gef
devtoolset-3-eclipse-rse
devtoolset-3-eclipse-jgit
devtoolset-3-eclipse-egit
devtoolset-3-eclipse-mylyn
devtoolset-3-eclipse-pde
devtoolset-3-eclipse-remote
devtoolset-3-eclipse-tests
devtoolset-3-eclipse-linuxtools
devtoolset-3-eclipse-changelog [a]
devtoolset-3-eclipse-gcov [a]
devtoolset-3-eclipse-gprof[a]
devtoolset-3-eclipse-manpage[a]
devtoolset-3-eclipse-systemtap[a]
devtoolset-3-eclipse-valgrind[a]
Note
The Red Hat D eveloper Toolset version of Eclipse fully supports C, C++, and Java
development, but does not provide support for the Fortran programming language.
17
Important
If you are working on a project that you previously built with the Red Hat Enterprise Linux
version of the G N U C o mp iler C o llect io n , make sure that you discard all previous build
results. To do so, open the project in Eclip se and select Pro ject C lean from the menu.
18
Chapt er 2 . Eclipse
To use the Red Hat D eveloper Toolset version of Eclip se with support for the toolchain distributed
with Red Hat Enterprise Linux change the configuration of the project to use absolute paths to the
Red Hat Enterprise Linux system versions of g cc, g + + , and as.
To configure Eclip se to explicitly use the Red Hat Enterprise Linux system versions of the tools for
the current project, complete the following steps:
1. In the C/C++ perspective, choose Pro ject Pro p ert ies from the main menu bar to open the
project properties.
2. In the menu on the left-hand side of the dialog box, click C /C + + B u ild Set t in g s.
3. Select the T o o l Setti ng s tab.
4. If you are working on a C project:
a. select G C C C C o mp iler or C ro ss G C C C o mp iler and change the value of the
C o mmand field to:
/usr/bin/gcc
b. select G C C C Lin ker or C ro ss G C C Lin ker and change the value of the C o mmand
field to:
/usr/bin/gcc
c. select G C C Assemb ler or C ro ss G C C Assemb ler and change the value of the
C o mmand field to:
/usr/bin/as
If you are working on a C++ project:
a. select G C C C + + C o mp iler or C ro ss G + + C o mp iler and change the value of the
C o mmand field to:
/usr/bin/g++
b. select G C C C C o mp iler or C ro ss G C C C o mp iler and change the value of the
C o mmand field to:
/usr/bin/gcc
c. select G C C C + + Lin ker or C ro ss G + + Lin ker and change the value of the
C o mmand field to:
/usr/bin/g++
d. select G C C Assemb ler or C ro ss G C C Assemb ler and change the value of the
C o mmand field to:
/usr/bin/as
5. Click the O K button to save the configuration changes.
19
See Also
Section A.1, Changes in Eclipse provides a comprehensive list of features and improvements
over the Eclip se development environment included in Red Hat Enterprise Linux 6 and the
previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 3, GNU Compiler Collection (GCC) provides information on how to compile programs
written in C, C++, and Fortran on the command line.
20
21
22
Note
To verify the version of g cc you are using at any point, type the following at a shell prompt:
whi ch g cc
Red Hat D eveloper Toolset's g cc executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset g cc:
g cc -v
Important
Some newer library features are statically linked into applications built with Red Hat
D eveloper Toolset to support execution on multiple versions of Red Hat Enterprise Linux. This
adds a small additional security risk as normal Red Hat Enterprise Linux errata would not
change this code. If the need for developers to rebuild their applications due to such an issue
arises, Red Hat will signal this via a security erratum. D evelopers are strongly advised not to
statically link their entire application for the same reasons.
Note
The Red Hat D eveloper Toolset 3.0 version of G C C adds support for Cilk+, an extension to
the C and C++ languages for parallel programming, which can be enabled using the fci l kpl us option. A new runtime library, l i bci l krts, is included in this release to support
Cilk+. The l i bci l krts library will be a part of the gcc-libraries package in the future Red Hat
Enterprise Linux releases, but the package is not included in all supported Red Hat
Enterprise Linux releases. To enable dynamic linkage of binaries and libraries built with
Red Hat D eveloper Toolset 3.0 G C C using Cilk+ features on supported Red Hat
Enterprise Linux releases that do not contain l i bci l krts, install the l i bci l krts. so
shared library from Red Hat D eveloper Toolset 3.0 with such binaries or libraries.
}
To compile this source code on the command line by using the g cc compiler from Red Hat
D eveloper Toolset, type:
23
24
Note that you can execute any command using the scl utility, causing it to be run with the Red Hat
D eveloper Toolset binaries used in preference to the Red Hat Enterprise Linux system equivalent.
This allows you to run a shell session with Red Hat D eveloper Toolset g + + as default:
scl enabl e d evto o l set-3 ' bash'
Note
To verify the version of g + + you are using at any point, type the following at a shell prompt:
whi ch g + +
Red Hat D eveloper Toolset's g + + executable path will begin with /opt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset g + + :
g + + -v
Important
Some newer library features are statically linked into applications built with Red Hat
D eveloper Toolset to support execution on multiple versions of Red Hat Enterprise Linux. This
adds a small additional security risk as normal Red Hat Enterprise Linux errata would not
change this code. If the need for developers to rebuild their applications due to such an issue
arises, Red Hat will signal this via a security erratum. D evelopers are strongly advised not to
statically link their entire application for the same reasons.
25
26
Note
To verify the version of g fo rtran you are using at any point, type the following at a shell
prompt:
whi ch g fo rtran
Red Hat D eveloper Toolset's g fo rtran executable path will begin with /o pt. Alternatively,
you can use the following command to confirm that the version number matches that for
Red Hat D eveloper Toolset g fo rtran:
g fo rtran -v
Important
Some newer library features are statically linked into applications built with Red Hat
D eveloper Toolset to support execution on multiple versions of Red Hat Enterprise Linux. This
adds a small additional security risk as normal Red Hat Enterprise Linux errata would not
change this code. If the need for developers to rebuild their applications due to such an issue
arises, Red Hat will signal this via a security erratum. D evelopers are strongly advised not to
statically link their entire application for the same reasons.
program hello
print *, "Hello, World!"
end program hello
To compile this source code on the command line by using the g fo rtran compiler from Red Hat
D eveloper Toolset, type:
~]$ scl enabl e d evto o l set-3 ' g fo rtran -o hel l o hel l o . f'
This creates a new binary file called hel l o in the current working directory.
27
See Also
28
Section A.2, Changes in GCC provides a comprehensive list of features and improvements over
the Red Hat Enterprise Linux system version of the G N U C o mp iler C o llect io n and the version
distributed in the previous release of Red Hat D eveloper Toolset, as well as information about the
language, ABI, and debugging compatibility.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 2, Eclipse provides a general introduction to the Eclip se development environment, and
describes how to use it with the tools from Red Hat D eveloper Toolset.
Chapter 4, binutils explains how to use the b in u t ils, a collection of binary tools to inspect and
manipulate object files and binaries.
Chapter 5, elfutils explains how to use elf u t ils, a collection of binary tools to inspect and
manipulate ELF files.
Chapter 6, dwz explains how to use d wz to optimize D WARF debugging information contained in
ELF shared libraries and ELF executables for size.
Chapter 7, GNU Debugger (GDB) provides information on how to debug programs written in C,
C++, and Fortran.
29
Chapter 4. binutils
b in u t ils is a collection of various binary tools, such as the G N U lin ker, G N U assemb ler, and
other utilities that allow you to inspect and manipulate object files and binaries. See Table 4.1, Tools
Included in binutils for Red Hat D eveloper Toolset for a complete list of binary tools that are
distributed with the Red Hat D eveloper Toolset version of b in u t ils.
Red Hat D eveloper Toolset is distributed with b in u t ils 2.24 . This version is more recent than the
version included in Red Hat Enterprise Linux and provides bug fixes and enhancements, including
support for the AVX-512 (512-bit Advanced Vector Extensions). For a detailed list of changes, see
Section A.3, Changes in binutils .
T ab le 4 .1. T o o ls In clu d ed in b in u t ils f o r R ed H at D evelo p er T o o lset
N ame
D escrip t io n
ad d r2l i ne
ar
as
c+ + fi l t
d wp
el fed i t
g pro f
ld
l d . bfd
ld.gold
nm
o bjco py
o bjd ump
ranl i b
read el f
si ze
stri ng s
stri p
30
Note that you can execute any command using the scl utility, causing it to be run with the Red Hat
D eveloper Toolset binaries used in preference to the Red Hat Enterprise Linux system equivalent.
This allows you to run a shell session with Red Hat D eveloper Toolset as as default:
scl enabl e d evto o l set-3 ' bash'
Note
To verify the version of as you are using at any point, type the following at a shell prompt:
whi ch as
Red Hat D eveloper Toolset's as executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset as:
as -v
Note
To verify the version of l d you are using at any point, type the following at a shell prompt:
whi ch l d
Red Hat D eveloper Toolset's l d executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset l d :
l d -v
31
Note
To verify the version of b in u t ils you are using at any point, type the following at a shell
prompt:
whi ch o bjd ump
Red Hat D eveloper Toolset's o bjd ump executable path will begin with /o pt. Alternatively, you
can use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset o bjd ump:
o bjd ump -v
32
See Also
Section A.3, Changes in binutils provides a comprehensive list of features and improvements
over the Red Hat Enterprise Linux system version of b in u t ils and the version distributed in the
previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 5, elfutils explains how to use elf u t ils, a collection of binary tools to inspect and
manipulate ELF files.
Chapter 3, GNU Compiler Collection (GCC) provides information on how to compile programs
written in C, C++, and Fortran.
33
Chapter 5. elfutils
elf u t ils is a collection of various binary tools, such as eu-o bjd ump, eu-read el f, and other
utilities that allow you to inspect and manipulate ELF files. See Table 5.1, Tools Included in elfutils
for Red Hat D eveloper Toolset for a complete list of binary tools that are distributed with the Red Hat
D eveloper Toolset version of elf u t ils.
Red Hat D eveloper Toolset is distributed with elf u t ils 0.159 . This version is more recent than the
version included in Red Hat Enterprise Linux and the previous release of Red Hat D eveloper Toolset,
and provides numerous bug fixes and enhancements.
T ab le 5.1. T o o ls In clu d ed in elf u t ils f o r R ed H at D evelo p er T o o lset
N ame
D escrip t io n
eu-ad d r2l i ne
eu-ar
eu-el fcmp
eu-el fl i nt
eu-fi nd textrel
eu-make-d ebug archi ve
eu-nm
eu-o bjd ump
eu-ranl i b
eu-read el f
eu-si ze
eu-stack
eu-stri ng s
eu-stri p
eu-unstri p
34
Note that you can execute any command using the scl utility, causing it to be run with the Red Hat
D eveloper Toolset binaries used in preference to the Red Hat Enterprise Linux system equivalent.
This allows you to run a shell session with Red Hat D eveloper Toolset binary tools as default:
scl enabl e d evto o l set-3 ' bash'
Note
To verify the version of elf u t ils you are using at any point, type the following at a shell
prompt:
whi ch eu-o bjd ump
Red Hat D eveloper Toolset's eu-o bjd ump executable path will begin with /o pt. Alternatively,
you can use the following command to confirm that the version number matches that for
Red Hat D eveloper Toolset eu-o bjd ump:
eu-o bjd ump -V
See Also
Section A.4, Changes in elfutils provides a comprehensive list of features and improvements
over the Red Hat Enterprise Linux system version of elf u t ils and the version distributed in the
previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 3, GNU Compiler Collection (GCC) provides information on how to compile programs
written in C, C++, and Fortran.
Chapter 4, binutils explains how to use the b in u t ils, a collection of binary tools to inspect and
manipulate object files and binaries.
Chapter 6, dwz explains how to use d wz to optimize D WARF debugging information contained in
ELF shared libraries and ELF executables for size.
35
Chapter 6. dwz
d wz is a command line tool that attempts to optimize D WARF debugging information contained in
ELF shared libraries and ELF executables for size. To do so, d wz replaces D WARF information
representation with equivalent smaller representation where possible and reduces the amount of
duplication by using techniques from Appendix E of the DWARF Standard.
Red Hat D eveloper Toolset is distributed with d wz 0.11.
Note
To verify the version of d wz you are using at any point, type the following at a shell prompt:
whi ch d wz
Red Hat D eveloper Toolset's d wz executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset d wz:
d wz -v
36
Chapt er 6 . dwz
dwz(1) The manual page for the d wz utility provides detailed information on its usage. To
display the manual page for the version included in Red Hat D eveloper Toolset, type:
scl enabl e d evto o l set-3 ' man d wz'
See Also
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 3, GNU Compiler Collection (GCC) provides information on how to compile programs
written in C, C++, and Fortran.
Chapter 4, binutils explains how to use the b in u t ils, a collection of binary tools to inspect and
manipulate object files and binaries.
Chapter 5, elfutils explains how to use elf u t ils, a collection of binary tools to inspect and
manipulate ELF files.
37
38
char *argv[]) {
a = 0;
b = 1;
sum;
39
return 0;
}
To compile this program on the command line using G C C from Red Hat D eveloper Toolset with
debugging information for the G N U D eb u g g er, type:
~]$ scl enabl e d evto o l set-3 ' g cc -g -o fi bo nacci fi bo nacci . c'
This creates a new binary file called fi bo nacci in the current working directory.
40
Note
To verify the version of g d b you are using at any point, type the following at a shell prompt:
whi ch g d b
Red Hat D eveloper Toolset's g d b executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset g d b:
g d b -v
41
Similarly, to display the code that is surrounding the beginning of a particular function, run:
l i st [file_name:]function_name
Note that you can change the number of lines the l i st command displays by running the following
command:
set l i stsi ze number
42
break [file_name:]function_name
43
(gdb) cl ear 7
Deleted breakpoint 2
44
45
A detailed description of the G N U D eb u g g er and all its features is beyond the scope of this book.
For more information, see the resources listed below.
See Also
Section A.5, Changes in GD B provides a comprehensive list of features and improvements over
the Red Hat Enterprise Linux system version of the G N U D eb u g g er and the version distributed in
the previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 2, Eclipse provides a general introduction to the Eclip se development environment, and
describes how to use it with the tools from Red Hat D eveloper Toolset.
Chapter 3, GNU Compiler Collection (GCC) provides further information on how to compile
programs written in C, C++, and Fortran.
Chapter 8, strace documents how to use the st race utility to monitor system calls that a program
uses and signals it receives.
Chapter 10, memstomp documents how to use the memst o mp utility to identify calls to library
functions with overlapping memory regions that are not allowed by various standards.
46
Chapt er 8 . st race
Chapter 8. strace
st race is a diagnostic and debugging tool for the command line that can be used to trace system
calls that are made and received by a running process. It records the name of each system call, its
arguments, and its return value, as well as signals received by the process and other interactions
with the kernel, and prints this record to standard error output or a selected file.
Red Hat D eveloper Toolset is distributed with st race 4 .8.
Note
To verify the version of strace you are using at any point, type the following at a shell prompt:
whi ch strace
Red Hat D eveloper Toolset's strace executable path will begin with /o pt. Alternatively, you
can use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset strace:
strace -V
47
standard error output. To redirect this output to a file, use the -o command line option followed by
the file name:
scl enabl e d evto o l set-3 ' strace -o file_name program [argument. . . ]'
Replace file_name with the name of the file.
D escrip t io n
fi l e
pro cess
netwo rk
si g nal
i pc
d esc
System calls
System calls
System calls
System calls
System calls
System calls
48
Chapt er 8 . st race
-1,
-1,
-1,
-1,
49
See Also
Section A.6, Changes in strace provides a comprehensive list of features and improvements
over the Red Hat Enterprise Linux system version of st race.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 9, ltrace provides information on how to trace program library calls using the lt race tool.
Chapter 7, GNU Debugger (GDB) provides information on how to debug programs written in C,
C++, and Fortran.
50
Chapt er 8 . st race
Chapter 10, memstomp documents how to use the memst o mp utility to identify calls to library
functions with overlapping memory regions that are not allowed by various standards.
51
Chapter 9. ltrace
lt race is a diagnostic and debugging tool for the command line that can be used to display calls
that are made to shared libraries. It uses the dynamic library hooking mechanism, which prevents it
from tracing calls to statically linked libraries. lt race also displays return values of the library calls.
The output is printed to standard error output or to a selected file.
Red Hat D eveloper Toolset is distributed with lt race 0.7.9 1.
Note
To verify the version of l trace you are using at any point, type the following at a shell
prompt:
whi ch l trace
Red Hat D eveloper Toolset's l trace executable path will begin with /o pt. Alternatively, you
can use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset l trace:
l trace -V
52
Chapt er 9 . lt race
By default, l trace prints the name of each system call, its arguments and the return value to
standard error output. To redirect this output to a file, use the -o command line option followed by
the file name:
scl enabl e d evto o l set-3 ' l trace -o file_name program [argument. . . ]'
Replace file_name with the name of the file.
53
ls->readdir({ 3 })
= nil
ls->closedir({ 3 }) = 0
BUILD BUILDROOT RPMS SOURCES
+++ exited (status 0) +++
SPECS
SRPMS
For a detailed description of available filter expressions, see the ltrace(1) manual page.
= nil
= nil
=
=
=
54
Chapt er 9 . lt race
Consider the l sbl k command. To run the l trace utility on this program and display a trace
summary, type:
~]$ scl enabl e d evto o l set-3 ' l trace -c l sbl k > /d ev/nul l '
% time
seconds usecs/call
calls
function
------ ----------- ----------- --------- -------------------53.60
0.261644
261644
1 __libc_start_main
4.48
0.021848
58
374 mbrtowc
4.41
0.021524
57
374 wcwidth
4.39
0.021409
57
374 __ctype_get_mb_cur_max
4.38
0.021359
57
374 iswprint
4.06
0.019838
74
266 readdir64
3.21
0.015652
69
224 strlen
...
------ ----------- ----------- --------- -------------------100.00
0.488135
3482 total
See Also
Section A.7, Changes in ltrace provides a comprehensive list of features and improvements over
the Red Hat Enterprise Linux system version of lt race.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 8, strace provides information on how to trace program system calls using the st race
tool.
Chapter 7, GNU Debugger (GDB) provides information on how to debug programs written in C,
C++, and Fortran.
Chapter 10, memstomp documents how to use the memst o mp utility to identify calls to library
functions with overlapping memory regions that are not allowed by various standards.
55
D escrip t io n
memcpy
Copies n bytes from one memory area to another and returns a pointer to
the second memory area.
Copies a maximum of n bytes from one memory area to another and stops
when a certain character is found. It either returns a pointer to the byte
following the last written byte, or NULL if the given character is not found.
Copies n bytes from one memory area to another and returns a pointer to
the byte following the last written byte.
Copies a string from one memory area to another and returns a pointer to
the second string.
Copies a string from one memory area to another and returns a pointer to
the terminating null byte of the second string.
Copies a maximum of n characters from one string to another and returns
a pointer to the second string.
Copies a maximum of n characters from one string to another. It either
returns a pointer to the terminating null byte of the second string, or if the
string is not null-terminated, a pointer to the byte following the last written
byte.
Appends one string to another while overwriting the terminating null byte
of the second string and adding a new one at its end. It returns a pointer
to the new string.
Appends a maximum of n characters from one string to another while
overwriting the terminating null byte of the second string and adding a
new one at its end. It returns a pointer to the new string.
The wide-character equivalent of the memcpy() function that copies n wide
characters from one array to another and returns a pointer to the second
array.
The wide-character equivalent of the mempcpy() function that copies n
wide characters from one array to another and returns a pointer to the
byte following the last written wide character.
The wide-character equivalent of the strcpy() function that copies a
wide-character string from one array to another and returns a pointer to
the second array.
The wide-character equivalent of the strncpy() function that copies a
maximum of n wide characters from one array to another and returns a
pointer to the second string.
memccpy
mempcpy
strcpy
stpcpy
strncpy
stpncpy
strcat
strncat
wmemcpy
wmempcpy
wcscpy
wcsncpy
56
Fu n ct io n
D escrip t io n
wcscat
wcsncat
57
In the current working directory, create a source file named empl o yee. c with the following
contents:
# include <stdio.h>
# include <string.h>
# define BUFSIZE 80
i nt main(int argc, char *argv[]) {
char employee[BUFSIZE] = "John,Doe,john@ example.com";
char name[BUFSIZE] = {0};
char surname[BUFSIZE] = {0};
char *email;
size_t length;
return 0;
}
Compile this program into a binary file named empl o yee by using the following command:
~]$ scl enabl e d evto o l set-3 ' g cc -rd ynami c -g -o empl o yee
empl o yee. c'
To identify erroneous function calls with overlapping memory regions, type:
~]$ scl enabl e d evto o l set-3 ' memsto mp --d ebug -i nfo . /empl o yee'
memstomp: 0.1.4 successfully initialized for process employee (pid
14887).
58
See Also
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 7, GNU Debugger (GDB) provides information on how to debug programs written in C,
C++, and Fortran.
Chapter 8, strace documents how to use the strace utility to monitor system calls that a program
uses and signals it receives.
Chapter 12, Valgrind explains how to use Valg rin d to profile applications and detect memory
errors and memory management problems, such as the use of uninitialized memory, improper
allocation and freeing of memory, and the use of improper arguments in system calls.
59
60
D escrip t io n
stap
stapd yn
staprun
stapsh
stap-prep
stap-merg e
stap-repo rt
stap-server
Note
The Red Hat D eveloper Toolset version of Syst emT ap is available for both Red Hat
Enterprise Linux 6 and Red Hat Enterprise Linux 7, but some new features are only offered by
the Red Hat D eveloper Toolset version of Syst emT ap for Red Hat Enterprise Linux 7. See
Section A.8, Changes in SystemTap for details.
In order to place instrumentation into the Linux kernel, Syst emT ap may also require installation of
additional packages with debugging information. To determine which packages to install, run the
stap-prep utility as follows:
scl enabl e d evto o l set-3 ' stap-prep'
61
Note that if you execute this command as the ro o t user, the utility automatically offers the packages
for installation. For more information on how to install these packages on your system, see the
Red Hat Enterprise Linux 6 SystemTap Beginners Guide or the Red Hat Enterprise Linux 7 SystemTap
Beginners Guide.
Note
To verify the version of Syst emT ap you are using at any point, type the following at a shell
prompt:
whi ch stap
Red Hat D eveloper Toolset's stap executable path will begin with /o pt. Alternatively, you can
use the following command to confirm that the version number matches that for Red Hat
D eveloper Toolset Syst emT ap :
stap -V
62
staprun(8) The manual page for the staprun command provides detailed information on its
usage. To display the manual page for the version included in Red Hat D eveloper Toolset, type:
scl enabl e d evto o l set-3 ' man staprun'
SystemTap Tapset Reference Manual HTML documentation on the most common tapset
definitions is located at /o pt/rh/d evto o l set-3/ro o t/usr/share/d o c/d evto o l set-3systemtap-cl i ent-2. 5/i nd ex. html .
See Also
Section A.8, Changes in SystemTap provides a comprehensive list of features and
improvements over the Red Hat Enterprise Linux system version of Syst emT ap and the version
distributed in the previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 12, Valgrind explains how to use Valg rin d to profile applications and detect memory
errors and memory management problems, such as the use of uninitialized memory, improper
allocation and freeing of memory, and the use of improper arguments in system calls.
Chapter 13, OProfile explains how to use O Pro f ile to determine which sections of code consume
the greatest amount of CPU time and why.
Chapter 14, Dyninst documents how to use the D yninst library to instrument a user-space
executable.
63
D escrip t io n
Memch eck
C ach eg rin d
C allg rin d
H elg rin d
DRD
Massif
Note
Note that if you use Valg rin d in combination with the G N U D eb u g g er, it is recommended
that you use the version of G D B that is included in Red Hat D eveloper Toolset to ensure that
all features are fully supported.
Chapt er 1 2 . Valgrind
Note
To verify the version of Valgrind you are using at any point, type the following at a shell
prompt:
whi ch val g ri nd
Red Hat D eveloper Toolset's val g ri nd executable path will begin with /o pt. Alternatively,
you can use the following command to confirm that the version number matches that for
Red Hat D eveloper Toolset Valg rin d :
val g ri nd --versi o n
65
See Also
Section A.9, Changes in Valgrind provides a comprehensive list of features and improvements
over the Red Hat Enterprise Linux system version of Valg rin d and the version distributed in the
previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 10, memstomp documents how to use the memst o mp utility to identify calls to library
functions with overlapping memory regions that are not allowed by various standards.
Chapter 11, SystemTap provides an introduction to Syst emT ap and explains how to use it to
monitor the activities of a running system.
Chapter 13, OProfile explains how to use O Pro f ile to determine which sections of code consume
the greatest amount of CPU time and why.
Chapter 14, Dyninst documents how to use the D yninst library to instrument a user-space
executable.
66
Chapt er 1 3. O Profile
D escrip t io n
o pro fi l ed
o pco ntro l
o panno tate
o parchi ve
o pg pro f
o phel p
o pi mpo rt
o pji tco nv
o prepo rt
o co unt
67
are distributed with O Pro f ile. For example, to use the o phel p command to list available events in
the XML format, type:
scl enabl e d evto o l set-3 ' o phel p -X'
Note that you can execute any command using the scl utility, causing it to be run with the Red Hat
D eveloper Toolset binaries used in preference to the Red Hat Enterprise Linux system equivalent.
This allows you to run a shell session with Red Hat D eveloper Toolset O Pro f ile as default:
scl enabl e d evto o l set-3 ' bash'
Note
To verify the version of O Pro f ile you are using at any point, type the following at a shell
prompt:
whi ch o pco ntro l
Red Hat D eveloper Toolset's o pco ntro l executable path will begin with /o pt. Alternatively,
you can use the following command to confirm that the version number matches that for
Red Hat D eveloper Toolset O Pro f ile:
o pco ntro l --versi o n
68
Chapt er 1 3. O Profile
Red Hat Enterprise Linux 6 D eployment Guide The Deployment Guide for Red Hat
Enterprise Linux 6 describes in detail how to install, configure, and start using OProfile on this
system.
Red Hat Enterprise Linux 7 System Administrator's Guide The System Administrator's Guide for
Red Hat Enterprise Linux 7 documents relevant information regarding the deployment,
configuration, and administration of Red Hat Enterprise Linux 7.
See Also
Section A.10, Changes in OProfile provides a comprehensive list of changes and improvements
over the Red Hat Enterprise Linux system version of O Pro f ile and the version distributed in the
previous release of Red Hat D eveloper Toolset.
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 11, SystemTap provides an introduction to Syst emT ap and explains how to use it to
monitor the activities of a running system.
Chapter 12, Valgrind explains how to use Valg rin d to profile applications and detect memory
errors and memory management problems, such as the use of uninitialized memory, improper
allocation and freeing of memory, and the use of improper arguments in system calls.
Chapter 14, Dyninst documents how to use the D yninst library to instrument a user-space
executable.
69
70
Chapt er 1 4 . Dyninst
See Chapter 11, SystemTap for more information about the Red Hat D eveloper Toolset version of
Syst emT ap . For a general introduction to Syst emT ap and its usage, see the SystemTap Beginners
Guide for Red Hat Enterprise Linux 6 or the SystemTap Beginners Guide for Red Hat Enterprise Linux 7.
print_iteration(i);
return 0;
}
This program prompts the user to enter a starting number and then counts down to 1, calling the
pri nt_i terati o n() function for each iteration in order to print the number to the standard
output. To compile this program on the command line using the g + + compiler from Red Hat
D eveloper Toolset, type the following at a shell prompt:
~]$ scl enabl e d evto o l set-3 ' g + + -g -o exerci se exerci se. C '
Now consider another source file named co unt. stp with the following contents:
# !/usr/bin/stap
g lobal count = 0
p robe process.function("print_iteration") {
count++
}
p robe end {
printf("Function executed %d times.\n", count)
}
This Syst emT ap script prints the total number of times the pri nt_i terati o n() function was
called during the execution of a process. To run this script on the exerci se binary file, type:
~]$ scl enabl e d evto o l set-3 "stap --d yni nst -c ' . /exerci se' co unt. stp"
Enter the starting number: 5
Iteration number 5
Iteration number 4
71
Iteration number 3
Iteration number 2
Iteration number 1
Function executed 5 times.
<stdio.h>
<fcntl.h>
"BPatch.h"
"BPatch_process.h"
"BPatch_function.h"
"BPatch_Vector.h"
"BPatch_thread.h"
"BPatch_point.h"
v oid usage() {
fprintf(stderr, "Usage: count <process_id> <function>\n");
}
/ / Global information for counter
B Patch_variableExpr *counter = NULL;
v oid createCounter(BPatch_process *app, BPatch_image *appImage) {
int zero = 0;
counter = app->malloc(*appImage->findType("int"));
counter->writeValue(& zero);
}
b ool interceptfunc(BPatch_process *app,
BPatch_image *appImage,
char *funcName) {
BPatch_Vector<BPatch_function *> func;
72
Chapt er 1 4 . Dyninst
appImage->findFunction(funcName, func);
if(func.size() == 0) {
fprintf(stderr, "Unable to find function to instrument()\n");
exit (-1);
}
BPatch_Vector<BPatch_snippet *> incCount;
BPatch_Vector<BPatch_point *> *points;
points = func[0]->findPoint(BPatch_entry);
if ((*points).size() == 0) {
exit (-1);
}
}
i nt main(int argc, char *argv[]) {
int pid;
BPatch bpatch;
if (argc != 3) {
usage();
exit(1);
pid = atoi(argv[1]);
createCounter(app, appImage);
BPatch_Vector<BPatch_function*> countFuncs;
bpatch.registerExitCallback(printCount);
app->continueExecution();
while (!app->isTerminated())
bpatch.waitForStatusChange();
return 0;
}
Note that a client application is expected to destroy all Bpatch objects before any of the D yninst
library destructors are called. Otherwise the mutator might terminate unexpectedly with a
segmentation fault. To work around this problem, set the BP atch object of the mutator as a local
variable in the mai n() function. Or, if you need to use BP atch as a global variable, manually
detach all the mutatee processes before the mutator exits.
73
This program accepts a process ID and a function name as command line arguments and then
prints the total number of times the function was called during the execution of the process. You
can use the following Makefi l e to build these two files:
D TS
= /opt/rh/devtoolset-3/root
C XXFLAGS = -g -I$(DTS)/usr/include/dyninst
LBITS
:= $(shell getconf LONG_BIT)
i feq ($(LBITS),64)
DYNINSTLIBS = $(DTS)/usr/lib64/dyninst
e lse
DYNINSTLIBS = $(DTS)/usr/lib/dyninst
e ndif
. PHONY: all
a ll: count exercise
c ount: count.C
g++ $(CXXFLAGS) count.C -I /usr/include/dyninst -c
g++ $(CXXFLAGS) count.o -L $(DYNINSTLIBS) -ldyninstAPI -o count
e xercise: exercise.C
g++ $(CXXFLAGS) exercise.C -o exercise
. PHONY: clean
c lean:
rm -rf *~ *.o count exercise
To compile the two programs on the command line using the g + + compiler from Red Hat
D eveloper Toolset, run the make utility as follows:
~]$ scl enabl e d evto o l set-3 make
g++ -g -I/opt/rh/devtoolset-3/root/usr/include/dyninst count.C -c
g++ -g -I/opt/rh/devtoolset-3/root/usr/include/dyninst count.o -L
/opt/rh/devtoolset-3/root/usr/lib64/dyninst -ldyninstAPI -o count
g++ -g -I/opt/rh/devtoolset-3/root/usr/include/dyninst exercise.C -o
exercise
This creates new binary files called exerci se and co unt in the current working directory.
In one shell session, execute the exerci se binary file as follows and wait for it to prompt you to
enter the starting number:
~]$ . /exerci se
Enter the starting number:
D o not enter this number. Instead, start another shell session and type the following at its prompt
to set the D Y NINST AP I_R T _LIB environment variable and execute the co unt binary file:
~]$ expo rt D Y NINST AP I_R T _LIB= /o pt/rh/d evto o l set3/ro o t/usr/l i b6 4 /d yni nst/l i bd yni nstAP I_R T . so
~]$ . /co unt `pi d o f exerci se` pri nt_i terati o n
Finding function print_iteration(): OK
Instrumenting function print_iteration(): OK
Waiting for process 8607 to exit...
74
Chapt er 1 4 . Dyninst
Now switch back to the first shell session and enter the starting number as requested by the
exerci se program. For example:
Enter the
Iteration
Iteration
Iteration
Iteration
Iteration
starting number: 5
number 5
number 4
number 3
number 2
number 1
When the exerci se program terminates, the co unt program displays the number of times the
pri nt_i terati o n() function was executed:
Function executed 5 times.
75
Red Hat Enterprise Linux 6 SystemTap Beginners Guide The SystemTap Beginners Guide for
Red Hat Enterprise Linux 6 provides an introduction to SystemTap and its usage.
Red Hat Enterprise Linux 7 SystemTap Beginners Guide The SystemTap Beginners Guide for
Red Hat Enterprise Linux 7 provides an introduction to SystemTap and its usage.
Red Hat Enterprise Linux 6 SystemTap Tapset Reference The SystemTap Tapset Reference for
Red Hat Enterprise Linux 6 provides further details about SystemTap.
Red Hat Enterprise Linux 7 SystemTap Tapset Reference The SystemTap Tapset Reference for
Red Hat Enterprise Linux 5 provides further details about SystemTap.
See Also
Chapter 1, Red Hat Developer Toolset provides an overview of Red Hat D eveloper Toolset and more
information on how to install it on your system.
Chapter 11, SystemTap provides an introduction to Syst emT ap and explains how to use it to
monitor the activities of a running system.
Chapter 12, Valgrind explains how to use Valg rin d to profile applications and detect memory
errors and memory management problems, such as the use of uninitialized memory, improper
allocation and freeing of memory, and the use of improper arguments in system calls.
Chapter 13, OProfile explains how to use O Pro f ile to determine which sections of code consume
the greatest amount of CPU time and why.
76
77
78
Note
If you ever forget your Red Hat login information, it can be recovered at
https://access.redhat.com/site/help/LoginAssistance.html.
Diagnost ics
The diagnostics report for Red Hat Enterprise Linux is required as well. This report is also known as
a sosreport and the program to create the report is provided by the sos package. To install the sos
package and all its dependencies on your system, type the following at a shell prompt as ro o t:
yum i nstal l so s
To generate the report, run as ro o t:
so srepo rt
For more information, access the Knowledgebase article at https://access.redhat.com/kb/docs/D OC3593.
79
Company name
Contact name
Preferred method of contact (phone or email) and contact information (phone number or email
address)
Issue Severit y
D etermining an issue's severity is important to allow the GSS team to prioritize their work. There are
four levels of severity.
Severit y 1 ( u rg en t )
A problem that severely impacts your use of the software for production purposes. It halts
your business operations and has no procedural workaround.
Severit y 2 ( h ig h )
A problem where the software is functioning, but production is severely reduced. It causes a
high impact to business operations, and no workaround exists.
Severit y 3 ( med iu m)
A problem that involves partial, non-critical loss of the use of the software. There is a
medium to low impact on your business, and business continues to function by utilizing a
workaround.
Severit y 4 ( lo w)
A general usage question, report of a documentation error, or a recommendation for a
future product improvement.
For more information on determining the severity level of an issue, see
https://access.redhat.com/support/policy/severity.
Once the issue severity has been determined, submit a service request through the Customer Portal
under the C o n n ect option, or at https://access.redhat.com/support/contact/technicalSupport.html.
Note that you need your Red Hat login details in order to submit service requests.
If the severity is level 1 or 2, then follow up your service request with a phone call. Contact
information and business hours are found at
https://access.redhat.com/support/contact/technicalSupport.html.
If you have a premium subscription, then after hours support is available for Severity 1 and 2 cases.
Turn-around rates for both premium subscriptions and standard subscription can be found at
https://access.redhat.com/support/offerings/production/sla.html.
80
Important
In order to re-open a service request, you need the original service-request number.
81
82
83
an enhanced Sp ec File Ed it o r plug-in, which is now able to download source files, prepare
a buildroot, and also provides a Bui l d menu, a corresponding toolbar, and improved
support for hyperlinks in the editor;
an enhanced Syst emT ap . stp files editor, which now has improved formatting capabilities;
improved Syst emT ap graphing, which has been streamlined to be easier to launch and
configure.
84
The G C o v and G Pro f plugins now support an automatic changing of compiler and linker
options for projects which simplifies the initial setup.
The Syst emt ap plugin went through a major overhaul of its user interface, making it easier,
faster, and more reliable for generating, editing, and displaying graphics, filtering gathered
datasets, and manipulating the probe and function inventories.
The speed of indexing the D evhelp (GTK+ and GNOME) documentation has been improved
significantly.
EG it , a G it integration plug-in for Eclip se, and JG it , a Java library implementing G it , have
been updated from version 3.1 to 3.4.1. This update includes:
The command line interface has been greatly enhanced. Commands now support more
parameters and new commands have been added.
Speed has been improved by making use of the Java 7 API.
Support has been added for performing interactive rebasing in the user interface.
Blame annotations now expose more information and provide a cross-reference capability.
85
Examples for features that are supported are Unicode strings (including the predefined macros
__ST D C _UT F_16 __ and __ST D C _UT F_32__), nonreturning functions (_No return and
<stdnoreturn.h>), and alignment support (_Al i g nas, _Al i g no f, max_al i g n_t, and
<stdalign.h>).
A.2.1.1.3. Parallelism an d C o n cu rren cy
G C C 4 .7 an d lat er provides improved support for programming parallel applications:
1. The GCC compilers support the OpenMP API specification for parallel programming, version
3.1. Refer to the OpenMP website for more information about this specification.
2. The C++11 and C11 standards provide programming abstractions for multi-threaded
programs. The respective standard libraries include programming abstractions for threads
and thread-related features such as locks, condition variables, or futures. These new
versions of the standard also define a memory model that precisely specifies the runtime
behavior of a multi-threaded program, such as the guarantees provided by compilers and the
constraints programmers have to pay attention to when writing multi-threaded programs.
Note that support for the memory model is still experimental (see below for details). For more
information about the status of support for C++11 and C11, refer to Section A.2.1.1.1, C++11
and Section A.2.1.1.2, C11 respectively.
The rest of this section describes two new GCC features in more detail. Both these features make it
easier for programmers to handle concurrency (such as when multiple threads do not run truly in
parallel but instead have to synchronize concurrent access to shared state), and both provide
atomicity for access to memory but differ in their scope, applicability, and complexity of runtime
support.
C + + 11 T yp es an d G C C B u ilt - in s f o r At o mic Memo ry Access
C++11 has support for atomic types. Access to memory locations of this type is atomic, and appears
as one indivisible access even when other threads access the same memory location concurrently.
The atomicity is limited to a single read or write access or one of the other atomic operations
supported by such types (for example, two subsequent operations executed on a variable of atomic
type are each atomic separately, but do not form one joint atomic operation).
An atomic type is declared as ato mi c<T>, where T is the non-atomic base type and must be trivially
copyable (for example, ato mi c<i nt> is an atomic integer). GCC does not yet support any base type
T, but only those that can be accessed atomically with the atomic instructions offered by the target
architecture. This is not a significant limitation in practice, given that atomics are primarily designed
to expose hardware primitives in an architecture-independent fashion; pointers and integrals that are
not larger than a machine word on the target are supported as base types. Using base types that are
not yet supported results in link-time errors.
The code generated for operations on atomic types, including the memory orders, implements the
semantics specified in the C++11 standard. However, support for the C++11 memory model is still
experimental, and for example GCC might not always preserve data-race freedom when optimizing
code.
GCC also supports new built-ins for atomic memory accesses, which follow the design of the memory
model and new atomic operations. The former set of synchronization built-ins (that is, those prefixed
with __sync) are still supported.
T ran sact io n al Memo ry
Transactional Memory (TM) allows programs to declare that a piece of code is supposed to execute as
a transaction, that is, virtually atomically and in isolation from other transactions. GCC's
86
transactional memory runtime library, l i bi tm, then ensures this atomicity guarantee when executing
the compiled program. Compared to atomic memory accesses, it is a higher-level programming
abstraction, because it is not limited to single memory locations, does not require special data types
for the data it modifies, and because transactions can contain arbitrary code and be nested within
other transactions (with some restrictions explained subsequently).
GCC implements transactions as specified in the D raft Specification for Transactional Language
Constructs for C++, version 1.1. This draft does not yet specify the language constructs for C, but
GCC already supports a C-compatible subset of the constructs when compiling C source code.
The main language constructs are transaction statements and expressions, and are declared by the
__transacti o n_ato mi c or __transacti o n_rel axed keywords followed by a compound
statement or expression, respectively. The following example illustrates how to increment a global
variable y if another variable x has a value less than 10:
_ _transaction_atomic { if (x < 10) y++; }
This happens atomically even in a multi-threaded execution of the program. In particular, even
though the transaction can load x and y and store to y, all these memory accesses are virtually
executed as one indivisible step.
Note that in line with the C++11 memory model, programs that use transactions must be free of data
races. Transactions are guaranteed to be virtually executed serially in a global total order that is
determined by the transactional memory implementation and that is consistent with and contributes
to the happens-before order enforced by the rest of the program (that is, transaction semantics are
specified based on the C++11 memory model, see the draft specification linked above). Nonetheless,
if a program is not data-race-free, then it has undefined behavior. For example, a thread can first
initialize some data and then make it publicly accessible by code like this:
i nit(data);
_ _transaction_atomic { data_public = true;}
false
// data_public is initially
Another thread can then safely use the data, for instance:
_ _transaction_atomic { if (data_public) use(data); }
However, the following code has a data race and thus results in undefined behavior:
_ _transaction_atomic { temp = copy(data); if (data_public) use(temp); }
Here, co py(d ata) races with i ni t(d ata) in the initializing thread, because this can be executed
even if d ata_publ i c is not true. Another example for data races is one thread accessing a variable
x transactionally and another thread accessing it nontransactionally at potentially the same time.
Note that the data can be safely reclaimed using code like this (assuming only one thread ever does
this):
_ _transaction_atomic { data_public = false; }
d estruct(data);
Here, d estruct() does not race with potential concurrent uses of the data because after the
transaction finishes, it is guaranteed that d ata_publ i c is false and thus data is private. See the
specification and the C++11 memory model for more background information about this.
87
Note that even if transactions are required to virtually execute in a total order, this does not mean that
they execute mutually exclusive in time. Transactional memory implementations attempt to run
transactions as much in parallel as possible to provide scalable performance.
There are two variants of transactions: atomic transactions (__transacti o n_ato mi c) and relaxed
transactions (__transacti o n_rel axed ). The former guarantee atomicity with regard to all other
code, but allow only code that is known to not include nontransactional kinds of synchronization,
such as atomic or volatile memory access. In contrast, relaxed transactions allow all code (for
example calls to I/O functions), but only provide atomicity with regard to other transactions.
Therefore, atomic transactions can be nested within other atomic and relaxed transactions, but
relaxed transactions can only be nested within other relaxed transactions. Furthermore, relaxed
transactions are likely to be executed with less performance, but this depends on the implementation
and available hardware.
GCC verifies these restrictions statically at compile time (for example, the requirements on code
allowed to be called from within atomic transactions). This has implications for when transactions
call functions that are defined within other compilation unit (source file) or within libraries. To enable
such cross-compilation-unit calls for transactional code, the respective functions must be marked to
contain code that is safe to use from within atomic transactions. Programmers can do so by adding
the transacti o n_safe function attribute to the declarations of these functions and by including
this declaration when defining the function. In turn, GCC then verifies that the code in these functions
is safe for atomic transactions and generates code accordingly. If the programmer does not follow
these constraints and/or steps, compile-time or link-time errors occur. Note that within a compilation
unit, GCC detects automatically whether a function is safe for use within transactions, and the
attributes therefore typically do not need to be added. See the draft specification linked above for
further details.
GCC's transactional memory support is designed in such a way that it does not decrease the
performance of programs that do not use transactions, nor the performance of nontransactional
code, except due to the normal kinds of interference by concurrent threads that use the same
resources such as the CPU.
Transactional memory support in GCC and l i bi tm is still experimental, and both the ABI and API
could change in the future if this is required due to the evolution of the specification of the language
constructs, or due to implementation requirements. Note that when executing applications built with
the -fg nu-tm command line option, it is currently a prerequisite to also have the appropriate version
of the l i bi tm. so . 1 shared library installed.
A.2.1.1.4 . Arch it ect u re- sp ecif ic O p t io n s
Red Hat D eveloper Toolset 3.0 is only available for Red Hat Enterprise Linux 6 and 7 for the 64-bit
Intel and AMD architectures. Consequently, the options described below are only relevant to these
architectures.
Optimization for several processors is now available through the command line options described in
Table A.1, Processor Optimization Options .
T ab le A.1. Pro cesso r O p t imiz at io n O p t io n s
O p t io n
D escrip t io n
88
O p t io n
D escrip t io n
-march= co re-avx-i
-march= co re-avx2
Support for various processor-specific intrinsics and instructions is now available through the
command line options described in Table A.2, Support for Processor-specific Intrinsics and
Instructions .
T ab le A.2. Su p p o rt f o r Pro cesso r- sp ecif ic In t rin sics an d In st ru ct io n s
O p t io n
D escrip t io n
Support for Intel AVX2 intrinsics, built-in functions, and code generation.
Support for Intel BMI2 intrinsics, built-in functions, and code generation.
Implementation and automatic generation of __bui l ti n_cl z* using
the l zcnt instruction.
-mfma
Support for Intel FMA3 intrinsics and code generation.
-mfsg sbase
Enables the generation of new segment register read/write instructions
through dedicated built-ins.
-mrd rnd
Support for the Intel rd rnd instruction.
-mf16 c
Support for two additional AVX vector conversion instructions.
-mtbm
Support for TBM (Trailing Bit Manipulation) built-in functions and code
generation.
-mbmi
Support for AMD 's BMI (Bit Manipulation) built-in functions and code
generation.
-mcrc32
Support for crc32 intrinsics.
-mmo vbe
Enables the use of the mo vbe instruction to implement
__bui l ti n_bswap32 and __bui l ti n_bswap6 4 .
-mxo p, -mfma4 , and - Support for the XOP, FMA4, and LWP instruction sets for the AMD Orochi
ml wp
processors.
-mabm
Enables the use of the po pcnt and l zcnt instructions on AMD
processors.
-mpo pcnt
Enables the use of the po pcnt instruction on both AMD and Intel
processors.
-mavx2
-mbmi 2
-ml zcnt
When using the x87 floating-point unit, GCC now generates code that conforms to ISO C99 in terms
of handling of floating-point excess precision. This can be enabled by -fexcesspreci si o n= stand ard and disabled by -fexcess-preci si o n= fast. This feature is enabled by
default when using standards conformance options such as -std = c9 9 .
Vectors of type vecto r l o ng l o ng or vecto r l o ng are passed and returned using the same
method as other vectors with the VSX instruction set. Previously GCC did not adhere to the ABI for
128-bit vectors with 64-bit integer base types (see GCC PR 48857).
89
The -mreci p command line option has been added, which indicates whether the reciprocal and
reciprocal square root instructions should be used.
The -mvecl i babi = mass command line option has been added. This can be used to enable the
compiler to auto-vectorize mathematical functions using the Mathematical Acceleration Subsystem
library.
The -msi ng l e-pi c-base command line option has been added, which instructs the compiler to
avoid loading the P IC base register in function prologues. The PIC base register must be initialized
by the runtime system.
The -mbl o ck-mo ve-i nl i ne-l i mi t command line option has been added, which enables the
user to control the maximum size of inlined memcpy calls and similar.
A.2.1.1.5. Lin k- t ime O p t imiz at io n
Link-time optimization (LTO) is a compilation technique in which GCC generates an internal
representation of each compiled input file in addition to the native code, and writes both to the output
object file. Subsequently, when several object files are linked together, GCC uses the internal
representations of the compiled code to optimize inter-procedurally across all the compilation units.
This can potentially improve the performance of the generated code (for example, functions defined
in one file can potentially be inlined when called in another file).
To enable LTO, the -fl to option needs to be specified at both compile time and link time. For further
details, including interoperability with linkers and parallel execution of LTO, refer to the
documentation for -fl to in the GCC 4.7.0 Manual. Also note that the internal representation is not a
stable interface, so LTO will only apply to code generated by the same version of GCC.
Note
Use of Link-time Optimization with debug generation is not yet supported in gcc 4.7 and 4.8
and so use of the -fl to and the -g options together is unsupported in Red Hat D eveloper
Toolset.
A.2.1.1.6 . Miscellan eo u s
-O fast is now supported as a general optimization level. It operates similar to -O 3, adds options
that can yield better-optimized code, but in turn might invalidate standards compliance (for example,
-ffast-math is enabled by -O fast).
GCC can now inform users about cases in which code generation might be improved by adding
attributes such as co nst, pure, and no return to functions declared in header files. Use the Wsug g est-attri bute= [co nst| pure| no return] command line option to enable this.
Assembler code can now make use of a goto feature that allows for jumps to labels in C code.
90
compilation or runtime performance. Some of these changes are not visible to the naked eye and will
not cause problems when updating from older versions. However, some of these changes are visible,
and can cause grief to users porting to Red Hat D eveloper Toolset's version of GCC. The following
text attempts to identify major issues and suggests solutions.
A.2.1.2.1. C
Constant expressions are now handled by GCC in a way that conforms to C90 and C99. For code
expressions that can be transformed into constants by the compiler but are in fact not constant
expressions as defined by ISO C, this may cause warnings or errors.
Ill-formed redeclarations of library functions are no longer accepted by the compiler. In particular, a
function with a signature similar to the built-in declaration of a library function (for example, abo rt()
or memcpy()) must be declared with extern "C " to be considered as a redeclaration, otherwise it is
ill-formed.
D u p licat e Memb er
Consider the following struct declaration:
struct A { int *a; union { struct { int *a; }; }; };
Previously, this declaration used to be diagnosed just by the C++ compiler, now it is also diagnosed
by the C compiler. Because of the anonymous unions and structs, there is ambiguity about what . a
actually refers to and one of the fields therefore needs to be renamed.
A.2.1.2.2. C + +
H ead er D ep en d en cy C h an g es
<i o stream>, <stri ng >, and other STL headers that previously included <uni std . h> as an
implementation detail (to get some feature macros for g thr*. h purposes) no longer do so, because
it was a C++ standard violation. This can result in diagnostic output similar to the following:
error: truncate was not declared in this scope
error: sleep was not declared in this scope
error: pipe was not declared in this scope
error: there are no arguments to 'offsetof' that depend on a template
parameter, so a declaration of 'offsetof' must be available
To fix this, add the following line early in the source or header files that need it:
# include <unistd.h>
Many of the standard C++ library include files have been edited to no longer include <cstd d ef> to
get namespace-std -scoped versions of si ze_t and ptrd i ff_t. As such, C++ programs that used
the macros NULL or o ffseto f without including <cstd d ef> will no longer compile. The diagnostic
produced is similar to the following:
error: 'ptrdiff_t' does not name a type
error: 'size_t' has not been declared
error: 'NULL' was not declared in this scope
error: there are no arguments to 'offsetof' that depend on a template
parameter, so a declaration of 'offsetof' must be available
91
return f(i);
}
i nt f(int i)
return i;
}
i nt main()
return t(1);
}
The following diagnostics output will be produced:
In instantiation of int t(T) [with T = int]
required from here
error: f was not declared in this scope, and no declarations were found
by argument-dependent lookup at the point of instantiation [-fpermissive]
note: int f(int) declared here, later in the translation unit
To correct the error in this example, move the declaration of function f() before the definition of
template function t(). The -fpermi ssi ve compiler flag turns compile-time errors into warnings and
can be used as a temporary workaround.
U n in it ializ ed co n st
Consider the following declaration:
struct A { int a; A (); };
struct B : public A { };
c onst B b;
92
An attempt to compile this code now fails with the following error:
error: uninitialized const b [-fpermissive]
note: const struct B has no user-provided default constructor
This happens, because B does not have a user-provided default constructor. Either an initializer
needs to be provided, or the default constructor needs to be added.
Visib ilit y o f T emp lat e In st an t iat io n s
The ELF symbol visibility of a template instantiation is now properly constrained by the visibility of its
template arguments. For instance, users that instantiate standard library components like
std : : vecto r with hidden user defined types such as struct my_hi d d en_struct can now
expect hidden visibility for std : : vecto r<my_hi d d en_struct> symbols. As a result, users that
compile with the -fvi si bi l i ty= hi d d en command line option should be aware of the visibility of
types included from the library headers used. If the header does not explicitly control symbol
visibility, types from those headers will be hidden, along with instantiations that use those types. For
instance, consider the following code:
# include <vector>
// template std::vector has default
visibility
# include <ctime>
// struct tm has hidden visibility
t emplate class std::vector<tm>; // instantiation has hidden visibility
One approach to adjusting the visibility of a library header <fo o . h> is to create a forwarding
header on the -I include path consisting of the following:
# pragma GCC visibility push(default)
# include_next <foo.h>
# pragma GCC visibility push
U ser- d ef in ed Lit eral Su p p o rt
When compiling C++ with the -std = {c+ + 11,c+ + 0 x,g nu+ + 11,g nu+ + 0 x} command line option,
GCC 4.7.0 and later, unlike older versions, supports user-defined literals, which are incompatible with
some valid ISO C++03 code. In particular, white space is now needed after a string literal before
something that could be a valid user defined literal. Consider the following code:
c onst char *p = "foobar"__TIME__;
In C++03, the __T IME__ macro expands to some string literal and is concatenated with the other
one. In C++11, __T IME__ is not expanded and instead, operator "" __T IME__ is being looked up,
which results in a warning like:
error: unable to find string literal operator operator"" __TIME__
This applies to any string literal followed without white space by some macro. To fix this, add some
white space between the string literal and the macro name.
T akin g t h e Ad d ress o f T emp o rary
Consider the following code:
93
94
The use of the thread _l o cal keyword has currently one important limitation: when the
d l cl o se() function is used to unload a dynamically loaded D SO that contains the definition of a
thread _l o cal object, the thread _l o cal object is destroyed, its destructor is called and the D SO
is unmapped from the address space of the process. If a thread in the process tries to access the
thread _l o cal object after this, the program may terminate unexpectedly. As a result, the
programmer may have to take extra care to ensure that thread _l o cal objects in a D SO are not
referred after it has been unloaded.
See also the next item for dynamic initialization issues.
D yn amic In it ializ at io n o f T h read - lo cal Variab les
The C++11 and OpenMP standards allow thread-local and thread-private variables to have dynamic
(that is, runtime) initialization. To support this, any use of such a variable goes through a wrapper
function that performs necessary initialization.
When the use and definition of the variable are in the same translation unit, this overhead can be
optimized away, but when the use is in a different translation unit, there is significant overhead even
if the variable does not actually need dynamic initialization. If the programmer can be sure that no
use of the variable in a non-defining translation unit needs to trigger dynamic initialization (either
because the variable is statically initialized, or a use of the variable in the defining translation unit
will be executed before any uses in another translation unit), they can avoid this overhead by using
the new -fno -extern-tl s-i ni t option.
By default, g + + uses the -fextern-tl s-i ni t option.
C + + 11 At t rib u t e Syn t ax
g + + now implements the C++11 attribute syntax, for example:
[[noreturn]] void f();
C + + 11 Alig n men t Sp ecif ier
g + + now implements the C++11 alignment specifier, for example:
a lignas(double) int i;
A.2.1.2.3. C /C + + Warn in g s
GCC 4.7.0 and later adds a number of new warnings that are either enabled by default, or by using
the -Wal l option. Although these warnings do not result in a compilation failure on their own, often
-Wal l is used in conjunction with -Werro r, causing these warnings to act like errors. This section
provides a list of these new or newly enabled warnings. Unless noted otherwise, these warnings
apply to both C and C++.
The behavior of the -Wal l command line option has changed and now includes the new warning
flags -Wunused -but-set-vari abl e and, with -Wal l -Wextra, -Wunused -but-setparameter. This may result in new warnings in code that compiled cleanly with previous versions of
GCC. For example, consider the following code:
v oid fn (void)
int foo;
*/
95
96
The -fcheck= bo und s option is equivalent to the -fbo und s-check command line option.
The -fcheck= array-temps option is equivalent to the -fcheck-array-tempo rari es
command line option.
The -fcheck= d o option checks for invalid modification of loop iteration variables.
The -fcheck= recursi ve option checks for recursive calls to subroutines or functions that
are not marked as recursive.
The -fcheck= po i nter option performs pointer association checks in calls, but does not
handle undefined pointers nor pointers in expressions.
The -fcheck= al l option enables all of the above options.
A new command line option -fno -pro tect-parens has been added. This option allows the
compiler to reorder REAL and COMPLEX expressions with no regard to parentheses.
When OpenMP's WO R KSHAR E is used, array assignments and WHER E will now be run in parallel.
More Fortran 2003 and Fortran 2008 mathematical functions can now be used as initialization
expressions.
The G C C $ compiler directive now enables support for some extended attributes such as
ST D C ALL.
A.2.1.3.2. C o mp at ib ilit y C h an g es
The -O fast command line option now automatically enables the -fno -pro tect-parens and fstack-arrays flags.
Front-end optimizations can now be disabled by the -fno -fro ntend -o pti mi ze option, and
selected by the -ffro ntend -o pti mi ze option. The former is essentially only desirable if invalid
Fortran source code needs to be compiled (for example, when functionsas compared to
subroutineshave side-effects) or to work around compiler bugs.
The G FO R T R AN_USE_ST D ER R environment variable has been removed, and GNU Fortran now
always prints error messages to standard error.
The -fd ump-co re command line option and the G FO R T R AN_ER R O R _D UMP C O R E environment
variable have been removed. When encountering a serious error, GNU Fortran now always aborts
the execution of the program.
The -fbacktrace command line option is now enabled by default. When a fatal error occurs,
GNU Fortran now attempts to print a backtrace to standard error before aborting the execution of
the program. To disable this behavior, use the -fno -backtrace option.
GNU Fortran no longer supports the use of the -M command line option to generate Makefile
dependencies for the module path. To perform this operation, use the -J option instead.
To significantly reduce the number of warnings, the -Wco nversi o n command line option now
only displays warnings when a conversion leads to information loss, and a new command line
option -Wco nversi o n-extra has been added to display warnings about other conversions.
The -Wco nversi o n option is now enabled with -Wal l .
A new command line option -Wunused -d ummy-arg ument has been added. This option can be
used to display warnings about unused dummy arguments, and is now enabled with -Wal l . Note
that the -Wunused -vari abl e option previously also warned about unused dummy arguments.
97
The C O MMO N default padding has been changed. Previously, the padding was added before a
variable. Now it is added after a variable to increase the compatibility with other vendors, as well
as to help to obtain the correct output in some cases. Note that this behavior is in contrast with the
behavior of the -fal i g n-co mmo ns option.
GNU Fortran no longer links against the l i bg fo rtranbeg i n library. The MAIN__ assembler
symbol is the actual Fortran main program and is invoked by the mai n function, which is now
generated and put in the same object file as MAIN__. Note that the l i bg fo rtranbeg i n library is
still present for backward compatibility.
Some internal names used in the assembler or object file have changed for symbols declared in the
specification part of a module. If an affected module or a file using it via use association is
recompiled, the module and all files which directly use such symbols have to be recompiled as well.
This change only affects the following kind of module symbols:
Procedure pointers. Note that C-interoperable function pointers (type(c_funptr)) are not
affected, nor are procedure-pointer components.
Deferred-length character strings.
A.2.1.3.3. Fo rt ran 2003 Feat u res
Improved but still experimental support for polymorphism between libraries and programs and for
complicated inheritance patterns.
Generic interface names which have the same name as derived types are now supported, which
allows the creation of constructor functions. Note that Fortran does not support static constructor
functions; only default initialization or an explicit structure-constructor initialization are available.
Automatic (re)allocation: In intrinsic assignments to allocatable variables, the left-hand side will
be automatically allocated (if unallocated) or reallocated (if the shape or type parameter is
different). To avoid the small performance penalty, you can use a(: ) = . . . instead of a =
. . . for arrays and character strings or disable the feature using -std = f9 5 or -fno real l o c-l hs.
Experimental support of the ASSO C IAT E construct has been added.
In pointer assignments it is now possible to specify the lower bounds of the pointer and, for a
rank-1 or a simply contiguous data-target, to remap the bounds.
D eferred type parameter: For scalar allocatable and pointer variables the character length can
now be deferred.
Namelist variables with allocatable attribute, pointer attribute, and with a non-constant length type
parameter are now supported.
Support has been added for procedure-pointer function results and procedure-pointer
components (including PASS).
Support has been added for allocatable scalars (experimental), D EFER R ED type-bound
procedures, and the ER R MSG = argument of the ALLO C AT E and D EALLO C AT E statements.
The ALLO C AT E statement now supports type-specs and the SO UR C E= argument.
Rounding (R O UND = , R Z, ...) for output is now supported.
The INT _FAST {8,16 ,32,6 4 ,128}_T format for ISO _C _BIND ING intrinsic module type
parameters is now supported.
98
O P ER AT O R (*) and ASSIG NMENT (= ) are now allowed as G ENER IC type-bound procedures (i.e.
as type-bound operators).
Support for unlimited polymorphic variables (C LASS(*)) has been added. Non-constant
character lengths are not yet supported.
A.2.1.3.4 . Fo rt ran 2003 C o mp at ib ilit y
Extensible derived types with type-bound procedure or procedure pointer with P ASS attribute now
have to use C LASS in line with the Fortran 2003 standard; the workaround to use T Y P E is no longer
supported.
A.2.1.3.5. Fo rt ran 2008 Feat u res
A new command line option -std = f20 0 8ts has been added. This option enables support for
programs that conform to the Fortran 2008 standard and the draft Technical Specification (TS)
29113 on Further Interoperability of Fortran with C. For more information, refer to the Chart of
Fortran TS 29113 Features supported by GNU Fortran.
The D O C O NC UR R ENT construct is now supported. This construct can be used to specify that
individual loop iterations do not have any interdependencies.
Full single-image support except for polymorphic coarrays has been added, and can be enabled
by using the -fco array= si ng l e command line option. Additionally, GNU Fortran now provides
preliminary support for multiple images via an MPI-based coarray communication library. Note
that the library version is not yet usable as remote coarray access is not yet possible.
The ST O P and ER R O R ST O P statements have been updated to support all constant expressions.
The C O NT IG UO US attribute is now supported.
Use of ALLO C AT E with the MO LD argument is now supported.
The ST O R AG E_SIZE intrinsic inquiry function is now supported.
The NO R M2 and P AR IT Y intrinsic functions are now supported.
The following bit intrinsics have been added:
the P O P C NT and P O P P AR bit intrinsics for counting the number of 1 bits and returning the
parity;
the BG E, BG T , BLE, and BLT bit intrinsics for bitwise comparisons;
the D SHIFT L and D SHIFT R bit intrinsics for combined left and right shifts;
the MASKL and MASKR bit intrinsics for simple left and right justified masks;
the MER G E_BIT S bit intrinsic for a bitwise merge using a mask;
the SHIFT A, SHIFT L, and SHIFT R bit intrinsics for shift operations;
the transformational bit intrinsics IALL, IANY , and IP AR IT Y .
The EXEC UT E_C O MMAND _LINE intrinsic subroutine is now supported.
The IMP UR E attribute for procedures is now supported. This allows the use of ELEMENT AL
procedures without the restrictions of P UR E.
Null pointers (including NULL()) and unallocated variables can now be used as an actual
argument to optional non-pointer, non-allocatable dummy arguments, denoting an absent
99
argument.
Non-pointer variables with the T AR G ET attribute can now be used as an actual argument to
P O INT ER dummies with INT ENT (IN).
Pointers that include procedure pointers and those in a derived type (pointer components) can
now also be initialized by a target instead of only by NULL.
The EXIT statement (with construct-name) can now be used to leave the ASSO C IAT E, BLO C K, IF,
SELEC T C ASE, and SELEC T T Y P E constructs in addition to D O .
Internal procedures can now be used as actual arguments.
The named constants INT EG ER _KIND S, LO G IC AL_KIND S, R EAL_KIND S, and
C HAR AC T ER _KIND S of the intrinsic module ISO _FO R T R AN_ENV have been added. These arrays
contain the supported 'kind' values for the respective types.
The C _SIZEO F module procedures of the ISO _C _BIND ING S intrinsic module and the
C O MP ILER _VER SIO N and C O MP ILER _O P T IO NS module procedures of the
ISO _FO R T R AN_ENV intrinsic module have been implemented.
The O P EN statement now supports the NEWUNIT = option. This option returns a unique file unit
and therefore prevents inadvertent use of the same unit in different parts of the program.
Unlimited format items are now supported.
The INT {8,16 ,32} and R EAL{32,6 4 ,128} format for ISO _FO R T R AN_ENV intrinsic module
type parameters are now supported.
It is now possible to use complex arguments with the T AN, SINH, C O SH, T ANH, ASIN, AC O S, and
AT AN functions. Additionally, the new functions ASINH, AC O SH, and AT ANH have been added for
real and complex arguments, and AT AN(Y ,X) now serves as an alias for AT AN2(Y ,X).
The BLO C K construct has been implemented.
A.2.1.3.6 . Fo rt ran 2008 C o mp at ib ilit y
The implementation of the ASY NC HR O NO US attribute in GCC is now compatible with the candidate
draft of TS 29113: Technical Specification on Further Interoperability with C.
A.2.1.3.7. Fo rt ran 77 C o mp at ib ilit y
When the GNU Fortran compiler is issued with the -fno -si g n-zero option, the SIG N intrinsic now
behaves as if zero were always positive.
A.2.1.3.8. O t h er C h an g es
B AC K T R AC E In t rin sic
A new intrinsic subroutine, BAC KT R AC E, has been added. This subroutine shows a backtrace at an
arbitrary place in user code, program execution continues normally afterwards.
Flo at in g Po in t N u mb ers wit h q as Exp o n en t ial
Reading floating point numbers that use q for the exponential (such as 4 . 0 q 0 ) is now supported as
a vendor extension for better compatibility with old data files. It is strongly recommended to use the
equivalent but standard conforming e (such as 4 . 0 e0 ) for I/O.
100
For Fortran source code, consider replacing the q in floating-point literals by a kind parameter (such
as 4 . 0 e0 _q p with a suitable q p). Note that in Fortran source code replacing q with a simple e
is not equivalent.
G FO R T R AN _T MPD IR En viro n men t Variab le
The G FO R T R AN_T MP D IR environment variable for specifying a non-default directory for files
opened with ST AT US= "SC R AT C H" is not used anymore. Instead, g fo rtran checks the POSIX/GNU
standard T MP D IR environment variable and if T MP D IR is not defined, g fo rtran falls back to other
methods to determine the directory for temporary files as documented in the user manual.
T S 29 113
Assumed types (T Y P E(*)) are now supported.
Experimental support for assumed-rank arrays (d i mensi o n(. . )) has been added. Note that at the
moment, the g fo rtran array descriptor is used, which is different from the array descriptor defined in
TS 29113. For more information, see the header file of g fo rtran or use the C h asm language
interoperability tools.
A.2.1.3.9 . C aveat s
The version of module files (the . mo d files) has been incremented. Fortran modules compiled by
earlier GCC versions have to be recompiled when they are used by files compiled with GCC 4.8, as
this version of GCC is not able to read . mo d files created by earlier versions; attempting to do so
fails with an error message.
Note
The ABI of the produced assembler data itself has not changed; object files and libraries are
fully compatible with older versions except as noted in Section A.2.1.3.10, ABI Compatibility .
A.2.1.3.10. AB I C o mp at ib ilit y
Some internal names used in the assembler or object file have changed for symbols declared in the
specification part of a module. If an affected module or a file using it via use association is
recompiled, the module and all files which directly use such symbols have to be recompiled as well.
This change only affects the following kind of module symbols:
Procedure pointers. Note that C-interoperable function pointers (type(c_funptr)) are not
affected, nor are procedure-pointer components.
Deferred-length character strings.
101
Important
If these built-in functions are called before any static constructors are invoked, such as IFUNC
initialization, then the CPU detection initialization must be explicitly run using this newly
provided built-in function, __bui l ti n_cpu_i ni t(). The initialization needs to be done only
once. For example, the following is sample invocation inside an IFUNC initializer:
static void (*some_ifunc_resolver(void))(void)
__builtin_cpu_init();
if (__builtin_cpu_is("amdfam10h") ...
if (__builtin_cpu_supports("popcnt") ...
Fu n ct io n Mu lt iversio n in g
Function multiversioning allows the programmer to specify multiple versions of the same function,
each of which is specialized for a particular variant of a given target. At runtime, the appropriate
version is automatically executed depending upon the target where the execution takes place. For
example, consider the following code fragment:
_ _attribute__ ((target ("default"))) int foo () { return 0; }
_ _attribute__ ((target ("sse4.2"))) int foo () { return 1; }
_ _attribute__ ((target ("arch=atom"))) int foo () { return 2; }
When the function fo o () is executed, the result returned depends upon the architecture where the
program runs, not the architecture where the program was compiled. See the GCC Wiki for more
details.
N ew R T M an d H LE In t rin sics
Support for the Intel RTM and HLE intrinsics, built-in functions, and code generation has been added
and can be enabled by using the -mrtm and -mhl e command line options. This is done via
intrinsics for Restricted Transactional Memory (RTM) and extensions to the memory model for Hardware
Lock Elision (HLE).
For HLE, two new flags can be used to mark a lock as using hardware elision:
__AT O MIC _H LE_AC Q U IR E
102
Starts lock elision on a lock variable. The memory model in use must be
__AT O MIC _AC Q UIR E or stronger.
__AT O MIC _H LE_R ELEASE
Ends lock elision on a lock variable. The memory model must be __AT O MIC _R ELEASE or
stronger.
For example, consider the following code fragment:
| __ATOMIC_HLE_ACQUIRE))
_mm_pause ();
/ / work with the acquired lock
_ _atomic_clear (& lockvar, __ATOMIC_RELEASE | __ATOMIC_HLE_RELEASE);
The new intrinsics that support Restricted Transactional Memory are:
unsi g ned _xbeg i n (vo i d )
Attempts to start a transaction. If it succeeds, this function returns _XBEG IN_ST AR T ED ,
otherwise it returns a status value indicating why the transaction could not be started.
vo i d _xend (vo i d )
Commits the current transaction. When no transaction is active, this function causes a fault.
All memory side effects of the transactions become visible to other threads in an atomic
manner.
i nt _xtest (vo i d )
Returns a non-zero value if a transaction is currently active, or zero if it is not.
vo i d _xabo rt (unsi g ned char status)
Aborts the current transaction. When no transaction is active, this is a no-op. The
parameter status is included in the return value of any _xbeg i n() call that is aborted by
this function.
The following example illustrates the use of these intrinsics:
i f ((status = _xbegin ()) == _XBEGIN_STARTED)
// some code
_xend ();
}
e lse
// examine the status to see why the transaction failed and possibly
retry
}
T ran sact io n s U sin g T ran sact io n al Syn ch ro n iz at io n Ext en sio n s
103
Transactions in the transactional memory feature (the -fg nu-tm option) of GCC can now be run
using Transactional Synchronization Extensions (TSX) if available on x86 hardware.
Su p p o rt f o r AMD Family 15h Pro cesso rs
The x86 backend of GCC now supports CPUs based on AMD Family 15h cores with the 64-bit x86
instruction set support. This can be enabled by using the -march= bd ver3 option.
Su p p o rt f o r AMD Family 16 h Pro cesso rs
The x86 backend of GCC now supports CPUs based on AMD Family 16h cores with the 64-bit x86
instruction set support. This can be enabled by using the -march= btver2 option.
Important
Use of C++11 features in your application requires careful consideration of the above ABI
compatibility information.
Aside from the C++11 ABI, discussed above, the Red Hat Enterprise Linux Application Compatibility
Specification is unchanged for Red Hat D eveloper Toolset. When mixing objects built with Red Hat
D eveloper Toolset with those built with the Red Hat Enterprise Linux 6 or 7 toolchain (particularly
. o /. a files), the Red Hat D eveloper Toolset toolchain should be used for any linkage. This ensures
any newer library features provided only by Red Hat D eveloper Toolset are resolved at link-time.
A new standard mangling for SIMD vector types has been added to avoid name clashes on systems
with vectors of varying length. By default the compiler still uses the old mangling, but emits aliases
with the new mangling on targets that support strong aliases. -Wabi will now display a warning
about code that uses the old mangling.
A.2.1.5.2. Miscellan eo u s
104
A.2.1.5.2. Miscellan eo u s
GCC now optimizes calls to various standard C string functions such as strl en(), strchr(),
strcpy(), strcat() and stpcpy() (as well as their respective _FO R T IFY _SO UR C E variants) by
transforming them into custom, faster code. This means that there might be fewer or other calls to
those functions than in the original source code. The optimization is enabled by default at -O 2 or
higher optimization levels. It is disabled when using -fno -o pti mi ze-strl en or when optimizing
for size.
When compiling for 32-bit GNU/Linux and not optimizing for size, -fo mi t-frame-po i nter is now
enabled by default. The prior default setting can be chosen by using the -fno -o mi t-framepo i nter command line option.
Floating-point calculations on x86 targets and in strict C99 mode are now compiled by GCC with a
stricter standard conformance. This might result in those calculations executing significantly slower.
It can be disabled using -fexcess-preci si o n= fast.
Note
Use of Link-time Optimization with debug generation is not yet supported in gcc 4.7 and 4.8
and so use of the -fl to and the -g options together is unsupported in Red Hat D eveloper
Toolset.
105
Ad d ressSan it iz er
A fast memory error detector called AddressSanitizer has been added and can be enabled by using
the -fsani ti ze= ad d ress command line option. It augments memory access instructions in order
to detect use-after-free and out-of-bound accesses to objects on the heap.
T h read San it iz er
A fast data race detector called ThreadSanitizer has been added in GCC 4.8. The option to enable this
feature is -fsani ti ze= thread .
C o mp ilin g Ext remely Larg e Fu n ct io n s
Many scalability bottlenecks have been removed from GCC optimization passes. As a consequence,
it is now possible to compile extremely large functions with smaller memory consumption in less time.
N ew - O g O p t imiz at io n Level
A new general optimization level, -O g , has been introduced. This optimization level addresses the
need for fast compilation and a superior debugging experience while providing a reasonable level of
runtime performance. Overall, the development experience should be better than the default
optimization level -O 0 .
C aret D iag n o st ic Messag es
The diagnostic messages of GCC, which display a line of source code, now also show a caret that
indicates the column where the problem was detected. For example:
fred.cc:4:15: fatal error: foo: No such file or directory
#include <foo>
^
compilation terminated.
N ew - f ira- h o ist - p ressu re O p t io n
A new command line option, -fi ra-ho i st-pressure, has been added. This option uses the
register allocator to help decide when it is worthwhile to move expressions out of loops. It can reduce
the size of the compiler code, but it slows down the compiler. This option is enabled by default at O s.
N ew - f o p t - in f o O p t io n
A new command line option, -fo pt-i nfo , has been added. This option controls printing
information about the effects of particular optimization passes, and takes the following form:
-fo pt-i nfo [-info][= file_name]
The info part of the option controls what is printed. Replace it with o pti mi zed to print information
when optimization takes place, mi ssed to print information when optimization does not take place,
no te to print more verbose information, or o ptal l to print everything.
Replace file_name with the name of the file in which you want the information to be written. If you omit
this part of the option, GCC writes the information to the standard error output stream.
For example, to display a list of optimizations that were enabled by the -O 2 option but had no effect
when compiling a file named fo o . c, type:
106
Note
elf u t ils, Syst emT ap , and Valg rin d do not support the . d wo files.
A.2 .1 .1 0 . Cave at s
Ag g ressive Lo o p O p t imiz at io n s
The loop optimizer of GCC has been improved to use language constraints in order to derive bounds
for the number of iterations of a loop. The bounds are then used as a guide to loop unrolling,
peeling, and loop exit test optimizations.
The optimizations assume that the loop code does not invoke undefined behavior by, for example,
causing signed integer overflows or making out-of-bound array accesses. For example, consider the
following code fragment:
u nsigned int foo()
107
return data_data[0];
}
A.2.2. Changes Since Red Hat Developer T oolset 2.1 and Red Hat
Ent erprise Linux 7.0
The following features have been added since the release of GCC in Red Hat D eveloper Toolset 2.1
and Red Hat Enterprise Linux 7.0:
108
A new pragma, #prag ma G C C i vd ep, has been added. This pragma notifies the compiler that no
loop-carried dependencies exist that would prevent a concurrent execution with SIMD (Single
Instruction, Multiple D ata) of consecutive iterations of the loop that follows the pragma.
Mu d f lap T o o l R emo ved
The Mu d f lap runtime checking tool was removed from the G C C suite and is no longer supported.
109
110
In Red Hat D eveloper Toolset 3.0, the g o l d linker is not enabled by default. Users can explicitly
switch between l d and g o l d by using the al ternati ves mechanism.
A.3.1.1.1. N ew Feat u res
The following features have been added since the release of b in u t ils included in Red Hat
Enterprise Linux 6.6:
A new INP UT _SEC T IO N_FLAG S keyword has been added to the linker script language. This
keyword can be used to select input sections by section header flags.
A new SO R T _BY _INIT _P R IO R IT Y keyword has been added to the linker script language. This
keyword can be used to sort sections by numerical value of the GCC init_priority attribute
encoded in the section name.
A new SO R T _NO NE keyword has been added to the linker script language. This keyword can be
used to disable section sorting.
A new linker-provided symbol, __ehd r_start, has been added. When producing ELF output, this
symbol points to the ELF file header (and nearby program headers) in the program's memory
image.
A.3.1.1.2. C o mp at ib ilit y C h an g es
The following compatibility changes have been made since the release of b in u t ils included in
Red Hat Enterprise Linux 6.6:
The --co py-d t-need ed -entri es command line option is no longer enabled by default.
Instead, --no -co py-d t-need ed -entri es is now the default option.
Evaluation of linker script expressions has been significantly improved. Note that this can
negatively affect scripts that rely on undocumented behavior of the old expression evaluation.
111
The read el f and o bjd ump tools can now display the contents of the . d ebug . macro sections.
New --d warf-start and --d warf-end command line options have been added to the
read el f and o bjd ump tools. These options are used by the new Emacs mode (see the d warfmo d e. el file).
A new --i nterl eave-wi d th command line option has been added to the o bjco py tool to
allow the use of the --i nterl eave to copy a range of bytes from the input to the output.
A new --d yn-syms command line option has been added to the read el f tool. This option can
be used to dump dynamic symbol table.
A new tool, el fed i t, has been added to b in u t ils. This tool can be used to directly manipulate
ELF format binaries.
A new command line option --ad d resses (or -a for short) has been added to the ad d r2l i ne
tool. This option can be used to display addresses before function and source file names.
A new command line option --pretty-pri nt (or -p for short) has been added to the
ad d r2l i ne tool. This option can be used to produce human-readable output.
Support for d wz -m optimized debug information has been added.
The devtoolset-2-binutils-devel package now provides the d emang l e. h header file.
A.3.2. Changes Since Red Hat Developer T oolset 2.1 and Red Hat
Ent erprise Linux 7.0
The following bugs have been fixed and features added since the release of b in u t ils in Red Hat
D eveloper Toolset 2.1 and Red Hat Enterprise Linux 7.0:
The detection of uncompressed . d ebug _str sections has been fixed.
The decoding of abbreviations using the D W_FO R M_ref_ad d r attribute has been fixed.
The o b jco p y utility now supports wildcards for section names in command line options.
The BFD linker script language now supports the ALIG N_WIT H_INP UT directive for output
sections. The directive directs the linker to compute the maximum alignment of the associated
input sections and use that alignment for the output section.
The AVX-512 (512-bit Advanced Vector Extensions) are now supported.
112
A.4 .2. Changes Since Red Hat Ent erprise Linux 7.0
The following features have been added since the release of elf u t ils 0.158 in Red Hat
Enterprise Linux 7.0:
The eu-stack utility has two new options:
A new option, -d or --d ebug name, has been added for looking up D WARF debugging
information names for frame addresses.
A new option, -i or --i nl i nes, has been added for showing inlined frames using D WARF
debugging information.
The lib d welf library has been improved in a number of ways:
A new header file, l i bd wel f. h, has been added for l i bd w. so low-level D WARF or ELF
helper functions.
New functions have been added: d wel f_el f_g nu_d ebug l i nk,
d wel f_d warf_g nu_d ebug al tl i nk, and d wel f_el f_g nu_bui l d _i d .
The lib d w library has been improved in a number of ways:
Support for D WZ multifile forms, D W_FO R M_G NU_ref_al t and D W_FO R M_G NU_strp_al t, is
now enabled by default and is no longer experimental.
New functions, d warf_g etal t and d warf_setal t, have been added for getting or setting
the alternative debugging file used for the alt FORMs.
The d wfl _l i nux_pro c_fi nd _el f callback now finds ELF from process memory for
(deleted) files if the D wfl has a process state attached.
In the lib d wf l library, the d wfl _bui l d _i d _fi nd _d ebug i nfo and
d wfl _stand ard _fi nd _d ebug i nfo functions now try to resolve and set an alternative
debugging file.
113
Ne w Fe at ure s
Support for linespecs has been improved (in particular, a more consistent handling of ambiguous
linespecs, some support for labels in the program's source, and FILE:LINE support now extends to
further linespecs types). Breakpoints are now set on all matching locations in all inferiors and will
be updated according to changes in the inferior.
New inferior control commands ski p functi o n and ski p fi l e have been added. These
commands can be uses to skip certain functions and files when stepping.
The i nfo thread s command now displays the thread name as set by prctl or
pthread _setname_np. In addition, new commands thread name and thread fi nd have
been added. The thread name command accepts a name as an argument and can be used to
set the name of the current thread. The thread fi nd command accepts a regular expression
and allows the user to find threads that match it.
GD B now provides support for reading and writing a new . g d b_i nd ex section. The command
g d b-ad d -i nd ex can be used to add . g d b_i nd ex to a file, which allows GD B to load symbols
from that file faster. Note that this feature is already present in Red Hat Enterprise Linux 6.1 and
later.
The watch command has been adapted to accept -l o cati o n as an optional argument.
Two new special values can now be used when specifying the current search path for
l i bthread _d b: $sd i r represents the default system locations of shared libraries, and $pd i r
stands for the directory with the l i bthread that is used by the application.
The i nfo macro command now accepts -al l and -- as valid options.
114
To display a function parameter's entry value (that is, the value at the time of function entry), the
suffix @ entry can be added to the parameter. GD B now displays @ entry values in backtraces, if
available.
The watch command now accepts mask mask_value as an argument. This can be used to
create masked watchpoints.
The i nfo o s command has been changed and can now display information on several objects
managed by the operating system, in particular:
The i nfo o s pro cg ro ups command lists process groups.
The i nfo o s fi l es command lists file descriptors.
The i nfo o s so ckets command lists internet-domain sockets.
The i nfo o s shm command lists shared-memory regions.
The i nfo o s semapho res command lists semaphores.
The i nfo o s msg command lists message queues.
The i nfo o s mo d ul es command lists loaded kernel modules.
GD B now has support for Static Defined Tracing (SD T) probes. Currently, the only implemented
back end is for SystemTap probes (the sys/sd t. h header file). You can set a breakpoint by
using the new -pro be, -pstap, or -pro be-stap options, and inspect the probe arguments by
using the new $_pro be_arg family of convenience variables.
The symbo l -rel o ad i ng option has been deleted.
g d bserver now supports STD IO connections, for example:
(gdb) targ et remo te | ssh myho st g d bserver - hel l o
GD B is now able to print flag enums. In a flag enum, all enumerator values have no bits in
common when pairwise AND -ed. When GD B prints a value whose type is a flag enum, GD B
shows all the constants; for example, for enum E { O NE = 1, T WO = 2}:
(gdb) pri nt (enum E) 3
$1 = (ONE | TWO)
The file name part of a linespec now matches trailing components of a source file name. For
example, break g cc/expr. c: 10 0 0 now sets a breakpoint in the bui l d /g cc/expr. c file, but
not in bui l d /l i bcpp/expr. c.
The i nfo pro c and g enerate-co re-fi l e commands now work on remote targets connected
to g d bserver.
The command i nfo catch has been removed.
The Ada-specific catch excepti o n and catch assert commands now accept conditions at
the end of the command.
The i nfo stati c-tracepo i nt-marker command now works on native targets with an inprocess agent.
GD B can now set breakpoints on inline functions.
115
The . g d b_i nd ex section has been updated to include symbols for inline functions. By default,
GD B now ignores older . g d b_i nd ex sections until their . g d b_i nd ex sections can be
recreated. The new command set use-d eprecated -i nd ex-secti o ns o n causes GD B to
use any older . g d b_i nd ex sections it finds. If this option is set, the ability to set breakpoints on
inline functions is lost in symbol files with older . g d b_i nd ex sections.
The . g d b_i nd ex section has also been updated to record more information about each symbol.
GD B now provides Ada support for GD B/MI Variable Objects.
GD B now supports breakpo i nt al ways-i nserted mo d e in the reco rd target.
g d bserver now supports evaluation of breakpoint conditions. Note that you can instruct GD B to
send the breakpoint conditions in bytecode form, but g d bserver only reports the breakpoint
trigger to GD B when its condition evaluates to true.
New convenience functions $_memeq (buf1, buf2, l eng th), $_streq (str1, str2),
$_strl en(str), and $_reg ex(str, reg ex) have been added.
Target reco rd has been renamed to reco rd -ful l . Consequently, you can now use the reco rd
ful l command to record or replay an execution log. In addition, the following commands have
been renamed:
The set reco rd i nsn-number-max and sho w reco rd i nsn-number-max commands
have been renamed to set reco rd ful l i nsn-number-max and sho w reco rd ful l
i nsn-number-max.
The set reco rd memo ry-q uery and sho w reco rd memo ry-q uery commands have
been renamed to set reco rd ful l memo ry-q uery and sho w reco rd ful l memo ryq uery.
The set reco rd sto p-at-l i mi t and sho w reco rd sto p-at-l i mi t commands have
been renamed to set reco rd ful l sto p-at-l i mi t and sho w reco rd ful l sto pat-l i mi t.
A new record target, reco rd -btrace, has been added. This target uses hardware support to
record the control flow of a process and can be enabled by using the reco rd btrace command.
This record target does not support replaying the execution.
Important
The reco rd -btrace target is only available on Intel Atom processors and requires the
Linux kernel in version 2.6.32 or later.
The -epo ch command line option has been removed. This option was used by GD B mode in
Epoch, a deprecated clone of the Emacs text editor.
The ptype and whati s commands have been updated to accept an argument to control the type
formatting.
The i nfo pro c command has been updated to work on some core files.
The cd command has been enhanced and no longer requires a directory path as its first
argument. When executed with no arguments, the command now changes to the home directory.
GD B now uses GNU v3 ABI as the default C++ ABI. This has been the default option for GCC since
November 2000.
116
The i nfo tracepo i nts command has been enhanced to display i nstal l ed o n targ et or
no t i nstal l ed o n targ et for each non-pending location of a tracepoint.
Ne w Re m o t e Packe t s
A number of new remote packets have been added. See Table A.3, New Remote Packets for a
complete list.
T ab le A.3. N ew R emo t e Packet s
R emo t e Packet
D escrip t io n
Q T Buffer: si ze
Sets the size of the trace buffer. The remote stub reports support
for this packet to the q Suppo rted query.
Enables branch tracing based on Branch Trace Store (BTS) for
the current thread. The remote stub reports support for this
packet to the q Suppo rted query.
D isables branch tracing for the current thread. The remote stub
reports support for this packet to the q Suppo rted query.
Reads the traced branches for the current thread. The remote
stub reports support for this packet to the q Suppo rted query.
The previously unused annex of the q Xfer: l i brari essvr4 : read packet is now used to support passing of an
argument list. The remote stub reports support for this argument
list to the q Suppo rted query.
Q btrace: bts
Q btrace: o ff
q Xfer: btrace: read
q Xfer: l i brari essvr4 : read 's annex
Ne w RSP Packe t
A new RSP packet has been added:
A new RSP packet Q P ro g ramSi g nal s can be used to specify the signals the remote stub can
pass to the debugged program without GD B involvement.
117
New async records = tsv-created , = tsv-d el eted , and = tsv-mo d i fi ed have been added.
These async records report that a trace state variable has been created, deleted, or modified.
New async records = reco rd -started and = reco rd -sto pped have been added. These async
records report that a process record has been started or stopped.
A new async record, = memo ry-chang ed , has been added. This async record reports that the
memory has changed.
When the source is requested, the -d ata-d i sassembl e command now includes a new
ful l name field containing an absolute path to the source file name.
The ful l name filed is now always present along with the fi l e field. This field is included even if
GD B cannot find the file.
A new optional parameter, C O UNT , has been added to the -d ata-wri te-memo ry-bytes
command. This parameter can be used to allow pattern filling of memory areas.
The response to breakpoint commands and breakpoint async records now includes a new
i nstal l ed field. This field reports the current state of each non-pending tracepoint location:
when the tracepoint is installed, the value of this field is y, otherwise the value is n.
The output of the -trace-status command now includes a new trace-fi l e field. This field is
only present when examining a trace file and contains the name of this file.
Ne w Co m m ands
The following new commands have been added:
New set use-d eprecated -i nd ex-secti o ns o n| o ff and sho w use-d eprecated i nd ex-secti o ns o n| o ff commands have been added. These commands allow you to
control the use of deprecated . g d b_i nd ex sections.
New catch l o ad and catch unl o ad commands have been added. These commands allow
you to stop execution of a debugged program when a shared library is loaded or unloaded.
A new enabl e co unt command has been added. This command allows you to auto-disable a
breakpoint after several hits.
A new i nfo vtbl command has been added. This command allows you to show the virtual
method tables for C++ and Java objects.
A new expl o re command has been added. It supports two subcommands expl o re val ue and
expl o re type, and allows you to recursively explore values and types of expressions. Note that
this command is only available with Python-enabled GD B.
A new d pri ntf location,format,args. . . command has been added. This command
allows you to create a dynamic pri ntf-type breakpoint, which performs a pri ntf-like operation
and then resumes program execution.
New set pri nt symbo l and sho w pri nt symbo l commands have been added. These
commands allow you to control whether GD B attempts to display the symbol, if any, that
corresponds to addresses it prints. This functionality is enabled by default, but you can restore
the previous behavior by running the set pri nt symbo l o ff command.
New reco rd i nstructi o n-hi sto ry and reco rd functi o n-cal l -hi sto ry commands
have been added. These commands allow you to view information about an execution log without
having to replay it. The reco rd i nstructi o n-hi sto ry command displays the execution
history at instruction granularity and the reco rd functi o n-cal l -hi sto ry displays the
118
execution history at function granularity. The commands are only supported by the reco rd
btrace command.
A new command, fo , has been added. This commands serves as a shorter variant of the
fo rward -search command.
A new command, catch si g nal , has been added. This command can be used to catch signals
by their names and is similar to the hand l e command, but also allows you to attach additional
conditions or commands.
A new command, mai nt i nfo bfd s, has been added. This command can be used to list all
binary files (BFD s) opened by GD B.
Two new commands, pytho n-i nteracti ve [command] and its shorter variant pi
[command], have been added. These commands allow you to start an interactive Python prompt
or evaluate a Python command and print the results to standard output.
A new command, py [command], has been added. This command serves as a shorter variant of
the pytho n [command] command.
New enabl e type-pri nter [name. . . ] and d i sabl e type-pri nter [name. . . ]
commands have been added. These commands allow you to enable or disable type printers.
New set breakpo i nt co nd i ti o n-eval uati o n and sho w breakpo i nt co nd i ti o neval uati o n commands have been added. These commands allow you to control whether
breakpoint conditions are evaluated by GD B (the ho st option), or by g d bserver (the targ et
option). The default option, auto , chooses the most efficient available mode.
New set d pri ntf-styl e g d b| cal l | ag ent and sho w d pri ntf-styl e commands have
been added. These commands allow you to control the way in which a dynamic pri ntf is
performed: the g d b option requests a GD B pri ntf command, cal l causes d pri ntf to call a
function in the inferior, and ag ent requests that the target agent such as g d bserver does the
printing.
New set d pri ntf-functi o n expression, sho w d pri ntf-functi o n, set d pri ntfchannel expression, and sho w d pri ntf-channel commands have been added. These
commands allow you to set the function and optional first argument to the call when using the
cal l style of dynamic pri ntf.
New set d i sco nnected -d pri ntf o n| o ff and sho w d i sco nnected -d pri ntf commands
have been added. These commands allow you to control whether agent-style dynamic pri ntfs
continue to be in effect after GD B disconnects.
New set pri nt type metho d s o n| o ff and sho w pri nt type metho d s commands have
been added. These commands allow you to control whether method declarations are displayed
by the ptype command. This functionality is enabled by default.
New set pri nt type typed efs o n| o ff and sho w pri nt type typed efs commands
have been added. These commands allow you to control whether typed ef definitions are
displayed by the ptype command. This functionality is enabled by default.
New set fi l ename-d i spl ay basename| rel ati ve| abso l ute and sho w fi l enamed i spl ay commands have been added. These commands allow you to control the way in which
file names are displayed: the basename option displays only the base name of a file name,
rel ati ve displays a path relative to the compilation directory, and abso l ute displays an
absolute path to the file. The default option is rel ati ve to preserve the previous behavior.
New set trace-buffer-si ze and sho w trace-buffer-si ze commands have been added.
These commands allow you to control the size of the trace buffer for a target.
119
New set remo te trace-buffer-si ze-packet auto | o n| o ff and sho w remo te tracebuffer-si ze-packet commands have been added. These commands allow you to control the
use of the remote protocol Q T Buffer: si ze packet.
New set d ebug no ti fi cati o n and sho w d ebug no ti fi cati o n commands have been
added. These commands allow you to control whether to display debugging information for
asynchronous remote notification. This functionality is disabled by default.
A new command i nfo macro s has been added. This command accepts linespec as an optional
argument and can be used to display the definitions of macros at that linespec location. Note that
in order to do this, the debugged program must be compiled with the -g 3 command line option to
have macro information available in it.
A new command al i as has been added. This command can be used to create an alias of an
existing command.
New set pri nt entry-val ues and sho w pri nt entry-val ues commands have been
added. The set pri nt entry-val ues command accepts bo th, co mpact, d efaul t, i fneed ed , no , o nl y, and preferred as valid arguments and can be used to enable printing of
function arguments at function entry. The sho w pri nt entry-val ues command can be used
to determine whether this feature is enabled.
New set d ebug entry-val ues and sho w d ebug entry-val ues commands have been
added. The set d ebug entry-val ues command can be used to enable printing of debugging
information for determining frame argument values at function entry and virtual tail call frames.
! command has been added as an alias of shel l command.
New set extend ed -pro mpt and sho w extend ed -pro mpt commands have been added. The
set extend ed -pro mpt command enables support for a defined set of escape sequences that
can be used to display various information. The sho w extend ed -pro mpt command can be
used to determine whether the extended prompt is enabled.
New set basenames-may-d i ffer and sho w basenames-may-d i ffer commands have
been added. The set basenames-may-d i ffer command enables support for source files with
multiple base names. The sho w basenames-may-d i ffer command can be used to determine
whether this support is enabled. The default option is o ff to allow faster GD B operations.
120
The following changes have been made to the Python scripting support:
The reg i ster_pretty_pri nter function in module g d b. pri nti ng now takes an optional
repl ace argument.
The mai nt set pytho n pri nt-stack o n| o ff command has been deprecated and will be
deleted in GD B 7.5. The new command set pytho n pri nt-stack no ne| ful l | messag e has
replaced it.
A prompt substitution hook (pro mpt_ho o k) is now available to the Python API.
A new Python module g d b. pro mpt has been added to the GD B Python modules library.
Python commands and convenience-functions located in
data_directory/pytho n/g d b/co mmand / and
data_directory/pytho n/g d b/functi o n/ are now automatically loaded on GD B start-up.
Blocks now provide four new attributes: g l o bal _bl o ck, stati c_bl o ck, i s_stati c, and
i s_g l o bal .
The g d b. breakpo i nt function has been deprecated in favor of g d b. breakpo i nts.
A new class g d b. Fi ni shBreakpo i nt is provided.
Type objects for struct and uni o n types now allow access to the fields using standard Python
dictionary (mapping) methods.
A new event g d b. new_o bjfi l e has been added.
A new function d eep_i tems has been added to the g d b. types module.
The function g d b. Wri te now accepts an optional keyword stream.
Parameters can now be sub-classed in Python, which allows for implementation of the
g et_set_d o c and g et_sho w_d o c functions.
Symbols, Symbol Table, Symbol Table and Line, Object Files, Inferior, Inferior Thread, Blocks,
and Block Iterator APIs now have an i s_val i d method.
Breakpoints can now be sub-classed in Python, which allows for implementation of the sto p
function that is executed each time the inferior reaches that breakpoint.
A new function g d b. l o o kup_g l o bal _symbo l has been added. This function can be used to
look up a global symbol.
GD B values in Python are now callable if the value represents a function.
A new module g d b. types has been added.
A new module g d b. pri nti ng has been added.
New commands i nfo pretty-pri nters, enabl e pretty-pri nter, and d i sabl e prettypri nter have been added.
A new g d b. parameter("d i recto ri es") function call is now available.
A new function g d b. newest_frame has been added. This function can be used to return the
newest frame in the selected thread.
The g d b. Inferi o rT hread class now supports a new name attribute.
121
Support for inferior events has been added. Python scripts can now add observers in order to be
notified of events occurring in the process being debugged.
GD B commands implemented in Python can now be put in the g d b. C O MMAND _USER command
class.
The mai nt set pytho n pri nt-stack o n| o ff command has been removed and replaced by
set pytho n pri nt-stack.
A new class g d b. pri nti ng . Fl ag Enumerati o nP ri nter has been added. This class can be
used to apply fl ag enum-style pretty-printing to enums.
The g d b. l o o kup_symbo l function now works correctly when there is no current frame.
The g d b. Symbo l object now has an additional attribute l i ne. This attribute holds the line
number in the source at which the symbol was defined.
The g d b. Symbo l object now has an additional attribute need s_frame, and a new method
val ue. The need s_frame attribute indicates whether the symbol requires a frame to compute its
value, and the val ue method computes the symbol's value.
The g d b. Val ue object now has a new method referenced _val ue. This method can be used
to dereference a pointer as well as C++ reference values.
The g d b. Symtab object now has two new methods, g l o bal _bl o ck and stati c_bl o ck.
These methods return the global and static blocks (as g d b. Bl o ck objects) of the underlying
symbol table respectively.
A new method g d b. fi nd _pc_l i ne returns the g d b. Symtab_and _l i ne object associated
with a PC value.
The g d b. Symtab_and _l i ne object now has an additional attribute l ast. This attribute holds
the end of the address range occupied by the code for the current source line.
Users can now create vectors by using the g d b. T ype. vecto r() method.
The atexi t. reg i ster() method is now supported.
Users can now pretty-print types by using the Python API.
In addition to Pyt h o n 2.4 and later, GD B now also supports Pyt h o n 3.
A new class, g d b. Archi tecture, has been added. This class exposes the internal
representation of the architecture in the Python API.
A new method, Frame. archi tecture, has been added. This method can be used to return the
g d b. Archi tecture object corresponding to the frame's architecture.
Frame filters and frame decorators have been added.
122
New commands set auto -l o ad and sho w auto -l o ad have been added and can be used to
control automatic loading of files:
The set auto -l o ad g d b-scri pts and sho w auto -l o ad g d b-scri pts commands
control automatic loading of GD B scripts.
The set auto -l o ad pytho n-scri pts and sho w auto -l o ad pytho n-scri pts
commands control automatic loading of Python scripts.
The set auto -l o ad l o cal -g d bi ni t and sho w auto -l o ad l o cal -g d bi ni t
commands control automatic loading of . g d bi ni t from the current working directory.
The set auto -l o ad l i bthread -d b and sho w auto -l o ad l i bthread -d b commands
control automatic loading of inferior-specific l i bthread _d b.
The set auto -l o ad scri pts-d i recto ry and sho w auto -l o ad scri pts-d i recto ry
commands control the list of directories from which to automatically load GD B and Python
scripts.
The set auto -l o ad safe-path and sho w auto -l o ad safe-path commands control
the list of directories from which it is safe to automatically load all previously mentioned items.
The set d ebug auto -l o ad and sho w d ebug auto -l o ad commands control displaying
of debugging information for all previously mentioned items.
The set auto -l o ad o ff command can be used to disable automatic loading globally. You
can also use sho w auto -l o ad with no subcommand to display current settings of all
previously mentioned items.
The mai nt set pytho n auto -l o ad o n| o ff command has been replaced with set auto l o ad pytho n-scri pts o n| o ff.
The mai ntenance pri nt secti o n-scri pts command has been renamed to i nfo auto l o ad pytho n-scri pts [pattern] and is no longer classified as a maintenance-only
command.
Support for the Guile extension language has been removed.
The GNU D ebugger has been adapted to follow GCC's rules on accessing volatile objects when
reading or writing target state during expression evaluation.
A.5.2. Changes Since Red Hat Developer T oolset 2.1 and Red Hat
Ent erprise Linux 7.0
The following features have been added since the release of G D B in Red Hat D eveloper Toolset 2.1
and Red Hat Enterprise Linux 7.0:
123
A representation of line tables has been added. Line tables map source lines to their executable
locations in memory. The l i netabl e function can be used to acquire line-table information for a
particular symbol table.
A new attribute, parent_type, has been added for g d b. Fi el d objects.
g d b. Fi el d objects can now be used as subscripts on g d b. Val ue objects to access structure
elements.
A new attribute, name, has been added for g d b. T ype objects.
Valid Python operations on g d b. Val ue objects representing structs or classes now invoke the
corresponding overloaded operators if available.
A new feature, Xmethods, has been added to the Python API. Xmethods are additional methods or
replacements for existing methods of a C++ class. This feature is useful for those cases where a
method defined in C++ source code could be inlined or optimized out by the compiler, making it
unavailable to G D B .
Ne w Co m m ands
A number of new commands have been added:
A new command, catch rethro w, has been added. This command works like the catch thro w
command, but it only catches re-thrown exceptions.
A new command, mai nt check-psymtabs, has been added. This command has been renamed
from the old mai nt check-symtabs. It is used for checking the consistency of partial symbol
tables.
A new command, mai nt check-symtabs, has been added. It performs consistency checks on
full symbol tables.
A new command, mai nt expand -symtabs, has been added. It is used for expanding full symbol
tables that match an optional regular expression.
A new command, sho w co nfi g urati o n, has been added. The command displays the details of
the configuration options with which G D B was built. This command is the equivalent of the -co nfi g urati o n command line option.
A new command, remo ve-symbo l -fi l e, has been added. It can be used to remove a symbol
file added using the ad d -symbo l -fi l e command. The file to remove can be identified by its file
name:
remo ve-symbo l -fi l e FILENAME
Or by an address that lies within the boundaries of this symbol file in memory. In that case, use
the -a option:
remo ve-symbo l -fi l e -a ADDRESS
A new command, i nfo excepti o ns, has been added. It can be used to display the list of Ada
exceptions defined in the program being debugged. Optionally, a regular expression can be
supplied to limit the list of displayed exceptions:
i nfo excepti o ns REGEXP
124
If provided, only the exceptions whose names match REGEXP are listed.
The following new pairs of commands make it possible to change settings and show their values:
set d ebug symfi l e [o ff| o n]
Controls the displaying of debugging information regarding the reading of symbol files and
symbol tables within those files. The sho w d ebug symfi l e command shows the value of
this setting.
set pri nt raw frame-arg uments [o ff| o n]
Controls the displaying of frame arguments in raw mode, disregarding any defined prettyprinters. The sho w pri nt raw frame-arg uments command shows the value of this
setting.
set remo te trace-status-packet o ff| o n| auto
Controls the use of the remote-protocol q T Status packet. The packet is used to ask the
remote stub whether a trace experiment is currently running. The sho w remo te tracestatus-packet command shows the value of this setting.
set rang e-steppi ng [o ff| o n]
Controls whether G D B instructs the target to step through the corresponding range of
addresses. If disabled, single-steps are always issued. The sho w rang e-steppi ng
command shows the value of this setting. This is set to o n by default.
set startup-wi th-shel l [o ff| o n]
Controls whether the shell is used to start subprocesses. If set to o ff, processes are started
directly. The sho w startup-wi th-shel l command shows the value of this setting. This
is set to o n by default.
set co d e-cache [o ff| o n]
Controls whether the target memory cache is used for accesses to code segments,
disregarding any configured memory regions. This improves performance of remote
debugging (particularly disassembly). The sho w co d e-cache command shows the value
of this setting. This is set to o n by default.
set pri nt symbo l -l o ad i ng o ff| bri ef| ful l
Controls whether to print informational messages when loading symbol information for a
file. The default value for this option is ful l , but when debugging programs with large
numbers of shared libraries, the amount of output becomes less useful. The sho w pri nt
symbo l -l o ad i ng command shows the value of this setting.
mai nt ad a set i g no re-d escri pti ve-types [o n| o ff]
Controls whether the debugger ignores descriptive types in Ada programs. The default
value is o ff, that is, not to ignore the descriptive types. See the user manual for more
details on descriptive types and the intended usage of this option. The mai nt ad a sho w
i g no re-d escri pti ve-types command shows the value of this setting.
set auto -co nnect-nati ve-targ et [o n| o ff]
Controls whether G D B may automatically connect to the native target when not connected
to any target yet. If set to o n, G D B attempts the run, attach, and other commands with the
native target. The sho w auto -co nnect-nati ve-targ et command shows the value of
this setting.
125
this setting.
set reco rd btrace repl ay-memo ry-access read -o nl y| read -wri te
Controls what memory accesses are allowed during replays. The sho w reco rd btrace
repl ay-memo ry-access command shows the value of this setting.
mai nt set targ et-async o n| o ff
Controls whether G D B targets operate in synchronous or asynchronous mode. By default
and if available, asynchronous mode is used. Set to o ff to simplify the debugging of
problems that only occur in synchronous mode. The mai nt sho w targ et-async
command shows the value of this setting.
set mi -async [o n| o ff]
Controls whether G D B /MI uses asynchronous mode. By default, synchronous mode is
used. Set to o n to enable background execution of commands. The sho w mi -async
command shows the value of this setting. This command supersedes the set targ etasync command from previous versions of G D B .
The following series of new commands enables displaying G D B resources used by each executed
command:
mai nt set per-co mmand space [o n| o ff]
Enable or disable the displaying of the amount of memory used by each command. The
mai nt sho w per-co mmand space command shows the value of this setting.
mai nt set per-co mmand ti me [o n| o ff]
Enable or disable the displaying of the execution time of each command. The
mai nt sho w per-co mmand ti me command shows the value of this setting.
mai nt set per-co mmand symtab [o n| o ff]
Enable or disable the displaying of basic symbol-table statistics for each command. The
mai nt sho w per-co mmand symtab command shows the value of this setting.
126
The ^erro r result record returned when trying to execute an undefined G D B /MI command now
provides a variable named co d e whose content is the undefined-command error code. Support
for this feature can be verified by using the -l i st-features command, which should contain
the "und efi ned -co mmand -erro r-co d e" item.
The -trace-save command can now optionally save trace buffer in the Common Trace Format.
A new command, -d pri ntf-i nsert, has been added. It sets a dynamic pri ntf breakpoint.
The -d ata-l i st-reg i ster-val ues command now accepts an optional --ski punavai l abl e option. When used, only available registers are displayed.
A new command, -trace-frame-co l l ected , has been added. It returns objects, register
names, trace-state variables, memory ranges, and computed expressions that have been
collected in a trace frame. There is no corresponding G D B command.
The -stack-l i st-l o cal s, -stack-l i st-arg uments, and -stack-l i st-vari abl es
commands now accept the --ski p-unavai l abl e option. When used, only available locals or
arguments are displayed.
The -exec-run command now accepts the optional --start option. When used, the command
follows the same semantics as the start command, stopping the program's execution at the start
of its main subprogram. Support for this feature can be verified by using the -l i st-features
command, which should contain the "exec-run-start-o pti o n" item.
New commands, -catch-assert and -catch-excepti o ns, have been added. The commands
insert catchpoints stopping the program when Ada exceptions are raised.
A new command, -i nfo -ad a-excepti o ns, has been added. It provides the equivalent of the
new i nfo excepti o ns command in G D B .
A new command, -g d b-set mi -async [o n| o ff], has been added. It replaces the -g d b-set
targ et-async command, which has been deprecated and only serves as an alias to the new
command for backward compatibility purposes. The -g d b-set mi -async command controls
whether MI operates in asynchronous mode. If set to o n, and provided the target supports it, MI
commands are executed in the background, and G D B interprets them while the target is still
running.
Ne w Fe at ure s in Re m o t e Packe t s
Two remote packets have had their feature set expanded:
The vC o nt packet now supports a new r start,end action. The action instructs the remote stub
to perform one step and then continue stepping through the address range specified by the start
(inclusive) and end (exclusive) parameters.
The q Xfer: btrace: read packet now supports a new annex, d el ta, to read the branch trace
incrementally.
127
A new option, --d ebug -fo rmat= o pti o n1[,o pti o n2, . . . ], has been added. It allows for
adding additional text to each output. At present, only time stamps are supported: --d ebug fo rmat= ti mestamps. Time stamps can also be turned on with the mo ni to r set d ebug fo rmat ti mestamps command in G D B .
Ge ne ral Change s
The Fission D WP file format in version 2 is now supported. To use Fission, supply the -g spl i td warf option to g cc to generate split D WARF files at compile time. This option must be used in
conjunction with the -c option, which disables linking, because Fission cannot be used when
compiling and linking in the same step. See http://gcc.gnu.org/wiki/D ebugFission for more
information about the Fission project.
Access to Intel MPX registers is now supported.
Support for Intel AVX-512 registers has been added, that is, support for displaying and
modifying the following Intel AVX-512 registers: $zmm0 $zmm31, $k0 $k7, $xmm16 $xmm31,
and $ymm16 $ymm31.
A new convenience function, $_i svo i d (expression), has been added. The function returns
1 if the type of the evaluated expression is void. In other cases, it returns 0 .
When displaying the values of registers for which the debugging information shows that they
have not been saved in the frame, and there is no place to retrieve them from (callee-saved or callclobbered registers), the <no t saved > message is now consistently printed.
A new formatter, z, has been added. When printing and examining memory, this formatter causes
the value to be displayed as a hexadecimal zero padded on the left to the size of the type.
Target-assigned range stepping with remote targets is now supported. The achieved reduction in
the number of control packets sent to and from G D B results in an improved performance.
G D B now understands the new tvar element, which has been added to the XML in the traceframe
information. It has the i d of the collected trace state variables.
The typei d C++ operator is now supported.
A new convenience variable, $_excepti o n, has been added. It holds the exception that is being
thrown or caught at an exception-related catchpoint.
Exception-related catchpoints, such as catch thro w, can now filter exceptions by type using a
supplied regular expression.
A new convenience variable, $_exi tsi g nal , has been added. It can be used to determine the
signal number with which a program terminates if it dies due to an uncaught signal. The
$_exi tco d e is then automatically set to vo i d .
Commands, such as c& , s& , can now be executed in the background if the target supports them.
In previous versions, asynchronous execution had to be explicitly enabled using the (now
deprecated) set targ et-async o n command.
The btrace record target now supports the reco rd g o to command. For locations inside the
execution trace, the back trace is computed based on the information stored in the execution
trace.
The btrace record target now supports limited reverse execution and replay. The target does not
record data and therefore does not allow for reading the memory or registers.
128
The naming of native targets has been unified, and they are now all called n at ive. To reflect this
change, the targ et chi l d command has been replaced by targ et nati ve. Target names
feature in the output of the following commands: hel p targ et, i nfo targ et, i nfo fi l es,
and mai nt pri nt targ et-stack.
The following commands have been modified:
The unl i mi ted literal value can now be used for options that interpret the 0 or -1 values as
unlimited.
The set d ebug symtab-create debugging command has been changed to accept a verbosity
level. 0 provides no debugging information, 1 provides basic debugging output, and values of 2
or greater provide a more verbose output.
The co mpare-secti o ns command now works with all targets. In previous versions, it was
limited to the remo te target.
The targ et nati ve command can now be used to explicitly connect to the native target, which
overrides the setting of the set auto -co nnect-nati ve-targ et command.
The ranges given as arguments to the reco rd functi o n-cal l -hi sto ry and
reco rd i nstructi o n-hi sto ry commands are now inclusive.
The reco rd i nstructi o n-hi sto ry command now starts counting instructions at one. This
also affects the instruction ranges reported by the reco rd functi o n-cal l -hi sto ry
command when given the /i modifier.
The tsave command now supports a new option, -ctf, to save trace data in the Common Trace
Format (CTF).
The mai ntenance pri nt o bjfi l es command now accepts an optional argument in the form
of a regular expression.
The commands set remo tebaud and sho w remo tebaud are no longer supported. Use set
seri al baud to set the baud rate for remote serial I/O and sho w seri al baud to display the
set rate.
The reco rd functi o n-cal l -hi sto ry command has been modified in a number of ways:
The command now supports a new modifier, /c, for indenting function names based on their
call-stack depth.
The fields for the /i and /l modifiers have been reordered.
The source-line range is now prefixed with at.
The instruction range is now prefixed with i nst. Both ranges are now printed as <fro m>,
<to > to allow copy-and-paste to the reco rd i nstructi o n-hi sto ry and l i st commands.
129
A new command line option, -y, has been added. This option can be used to print file descriptor
paths.
A new command line option, -P , has been added. This option can be used to filter system calls
based on the file descriptor paths.
A new command line option, -I, has been added. This option can be used to control how
interactive strace is.
A new command line utility, strace-l o g -merg e, has been added. This utility can be used to
merge timestamped strace output into a single file.
The strace utility now uses optimized interfaces to extract data from the traced process for better
performance.
The strace utility now provides improved support for decoding of arguments for various system
calls. In addition, a number of new system calls are supported.
130
131
Support has been added for probing virtual machines from the host without a network. The
probing requires a minimal runtime installed within the virtual machine, which communicates
through the virtio-serial device.
Support has been added for using . g nu_d ebug d ata symbol tables in base executables to
resolve certain probe symbols or addresses without the need for full debuginfo.
Note
Incompatibility problems with old scripts can be resolved using the backward-compatibility
option, --co mpati bl e version, where version is the version of Syst emT ap for which the
script was written.
A.9.1. Changes Since Red Hat Developer T oolset 2.1 and Red Hat
Ent erprise Linux 6.6
The following features have been added since the release of Valg rin d 3.8.1 included in Red Hat
D eveloper Toolset 2.1 and Red Hat Enterprise Linux 6.6:
A.9 .1 .1 . Change s in T o o ls
Memch eck
A new command line option, --parti al -l o ad s-o k[= argument], has been added. The option
accepts the yes or no arguments. The default is no . The option can be used to significantly
reduce the number of false error reports when handling vectorised code.
New command line options, --sho w-l eak-ki nd s[= argument] and --erro rs-fo r-l eakki nd s[= argument], have been added. Both options accept a comma-separated list of the
following arguments: d efi ni te, i nd i rect, po ssi bl e, reachabl e, as well as al l or no ne.
The default setting for both options is equivalent to passing the d efi ni te and po ssi bl e
arguments.
The options allow you to exercise a finer control over the leak checker by specifying the kinds of
leaks that are to be shown or suppressed in a full leak search and that are to count as errors in a
full leak search. Optionally, you can also specify the kinds of leaks to suppress directly in the
suppressions file using the match-l eak-ki nd s: line. Note that the generated suppressions
files now include this line by default, which makes them more specific. To get the old behavior,
remove the line prior to using the suppressions file.
A new command line option, --l eak-check-heuri sti cs[= argument], has been added. The
option accepts a comma-separated list of the following arguments: std stri ng , l eng th6 4 ,
newarray, mul ti pl ei nheri tance, as well as al l or no ne. The default is no ne. The option
improves the way the leak checker reports on possible leaks by specifying which interior pointers
are considered valid.
A new command line option, --keep-stacktraces[= argument], has been added. The option
132
A.9 .1 .2 . Ot he r Change s
The space required by Valg rin d now better corresponds with the expected capabilities of the target:
A new command line option, --num-transtab-secto rs= number, has been added. The option
can be used to specify the maximum number of sectors in the translation cache. The default
number of sectors has been increased to 16 in order to accommodate applications that need to
store large amounts of code. This improves performance because Valg rin d does not need to retranslate and re-instrument machine code so often. The number of memory-mapped segments that
can be tracked has been increased by a factor of 6.
The way Valg rin d reads debugging information has been improved:
Valg rin d no longer uses excessive amounts of virtual memory when reading debuginfo from
large shared objects. Instead of temporarily mapping entire objects for reading, Valg rin d now
uses only a small, fixed buffer.
A new command line option, --d ebug i nfo -server= ipaddress: port, has been added. This
option allows you to instruct Valg rin d to read debuginfo from objects stored on a different
machine and served by a debuginfo server, which needs to be accessible on the specified IP
address and port.
A new command line option, --al l o w-mi smatched -d ebug i nfo = argument, has been added.
The option accepts the yes and no arguments. The default is no . Using this option, you can
instruct Valg rin d to ignore inconsistencies between main and debuginfo objects. Use with
caution, as Valg rin d may not be stable when main and debugging objects do not match.
A new command line option, --merg e-recursi ve-frame= number, has been added. The option
allows you to instruct Valg rin d to detect and merge recursive algorithms, thus saving memory used
to store the recorded stack traces. The value supplied to this option determines the complexity of the
recursive calls to be merged.
A new command line option, --si g i l l -d i ag no sti cs= argument, has been added. This option
accepts the yes and no arguments. The default is yes. Use this option to control whether Valg rin d
displays a warning when encountering an instruction it is unable to decode or translate.
In order to be able to run applications that natively require up to 35 GB of memory, Valg rin d can
now use 64 GB of memory on 64-bit targets.
G D B Server Mo n it o r
133
A new client request, VALG R IND _MO NIT O R _C O MMAND , has been added to val g ri nd . h. Use it
to run g d b server monitor commands from client programs.
A new monitor command, v. i nfo o pen_fd s, has been added. It provides a list of open file
descriptors. Note that this is only available if the --track-fd s= yes option was passed on
startup.
It is now possible to pass an optional message with the v. i nfo n_errs_fo und [message]
monitor command, so that a comment can be inserted into process outputs. This helps to
separate errors reported with different tests.
A new monitor command, v. i nfo exectxt, has been added. It displays information about stack
traces (executable contexts) recorded by Valg rin d .
A new monitor command, v. d o expensi ve_sani ty_check_g eneral , has been added. It
runs various consistency checks. The command can be used to verify the sanity of the Valg rin d
heap.
A.11.1. Changes Since Red Hat Developer T oolset 2.1 and Red Hat
Ent erprise Linux 7.0
A number of bugs have been fixed. In addition to that, the following features have been added since
the release of D yn in st in Red Hat D eveloper Toolset 2.1 and Red Hat Enterprise Linux 7.0:
The Pro cC o n t ro l library has been improved to provide callbacks whenever a syscall-monitored
thread enters or exits a system call.
134
The Symt ab API library has been improved to support access to inline functions.
Checks are now performed and errors returned in case the instrumentation requires traps, but the
user has disabled them.
The generation of XMM registers save and restore has been improved, and function-call snippets
have been optimized as a result.
Block-level instrumentation performance in shared code has been improved.
Whenever possible, checks are now performed on parameter and return-value snippets.
Symbol visibility is now properly controlled, so that only public D yn in st functions and variables
are exposed to users.
135
Revision History
R evisio n 0.0- 16
T h u 13 N o v 2014
R o b ert K rt k
Release of Red Hat D eveloper Toolset 3.0 User Guide with minor post-GA fixes.
R evisio n 0.0- 14
T h u 30 O ct 2014
Release of Red Hat D eveloper Toolset 3.0 User Guide.
R o b ert K rt k
R evisio n 0.0- 10
T u e 07 O ct 2014
Release of Red Hat D eveloper Toolset 3.0 Beta-2 User Guide.
R o b ert K rt k
R evisio n 0.0- 8
T u e Sep 09 2014
Release of Red Hat D eveloper Toolset 3.0 Beta-1 User Guide.
R o b ert K rt k
Index
A
AB I
- compatibility, ABI Compatibility
ad d r2lin e
- features, New Features
- overview, binutils
- usage, Using Other Binary Tools
ap p licat io n b in ary in t erf ace ( see AB I)
ar
- overview, binutils
- usage, Using Other Binary Tools
as ( see G N U assemb ler)
assemb lin g ( see G N U assemb ler)
B
b in u t ils
-
C
C p ro g rammin g lan g u ag e
- compiling, Using the C Compiler, Preparing a Program for D ebugging
- running, Running a C Program
- support, GNU C Compiler
C + + p ro g rammin g lan g u ag e
136
D
d eb u g g in g ( see G N U D eb u g g er)
D evelo p er T o o lset ( see R ed H at D evelo p er T o o lset )
d o cu men t at io n
- Red Hat Product D ocumentation, Accessing Red Hat Product D ocumentation
DRD
- overview, Valgrind
- usage, Using Valgrind
d wp
- overview, binutils
- usage, Using Other Binary Tools
d wz
-
D yn in st
137
E
Eclip se
-
elf ed it
- features, New Features
- overview, binutils
- usage, Using Other Binary Tools
elf u t ils
-
eu - ad d r2lin e
- overview, elfutils
- usage, Using elfutils
eu - ar
- overview, elfutils
- usage, Using elfutils
eu - elf cmp
- overview, elfutils
- usage, Using elfutils
eu - elf lin t
- overview, elfutils
- usage, Using elfutils
eu - f in d t ext rel
- overview, elfutils
- usage, Using elfutils
eu - make- d eb u g - arch ive
- overview, elfutils
- usage, Using elfutils
eu - n m
- overview, elfutils
- usage, Using elfutils
eu - o b jd u mp
- overview, elfutils
- usage, Using elfutils
eu - ran lib
138
- overview, elfutils
- usage, Using elfutils
eu - read elf
- overview, elfutils
- usage, Using elfutils
eu - siz e
- overview, elfutils
- usage, Using elfutils
eu - st ack
- overview, elfutils
eu - st rin g s
- overview, elfutils
- usage, Using elfutils
eu - st rip
- overview, elfutils
- usage, Using elfutils
eu - u n st rip
- overview, elfutils
- usage, Using elfutils
F
Fo rt ran p ro g rammin g lan g u ag e
- compiling, Using the Fortran Compiler
- running, Running a Fortran Program
- support, GNU Fortran Compiler
G
g + + ( see G N U C o mp iler C o llect io n )
G AS ( see G N U assemb ler)
G C C ( see G N U C o mp iler C o llect io n )
g cc ( see G N U C o mp iler C o llect io n )
G D B ( see G N U D eb u g g er)
g f o rt ran ( see G N U C o mp iler C o llect io n )
G lo b al Su p p o rt Services
- contacting, Contacting Global Support Services
G N U assemb ler
- documentation, Additional Resources
- installation, Installing binutils
- overview, binutils
- usage, Using the GNU Assembler
G N U B in u t ils ( see b in u t ils)
G N U C o mp iler C o llect io n
- C support, GNU C Compiler
- C++ support, GNU C++ Compiler
139
H
H elg rin d
- overview, Valgrind
- usage, Using Valgrind
h elp
- Global Support Services, Contacting Global Support Services
- Red Hat Product D ocumentation, Accessing Red Hat Product D ocumentation
L
ld ( see G N U lin ker)
lin kin g ( see G N U lin ker)
lt race
-
14 0
M
Massif
- overview, Valgrind
- usage, Using Valgrind
Memch eck
- overview, Valgrind
- usage, Using Valgrind
memst o mp
- documentation, Additional Resources
- installation, Installing memstomp
- overview, memstomp
- usage, Using memstomp
- version, About Red Hat D eveloper Toolset
N
nm
- overview, binutils
- usage, Using Other Binary Tools
O
o b jco p y
- features, New Features
- overview, binutils
- usage, Using Other Binary Tools
o b jd u mp
- features, New Features
- overview, binutils
- usage, Using Other Binary Tools
o co u n t
- overview, OProfile
o p an n o t at e
- overview, OProfile
- usage, Using OProfile
o p arch ive
- overview, OProfile
- usage, Using OProfile
o p co n t ro l
- overview, OProfile
- usage, Using OProfile
o p g p ro f
- overview, OProfile
- usage, Using OProfile
o p h elp
- overview, OProfile
- usage, Using OProfile
14 1
o p imp o rt
- overview, OProfile
- usage, Using OProfile
o p jit co n v
- overview, OProfile
- usage, Using OProfile
o p rep o rt
- overview, OProfile
- usage, Using OProfile
O Pro f ile
-
o p ro f iled
- overview, OProfile
- usage, Using OProfile
R
ran lib
- overview, binutils
- usage, Using Other Binary Tools
read elf
- features, New Features
- overview, binutils
- usage, Using Other Binary Tools
R ed H at D evelo p er T o o lset
- compatibility, Compatibility
- documentation, Additional Resources, Accessing Red Hat Product D ocumentation
- features, Main Features
- installation, Installing Red Hat D eveloper Toolset
- overview, About Red Hat D eveloper Toolset
- subscription, Getting Access to Red Hat D eveloper Toolset
- support, About Red Hat D eveloper Toolset
- uninstallation, Uninstalling Red Hat D eveloper Toolset
- update, Updating Red Hat D eveloper Toolset
R ed H at En t erp rise Lin u x
- documentation, Additional Resources, Accessing Red Hat Product D ocumentation
- supported versions, Compatibility
R ed H at Su b scrip t io n Man ag emen t
- subscription, Using Red Hat Subscription Management
R H N C lassic
- subscription, Using RHN Classic
14 2
S
scl ( see So f t ware C o llect io n s)
siz e
- overview, binutils
- usage, Using Other Binary Tools
So f t ware C o llect io n s
- documentation, Additional Resources, Accessing Red Hat Product D ocumentation
- overview, About Red Hat D eveloper Toolset
st ap
- overview, SystemTap
- usage, Using SystemTap, Using D yninst with SystemTap
st ap - merg e
- overview, SystemTap
- usage, Using SystemTap
st ap - p rep
- overview, SystemTap
- usage, Installing SystemTap
st ap - rep o rt
- overview, SystemTap
- usage, Using SystemTap
st ap - server
- overview, SystemTap
st ap d yn
- overview, SystemTap
st ap ru n
- overview, SystemTap
- usage, Using SystemTap
st ap sh
- overview, SystemTap
- usage, Using SystemTap
st race
-
st rin g s
- overview, binutils
- usage, Using Other Binary Tools
st rip
- overview, binutils
- usage, Using Other Binary Tools
14 3
su p p o rt
- Red Hat D eveloper Toolset, About Red Hat D eveloper Toolset
Syst emT ap
- documentation, Additional Resources
- installation, Installing SystemTap
- overview, SystemTap
- usage, Using SystemTap, Using D yninst with SystemTap
- version, About Red Hat D eveloper Toolset, SystemTap
V
Valg rin d
-
versio n
- version, memstomp
14 4