File: Windows_Install_Guide.rst

package info (click to toggle)
rocblas 5.5.1%2Bdfsg-7
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 565,372 kB
  • sloc: cpp: 198,491; python: 44,792; f90: 25,111; sh: 24,429; asm: 8,954; xml: 222; makefile: 147; ansic: 107; awk: 14
file content (245 lines) | stat: -rw-r--r-- 11,770 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
=====================================
Installation and Building for Windows
=====================================

-------------
Prerequisites
-------------

- An AMD HIP SDK enabled platform. More information can be found `here <https://docs.amd.com/>`_.
- rocBLAS is supported on the same Windows versions and toolchains that are supported by the HIP SDK.
- As the AMD HIP SDK is new and quickly evolving it will have more up to date information regarding the SDK's internal contents.  Thus it may overrule statements found in this section on installing and building for Windows.


----------------------------
Installing Prebuilt Packages
----------------------------

rocBLAS can be installed on Windows 11 or Windows 10 using the AMD HIP SDK installer.

The simplest way to use rocBLAS in your code would be using CMake for which you would add the SDK installation location to your
`CMAKE_PREFIX_PATH`. Note you need to use quotes as the path contains a space, e.g.,

::

    -DCMAKE_PREFIX_PATH="C:\Program Files\AMD\ROCm\5.5"


in your CMake configure step and then in your CMakeLists.txt use

::

    find_package(rocblas)

    target_link_libraries( your_exe PRIVATE roc::rocblas )


Example code of consuming rocBLAS on windows with CMake can be found at `rocBLAS-Examples github page <https://github.com/ROCmSoftwarePlatform/rocBLAS-Examples>`_.

Otherwise once installed, rocBLAS can be used just like any other library with a C API.
The rocblas.h header file must be included in the user code to make calls
into rocBLAS, and the rocBLAS import library and dynamic link library will become respective link-time and run-time
dependencies for the user application.
Note an additional runtime dependency beyond the dynamic link library (.dll) file is the entire rocblas/ subdirectory found in the HIP SDK bin folder.
This must be kept in the same directory as the rocblas.dll or can be located elsewhere if setting the environment variable `ROCBLAS_TENSILE_LIBPATH` to the non-standard location.
The contents are read at execution time much like additional DLL files.

Once installed, find rocblas.h in the HIP SDK `\\include\\rocblas`
directory. Only use these two installed files when needed in user code.
Find other rocBLAS included files in HIP SDK `\\include\\rocblas\\internal`, however,
do not include these files directly into source code.


-------------------------------
Building and Installing rocBLAS
-------------------------------

For most users, building from source is not necessary, as rocBLAS can be used after installing the prebuilt
packages as described above. If desired, users can use the following instructions to build rocBLAS from source.
The codebase used for rocBLAS for the HIP SDK is the same as used for linux ROCm distribution.
However as these two distributions have different stacks the code and build process have subtle variations.


Requirements
^^^^^^^^^^^^

As a rough estimate, 64GB of system memory is required for a full rocBLAS build. This value can be lower if
rocBLAS is built with a different Tensile logic target (see the --logic command from rmake.py --help). This value
may also increase in the future as more functions are added to rocBLAS and dependencies such as Tensile grow.


Download rocBLAS
^^^^^^^^^^^^^^^^

The rocBLAS source code, which is the same as for the ROCm linux distributions, is available at the `rocBLAS github page <https://github.com/ROCmSoftwarePlatform/rocBLAS>`_.
The version of the ROCm HIP SDK may be shown in the path of default installation, but
you can run the HIP SDK compiler to report the verison from the bin/ folder with:

::

    hipcc --version

The HIP version has major, minor, and patch fields, possibly followed by a build specific identifier. For example, HIP version could be 5.4.22880-135e1ab4;
this corresponds to major = 5, minor = 4, patch = 22880, build identifier 135e1ab4.
There are GitHub branches at the rocBLAS site with names release/rocm-rel-major.minor where major and minor are the same as in the HIP version.
For example for you can use the following to download rocBLAS:

::

   git clone -b release/rocm-rel-x.y https://github.com/ROCmSoftwarePlatform/rocBLAS.git
   cd rocBLAS

Replace x.y in the above command with the version of HIP SDK installed on your machine. For example, if you have HIP 5.5 installed, then use -b release/rocm-rel-5.5
You can can add the SDK tools to your path with an entry like:

::

   %HIP_PATH%\bin

Building
^^^^^^^^

Below are steps to build using the `rmake.py` script. The user can install dependencies and build either:

* dependencies + library

* dependencies + library + client

You only need (dependencies + library) if you call rocBLAS from your code and only want the library built.
The client contains testing and benchmark tools.  rmake.py will print to the screen the full cmake command being used to configure rocBLAS based on your rmake command line options.
This full cmake command can be used in your own build scripts if you want to bypass the python helper script for a fixed set of build options.

