Cray Compiler Environment
Overview
HPE Cray Compiling Environment (CCE) consists of compilers, libraries, and utilities that perform code analysis during compilation and automatically generate highly optimized code. Compilers support numerous command-line arguments to enable manual control over compiler behavior and optimization. Supported languages include Fortran, C and C++, and UPC (Unified Parallel C).
Implementation
CCE provides Fortran, C, and C++ compilers for HPE Cray EX, XD, and HPE Apollo 2000 Gen10Plus systems.
Introduction
HPE Cray’s proprietary Fortran compiler that fully supports the Fortran 2018 standard with some exceptions and deferred features as noted in the HPE Cray Compiling Environment Release Overview (S-5212). The HPE Fortran programming environment consisting of the tools and libraries used to develop Fortran applications. Some of those tools and libraries are outlined below.
- The ftn command, a compiler driver that compiles source into object code and links object code files and libraries to create executable files. See the crayftn(1) man page for more information. 
- The ftnlx command, which generates listing and checks for possible Fortran programming errors. See the ftnlx(1) man page for more information. 
- The ftnsplit command, which splits named Fortran files into separate files with one program unit per file, See the ftnsplit(1) man page for more information, 
- The ftnmgen command, which invokes the Fortran makefile generator. See the ftnmgen(1) man page for more information. 
- CrayLibs libraries, which provides library routines, intrinsic procedures, I/O routines, and data conversion routines. 
HPE Clang C and C++, is based on Clang/LLVM. HPE has modifed Clang/LLVM to improve the performance of generated code. The modifications also provide additional features. In general, performance improvements are enabled by default at appropriate optimization levels, but features must be requested by an option. The latest version of the full documentation for the Clang compiler is provided at https://clang.llvm.org/docs/UsersManual.html. See HPE Cray Clang C and C++ Quick Reference (S-2179) for ways in which the CCE implementation of Clang differs from the LLVM source. Compiler drivers cc and CC that set the target based on the loaded craype-arch module and link with the necessary HPE Cray libraries, including optimized math functions, memcpy, and OpenMP runtime. HPE discourages use of native clang or clang++ commands, as doing so may not find necessary paths and does not link automatically to our libraries.
Compiling and Launching
Compiling a code is typically done on a user access or login node rather than directly on a compute node. When the Cray programming environment is loaded (typically by default), use one of the HPE compiler drivers, ftn(1), cc(1), or CC(1), to quickly and easily compile, assemble, and link Fortran, C, or C++ codes, respectively. See ftn(1), cc(1), or CC(1) for more information.
After an executable is generated it is launched via a workload manager, such has PBS Professional or Slurm.
The following sections detail some of the larger CCE components.
Introduction Man Pages
These man pages introduce and explain various compiler features and concepts.
- CCE Clang User Guide
- Introduction to Compiler Directives
- Introduction to asm Intrinsics
- Introduction to Conversion
- Introduction to ffio
- Introduction to IEEE
- Introduction to intrin
- Introduction to Intrinsics
- Introduction to IO
- Introduction to libm
- Introduction to OpenACC
- Introduction to OpenMP
- Introduction to PGAS
- Introduction to pxf
- Introduction to Quad Precision
- Introduction to Timing
- Overview of CCE Compiler Interoperability
Directives
- autothread
- blockable
- blockingsize
- bounds
- buffered_async
- cache
- cache_nt
- clone
- clonealways
- collapse
- concurrent
- defer_sync
- copy_assumed_shape
- duplicate
- free
- fusion
- hand_tuned
- ident
- inline
- inlinealways
- instantiate
- interchange
- ivdep
- loop_info
- memory
- message
- nextscalar
- nofission
- nosideeffects
- opt
- optimize
- pattern
- permutation
- pgo_loop_info
- pipeline
- prefervector
- prefetch
- preprocess
- probability
- safe_address
- safe_conditional
- same_tbs
- shortloop
- stack
- suppress
- unroll
- vector
- weak
UPC Man Pages
- cray_upc_dtype_t
- cray_upc_op_create
- cray_upc_op_free
- cray_upc_return_t
- cray_upc_shared_cast
- cray_upc_sheap_info
- cray_upc_team_allreduce
- cray_upc_team_alltoall
- cray_upc_team_barrier
- cray_upc_team_free
- cray_upc_team_rank
- cray_upc_team_reduce
- cray_upc_team_size
- cray_upc_team_split
- cray_upc_team_t
- cray_upc_thread_region_begin
- cray_upc_thread_region_end
- cray_upc_thread_region_epilogue
- cray_upc_thread_region_prologue
- cray_upc_type_size
- cray_upc_user_fun
- upc_addrfield
- upc_affinitysize
- upc_all_alloc
- upc_all_broadcast
- upc_all_exchange
- upc_all_free
- upc_all_gather
- upc_all_gather_all
- upc_all_lock_alloc
- upc_all_permute
- upc_all_reduce
- upc_all_scatter
- upc_alloc
- upc_blocksizeof
- upc_cast
- upc_castable
- upc_elemsizeof
- upc_flag_t
- upc_free
- upc_global_alloc
- upc_global_exit
- upc_global_lock_alloc
- upc_localsizeof
- upc_lock
- upc_lock_attempt
- upc_lock_free
- upc_lock_t
- upc_memcpy
- upc_memget
- upc_memput
- upc_memset
- upc_nodeof
- upc_op_t
- upc_phaseof
- upc_resetphase
- upc_sync
- upc_thread_info
- upc_threadof
- upc_unlock
IEEE Man Pages
- ieee_class
- ieee_copy_sign
- ieee_get_flag
- ieee_get_halting_mode
- ieee_get_rounding_mode
- ieee_get_status
- ieee_get_underflow_mode
- ieee_is_finite
- ieee_is_nan
- ieee_is_negative
- ieee_is_normal
- ieee_logb
- ieee_next_after
- ieee_real
- ieee_rem
- ieee_rint
- ieee_scalb
- ieee_selected_real_kind
- ieee_set_flag
- ieee_set_halting_mode
- ieee_set_rounding_mode
- ieee_set_status
- ieee_set_underflow_mode
- ieee_support_datatype
- ieee_support_denormal
- ieee_support_divide
- ieee_support_flag
- ieee_support_halting
- ieee_support_inf
- ieee_support_io
- ieee_support_nan
- ieee_support_rounding
- ieee_support_sqrt
- ieee_support_standard
- ieee_support_underflow_control
- ieee_unordered
- ieee_value
Math Man Pages
AIO Man Pages
PXF Man Pages
- pxfaccess
- pxfalarm
- pxfcfgetospeed
- pxfchdir
- pxfchmod
- pxfchown
- pxfchroot
- pxfclearenv
- pxfclose
- pxfconst
- pxfcreat
- pxfctermid
- pxfdirectory
- pxfestrget
- pxfexecv
- pxffastexit
- pxffcntl
- pxffileno
- pxffork
- pxfgetarg
- pxfgetcwd
- pxfgetegid
- pxfgetenv
- pxfgeteuid
- pxfgetgid
- pxfgetgrgid
- pxfgetgrnam
- pxfgetgroups
- pxfgetlogin
- pxfgetpgrp
- pxfgetpid
- pxfgetppid
- pxfgetpwnam
- pxfgetpwuid
- pxfgetuid
- pxfintget
- pxfintset
- pxfisatty
- pxfisblk
- pxfischr
- pxfisdir
- pxfisfifo
- pxfisreg
- pxfkill
- pxflink
- pxflocaltime
- pxfopen
- pxfpause
- pxfpipe
- pxfrename
- pxfrmdir
- pxfsetenv
- pxfsetsid
- pxfsetuid
- pxfsigaddset
- pxfsigdelset
- pxfsigemptyset
- pxfsigfillset
- pxfsigismember
- pxfsigpending
- pxfsigprocmask
- pxfsigsuspend
- pxfsleep
- pxfstat
- pxfstrget
- pxfstrset
- pxfstructcopy
- pxfstructcreate
- pxfstructfree
- pxfsysconf
- pxfsystem
- pxftime
- pxftimes
- pxfucompare
- pxfumask
- pxfuname
- pxfunlink
- pxfutime
- pxfwait
Misc Man Pages
- abort
- adjustl
- adjustr
- all
- allocated
- amo
- any
- asnctl
- asnqfile
- assign
- assign
- associated
- bit_size
- btest
- c_loc
- char
- clock
- cmr
- co_bcast
- co_broadcast
- co_max
- co_min
- co_sum
- command_argument_count
- compl
- count
- cpu_time
- cri2ieg
- cry2ieg
- cshift
- csmg
- cvmg
- date
- date_and_time
- dble
- digits
- dim
- dshiftl
- dshiftr
- eoshift
- epsilon
- eqv
- erf
- ex
- execute_command_line
- exit
- explain
- expm1
- fcd
- fdcp
- ffassign
- fffcntl
- ffiolock
- fflistio
- ffopen
- ffread
- ffseek
- ffstrerror
- flush
- fp_class
- fraction
- fseek
- gbit
- get_command
- get_command_argument
- get_environment_variable
- heap_allocate
- huge
- ia2ieg
- iand
- ibchng
- ibits
- ibm2ieg
- idate
- ieu2ieg
- ilen
- index
- int_mult_upper
- ipxfargc
- ipxfwexitstatus
- ipxfwstopsig
- ipxfwtermsig
- is_iostat
- isha
- ishc
- ishft
- ishftc
- ishl
- kind
- lbound
- leadz
- len
- len_trim
- length
- lge
- lio_listio
- loc
- logical
- malloc
- mask
- matmul
- maxloc
- maxval
- merge
- minloc
- minval
- mips2ieg
- models
- mpp2ieg
- mvbits
- nearest
- not
- null
- num_images
- num_nodes
- num_pes
- numblks
- openacc.examples
- pack
- pbit
- popcnt
- poppar
- precision
- present
- radix
- ran
- random_number
- random_seed
- range
- real
- repeat
- reshape
- rrspacing
- rtc
- scale
- scan
- second
- secondr
- selected_char_kind
- selected_int_kind
- selected_real_kind
- set_exponent
- shape
- shift
- shifta
- size
- sizeof
- spacing
- spread
- sysclock
- system_clock
- this_image
- this_node
- time
- timef
- tiny
- trailz
- transfer
- transpose
- trim
- trimlen
- ubound
- unit
- unpack
- usr2ieg
- vax2ieg
- verify