# Release Notes The release notes for the ROCm platform. ------------------- ## ROCm 5.3.0 ### Deprecations and Warnings #### HIP Perl Scripts Deprecation The `hipcc` and `hipconfig` Perl scripts are deprecated. In a future release, compiled binaries will be available as `hipcc.bin` and `hipconfig.bin` as replacements for the Perl scripts. > **Note** > > There will be a transition period where the Perl scripts and compiled binaries are available before the scripts are removed. There will be no functional difference between the Perl scripts and their compiled binary counterpart. No user action is required. Once these are available, users can optionally switch to `hipcc.bin` and `hipconfig.bin`. The `hipcc`/`hipconfig` soft link will be assimilated to point from `hipcc`/`hipconfig` to the respective compiled binaries as the default option. #### Linux Filesystem Hierarchy Standard for ROCm ROCm packages have adopted the Linux foundation filesystem hierarchy standard in this release to ensure ROCm components follow open source conventions for Linux-based distributions. While moving to a new filesystem hierarchy, ROCm ensures backward compatibility with its 5.1 version or older filesystem hierarchy. See below for a detailed explanation of the new filesystem hierarchy and backward compatibility. ##### New Filesystem Hierarchy The following is the new filesystem hierarchy: ```text /opt/rocm- | --bin | --All externally exposed Binaries | --libexec | -- | -- Component specific private non-ISA executables (architecture independent) | --include | -- | --
| --lib | --lib.so -> lib.so.major -> lib.so.major.minor.patch (public libraries linked with application) | -- (component specific private library, executable data) | -- | --components | --.config.cmake | --share | --html//*.html | --info//*.[pdf, md, txt] | --man | --doc | -- | -- | -- | -- (arch independent non-executable) | --samples ``` > **Note** > > ROCm will not support backward compatibility with the v5.1(old) file system hierarchy in its next major release. For more information, refer to . ##### Backward Compatibility with Older Filesystems ROCm has moved header files and libraries to its new location as indicated in the above structure and included symbolic-link and wrapper header files in its old location for backward compatibility. > **Note** > > ROCm will continue supporting backward compatibility until the next major release. ##### Wrapper header files Wrapper header files are placed in the old location (`/opt/rocm-xxx//include`) with a warning message to include files from the new location (`/opt/rocm-xxx/include`) as shown in the example below: ```h // Code snippet from hip_runtime.h #pragma message “This file is deprecated. Use file from include path /opt/rocm-ver/include/ and prefix with hip”. #include "hip/hip_runtime.h" ``` The wrapper header files’ backward compatibility deprecation is as follows: - `#pragma` message announcing deprecation -- ROCm v5.2 release - `#pragma` message changed to `#warning` -- Future release - `#warning` changed to `#error` -- Future release - Backward compatibility wrappers removed -- Future release ##### Library files Library files are available in the `/opt/rocm-xxx/lib` folder. For backward compatibility, the old library location (`/opt/rocm-xxx//lib`) has a soft link to the library at the new location. Example: ```log $ ls -l /opt/rocm/hip/lib/ total 4 drwxr-xr-x 4 root root 4096 May 12 10:45 cmake lrwxrwxrwx 1 root root 24 May 10 23:32 libamdhip64.so -> ../../lib/libamdhip64.so ``` ##### CMake Config files All CMake configuration files are available in the `/opt/rocm-xxx/lib/cmake/` folder. For backward compatibility, the old CMake locations (`/opt/rocm-xxx//lib/cmake`) consist of a soft link to the new CMake config. Example: ```log $ ls -l /opt/rocm/hip/lib/cmake/hip/ total 0 lrwxrwxrwx 1 root root 42 May 10 23:32 hip-config.cmake -> ../../../../lib/cmake/hip/hip-config.cmake ``` ### Fixed Defects The following defects are fixed in this release. These defects were identified and documented as known issues in previous ROCm releases and are fixed in the ROCm v5.3 release. #### Kernel produces incorrect results with ROCm 5.2 User code did not initialize certain data constructs, leading to a correctness issue. A strict reading of the C++ standard suggests that failing to initialize these data constructs is undefined behavior. However, a special case was added for a specific compiler builtin to handle the uninitialized data in a defined manner. The compiler fix consists of the following patches: - A new `noundef` attribute is added. This attribute denotes when a function call argument or return val may never contain uninitialized bits. For more information, see - The application of this attribute was refined such that it was not added to a specific compiler builtin where the compiler knows that inactive lanes do not impact program execution. For more information, see . ### Known Issues This section consists of known issues in this release. #### Issue with OpenMP-Extras Package Upgrade The `openmp-extras` package has been split into runtime (`openmp-extras-runtime`) and dev (`openmp-extras-devel`) packages. This change has broken the upgrade support for the `openmp-extras` package in RHEL/SLES. An available workaround in RHEL is to use the following command for upgrades: ```sh sudo yum upgrade rocm-language-runtime --allowerasing ``` An available workaround in SLES is to use the following command for upgrades: ```sh zypper update --force-resolution ``` #### AMD Instinct™ MI200 SRIOV Virtualization Issue There is a known issue in this ROCm v5.3 release with all AMD Instinct™ MI200 devices running within a virtual function (VF) under SRIOV virtualization. This issue will likely impact the functionality of SRIOV-based workloads, but does not impact Discrete Device Assignment (DDA) or Bare Metal. Until a fix is provided, users should rely on ROCm v5.2.3 to support their SRIOV workloads. #### System Crash when IMMOU is Enabled If IOMMU is enabled in SBIOS and ROCm is installed, the system may report the following failure or errors when running workloads such as bandwidth test, clinfo, and HelloWord.cl and cause a system crash. - IO PAGE FAULT - IRQ remapping does not support X2APIC mode - NMI error Workaround: To avoid the system crash, add `amd_iommu=on iommu=pt` as the kernel bootparam, as indicated in the warning message.