Library Dependencies
^^^^^^^^^^^^^^^^^^^^

Dependencies installed by the python script rdeps.py are listed in the rdeps.xml configuration file. The -d flag passed to rmake.py installs dependencies the same as if
running rdeps.py directly.
Currently rdeps.py uses vcpkg and pip to install the build dependencies, with vcpkg being cloned into environment variable `VCPKG_PATH` or defaults into `C:\\github\\vckpg`.
pip will install into your current python3 environment.

The minimum version requirement for CMake is listed in the top level CMakeLists.txt file. CMake installed with Visual Studio 2022 meets this requirement.
The vcpkg version tag is specified at the top of the rdeps.py file.


Build Library dependencies + Library
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Common uses of rmake.py to build (library dependencies + library) are
in the table below:

.. tabularcolumns::
   |\X{1}{4}|\X{3}{4}|

+--------------------+--------------------------+
| Command            | Description              |
+====================+==========================+
| ``./rmake.py -h``  | Help information.        |
+--------------------+--------------------------+
| ``./rmake.py -d``  | Build library            |
|                    | dependencies and library |
|                    | in your local directory. |
|                    | The -d flag only needs   |
|                    | to be used once.         |
+--------------------+--------------------------+
| ``./rmake.py``     | Build library. It is     |
|                    | assumed dependencies     |
|                    | have been built.         |
+--------------------+--------------------------+
| ``./rmake.py -i``  | Build library, then      |
|                    | build and install        |
|                    | rocBLAS package.         |
|                    | If you want to keep      |
|                    | rocBLAS in your local    |
|                    | tree, you do not         |
|                    | need the -i flag.        |
+--------------------+--------------------------+


Build Library Dependencies + Client Dependencies + Library + Client
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Some client executables (.exe) are listed in the table below:

====================== =================================================
executable name        description
====================== =================================================
rocblas-test           runs Google Tests to test the library
rocblas-bench          executable to benchmark or test functions
rocblas-example-sscal  example C code calling rocblas_sscal function
====================== =================================================

Common uses of rmake.py to build (dependencies + library + client) are
in the table below:

.. tabularcolumns::
   |\X{1}{4}|\X{3}{4}|

+------------------------+--------------------------+
| Command                | Description              |
+========================+==========================+
| ``./rmake.py -h``      | Help information.        |
+------------------------+--------------------------+
| ``./rmake.py -dc``     | Build library            |
|                        | dependencies, client     |
|                        | dependencies, library,   |
|                        | and client in your local |
|                        | directory. The d flag    |
|                        | only needs to be used    |
|                        | once. For subsequent     |
|                        | invocations of           |
|                        | rmake.py it is not       |
|                        | necessary to rebuild the |
|                        | dependencies.            |
+------------------------+--------------------------+
| ``./rmake.py -c``      | Build library and client |
|                        | in your local directory. |
|                        | It is assumed the        |
|                        | dependencies have been   |
|                        | installed.               |
+------------------------+--------------------------+
| ``./rmake.py -idc``    | Build library            |
|                        | dependencies, client     |
|                        | dependencies, library,   |
|                        | client, then build and   |
|                        | install the rocBLAS      |
|                        | package. If              |
|                        | you want to keep rocBLAS |
|                        | in your local directory, |
|                        | you do not need the -i   |
|                        | flag.                    |
+------------------------+--------------------------+
| ``./rmake.py -ic``     | Build and install        |
|                        | rocBLAS package, and     |
|                        | build the client.        |
|                        | If you want to keep      |
|                        | rocBLAS in your local    |
|                        | directory, you do not    |
|                        | need the -i flag.        |
+------------------------+--------------------------+

Build Clients without Library
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

The rocBLAS clients can be built on their own using `rmake.py` with a pre-existing rocBLAS library.

Note that the version of the rocBLAS clients being built should match the version of the installed rocBLAS.
You can determine the version of the installed rocBLAS in the HIP SDK directory from the file include\\rocblas\\internal\\rocblas-version.h.
Find the version of rocBLAS being built if you have grep (e.g. in a git bash) with command ``grep "VERSION_STRING" CMakeLists.txt`` in the rocBLAS directory where you are building the clients.

.. tabularcolumns::
   |\X{1}{4}|\X{3}{4}|

+-------------------------------------+--------------------------+
| Command                             | Description              |
+=====================================+==========================+
| ``./rmake.py --clients-only``       | Build rocBLAS clients    |
|                                     | and use an installed     |
|                                     | rocBLAS library at       |
|                                     | HIP_PATH if no           |
|                                     | --library-path specified |
+-------------------------------------+--------------------------+
| ``./rmake.py --clients-only``       | Build rocBLAS clients    |
| ``--library-path /path/to/rocBLAS`` | and use a rocBLAS        |
|                                     | library at the specified |
|                                     | location.                |
+-------------------------------------+--------------------------+