Question & Answer
Question
Answer
IBM compilers for AIX are marketed as xlC/C++. The runtime environment is also xlC/C++.
These are two very different things. The runtime environment is installed with AIX and provides libraries to run C++ applications.
The xlC and xlC/C++ compilers are not provided with the AIX operating system. The compilers must be purchased separately. See the "Where to Get the Compilers" section.
Before the xlC 13.1, compiler file sets were installed with “vac” in their name, a holdover from when they were marketed as Visual Age compilers. Starting with 13.1 the compiler file sets now are installed with xlc and xlC in their names
xlCcmp
xlccmp
This is an example of runtime and compiler file sets installed on a system:
# lslpp -l | grep -i xlc
xlC.adt.include 13.1.0.0 COMMITTED C Set ++ Application
xlC.aix61.rte 13.1.3.1 COMMITTED IBM XL C++ Runtime for AIX 6.1
xlC.cpp 9.0.0.0 COMMITTED C for AIX Preprocessor
xlC.msg.en_US.cpp 9.0.0.0 COMMITTED C for AIX Preprocessor
xlC.msg.en_US.rte 13.1.3.1 COMMITTED IBM XL C++ Runtime
xlC.rte 13.1.3.1 COMMITTED IBM XL C++ Runtime for AIX
xlC.sup.aix50.rte 9.0.0.1 COMMITTED XL C/C++ Runtime for AIX 5.2
xlCcmp.13.1.0 13.1.0.0 COMMITTED XL C++ compiler
xlCcmp.13.1.0.bundle 13.1.0.0 COMMITTED XL C++ media defined bundles
xlCcmp.13.1.0.lib 13.1.0.0 COMMITTED XL C++ libraries
xlCcmp.13.1.0.license 13.1.0.0 COMMITTED XL C++ license files
xlCcmp.13.1.0.ndi 13.1.0.0 COMMITTED XL C++ non-default
xlCcmp.13.1.0.tools 13.1.0.0 COMMITTED XL C++ tools
xlccmp.13.1.0 13.1.0.0 COMMITTED XL C compiler
xlccmp.13.1.0.bundle 13.1.0.0 COMMITTED XL C media defined bundles
xlccmp.13.1.0.lib 13.1.0.0 COMMITTED XL C libraries for AIX 6.1 and
xlccmp.13.1.0.license 13.1.0.0 COMMITTED XL C license files
xlccmp.13.1.0.ndi 13.1.0.0 COMMITTED XL C non-default installation
Note that the runtime file sets all have "rte" as part of their name. Note, if xlccmp not listed in the lslpp output, you do not have the C compiler installed. If xlCcmp is not in the output, you do not have the C++ compiler installed. The C++ compiler cannot be installed without the C compiler.
/opt/IBM/xlc/13.1.0/bin
/opt/IBM/xlC/13.1.0/bin
This means you can have the 16.1.0 compiler installed next to the 13.1.0 compiler and only have to use PATH or makefile variables to point to the correct location. For example, the default installation directory for the 16.1 compilers is:
/opt/IBM/xlc/16.1.0/bin
/opt/IBM/xlC/16.1.0/bin
Compilers before 13.1 have a default installation directory of /usr/vac. If customers wanted both a 11.1 and 12.1 compiler on the same system one had to be installed using the NDI (non-default install) process.
Some customers mistakenly think they can get the C compilers from the patch update site which links to Fix Central. This site is only meant to download compiler patches. It does not provide a functional compiler. Patches only apply to the version of the compiler that is installed. You cannot patch a 12.1 compiler to 13.1, the 13.1 version needs to be purchased. This is also emphasized in the Updates section below.
Customers can either purchase the xlC compiler, which provides the C compiler, or they can purchase the xlC/C++ compiler, which provides the C and C++ compilers.
- Try, or purchase the compilers, on the IBM XL C/C++ for AIX site.
*AIX support cannot provide compiler file sets, as this is a sales function, not a support function.
Once the compiler has been purchased, there are three means for a customer to get it:
- Media provided by IBM Sales
- Download from the Passport Advantage website.
- Download from Entitled Systems Support (ESS).
The installation guide for the respective compiler versions is your best source of information on how to install, uninstall, or update the compiler software. They are readily found by searching for “xlC compiler install” on the internet.
Once the compiler has been installed, the customer must either place its location on his PATH variable, update application makefiles, or type the full path to the version he wants to use.
A simple test to make sure the compiler works is to type
cc -qversion
Here is an example program the customer can compile to prove the compiler works.
$ cat hello.c
#include <stdio.h>
int main(void) {
printf(“hello world\n”);
}
cc hello.c (for a basic compile)
./a.out (to run the program)
Patches for the C/C++ compilers and updates for the C/C++ runtime environment can be obtained from this location:
http://www-01.ibm.com/support/docview.wss?uid=swg21110831
Note that this will direct you to Fix Central under Rational software to do the actual download. Also note that an update means patching the existing compiler. It does not mean upgrading to a new compiler version, such as from xlC 11.1 to xlC 13.1. That requires purchasing the new compiler version.
1. A common issue after updating AIX is that customers try to use old compilers, that usually have never been patched, on newer versions of AIX. They will get a message stating that there is no configuration file for that version of AIX.
The most likely reason for this is that the newer version of AIX had not been released when the compiler was made available. If the compiler is still under support, as shown in the previous link, then patching it to the most current version will address the problem. An /etc/vac.cfg file that corresponds to the proper version of AIX must exist. For example,
/etc/vac.cfg.61 (for AIX 6.1)
/etc/vac.cfg.71 (for AIX 7.1)
2. Another issue is that the customer upgrades AIX and the compiler that was being used is no longer supported (for example xlC 10.1). The customer purchases and installs xlC 13.1 and still gets an error that the compiler is not supported. A common reason for this is that the customer has his PATH variable pointing to the old compiler or the makefile being used has a path referencing the old compiler.
3. Customers will sometimes compile on one version of AIX and attempt to run the binary on a different version of AIX. This is supported if the version of AIX on which the program was compiled is older than the version the binary is being run on - for example, you can compile on AIX 6.1 and expect the binary to work on AIX 7.1. However, you cannot expect a binary compiled on AIX 7.2 to work on AIX 7.1, or compiled on AIX 7.1 to work on AIX 6.1. This is because libc.a is dynamically linked into the binary and newer versions of AIX have symbol definitions that do not exist in older versions. See
Related Information
Was this topic helpful?
Document Information
Modified date:
19 January 2023
UID
isg3T1025914