Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

HIP: Heterogeneous Interface for Portability is developed by AMD to program on AMD GPUs. 

ROCm environment offers two automated methods for automatically converting CUDA projects to HIP:  Hipify perl a Perl script you can run on the CUDA source code to convert it to HIP format and Hipify clang a preprocessor that operates from within the HIP/ Clang compiler tool chain, converting the code as a preliminary step within the compiler process.

The hipify perl script acts directly on the CUDA source code using a series of simple string replacements. Ex., (sed e ’s/cuda/hip/g’)

To convert a CUDA file (foo.cu , for example) to HIP format, enter the following after loading a ROCm module:

The content of this section is currently being updated to include material relevant for Phase-2 of Setonix and the use of GPUs.
On the other hand, all the existing material related to Phase-1 and the use of CPU compute nodes can be considered safe, valid and up-to-date.
Column
Note
titleWork in Progress for Phase-2 Documentation
width900px


Code Block
languagebash
themeDJango
titleTerminal N. Loading ROCm module and using the hipify-perl tool for translating the code from CUDA to HIP
$ module load rocm/<version>
$ hipify-perl foo.cu > new_foo.cpp



You can then compile the HIP ready . cpp file for the ROCm environment using the HIP/ Clang compiler provided in the ROCm installation:

Column
width900px


Code Block
languagebash
themeDJango
titleTerminal N. Compiling the code with hipcc
$ hipcc new_foo.cpp



There are several other utility scripts and options available to support the porting of codes that you can find in the rocm installation. These include:

  • hipify-clang
  • hipify-perl
  • hipexamine.sh
  • hipexamine-perl.sh
  • hipconvertinplace.sh
  • hipconvertinplace-perl.sh



For example, hipify-perl -inplace option saves the HIP version of the code in the same file. The original CUDA code is saved in the backup file .prehip:

Column
width900px


Code Block
languagebash
themeDJango
titleTerminal N. Compiling the code with hipcc
$ hipify-perl -inplace <filename>


Or hipexamine-perl.sh scans a file/directory to determine which file/files contain CUDA code and how much of that code can be automatically hipified.

Code Block
$ hipexamine-perl.sh <filename/directory>

Or hipconvertinplace-perl.sh converts all the related files that are located inside the directory

Code Block
$ hipconvertinplace-perl.sh <directory>

for more information see HIP programming guide, ROCm-Developer-Tools, HIPIFY/README