README.md 2.06 KB
Newer Older
Chao Liu's avatar
Chao Liu committed
1
2
3
4
5
6
## Build docker image
```bash
DOCKER_BUILDKIT=1 docker build -t ck:latest -f Dockerfile .
```

## Launch docker
7
8
9
10
11
12
13
```bash
docker run                                     \
-it                                            \
--privileged                                   \
--group-add sudo                               \
-w /root/workspace                             \
-v ${PATH_TO_LOCAL_WORKSPACE}:/root/workspace  \
Chao Liu's avatar
Chao Liu committed
14
ck:latest                                      \
15
16
/bin/bash
```
Chao Liu's avatar
Chao Liu committed
17

Chao Liu's avatar
Chao Liu committed
18
## Build CK
19
20
21
```bash
mkdir build && cd build

Chao Liu's avatar
Chao Liu committed
22
23
24
25
26
27
28
# Need to specify target ID, example below is for gfx908 and gfx90a
cmake                                                                                             \
-D CMAKE_PREFIX_PATH=/opt/rocm                                                                    \
-D CMAKE_CXX_COMPILER=/opt/rocm/bin/hipcc                                                         \
-D CMAKE_CXX_FLAGS="-O3"                                                                          \
-D CMAKE_BUILD_TYPE=Release                                                                       \
-D GPU_TARGETS=gfx908;gfx90a                                                                      \
29
30
31
..
```

Chao Liu's avatar
Chao Liu committed
32
### Build examples and tests
33
```bash
34
 make -j examples tests
35
36
37
 make test
```

Chao Liu's avatar
Chao Liu committed
38
39
40
Instructions for running each individual examples are under ```example/```


41
42
43
44
45
## Build ckProfiler
```bash
 make -j ckProfiler
```
Instructions for running ckProfiler are under ```profiler/```
JD's avatar
JD committed
46

47
48
49
50
51
52
## Install CK
```bash
make install
```

## Using CK as pre-built kernel library
53
Instructions for using CK as a pre-built kernel library are under ```client_example/```
JD's avatar
JD committed
54
55
56
57
58
59
60
61
62

## Caveat
### Kernel Timing and Verification
CK's own kernel timer will warn up kernel once, and then run it multiple times
to get average kernel time. For some kernels that use atomic add, this will cause
output buffer to be accumulated multiple times, causing verfication failure.
To work around it, do not use CK's own timer and do verification at the same time.
CK's own timer and verification in each example and ckProfiler can be enabled or
disabled from command line.