Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ROCm Port #1087

Merged
merged 105 commits into from
Aug 25, 2023
Merged
Show file tree
Hide file tree
Changes from 74 commits
Commits
Show all changes
105 commits
Select commit Hold shift + click to select a range
0fd8363
use hipblas based on cublas
SlyEcho Apr 19, 2023
54a63c1
Update Makefile for the Cuda kernels
SlyEcho Apr 20, 2023
0e005f7
Build file changes
SlyEcho Apr 20, 2023
d3e1984
add rpath
SlyEcho Apr 21, 2023
3677235
More build file changes
SlyEcho Apr 22, 2023
db7a012
Merge 'origin/master' into hipblas
SlyEcho Apr 23, 2023
3a004b2
add rpath
SlyEcho Apr 23, 2023
608aa33
change default GPU arch to match CMake
SlyEcho Apr 25, 2023
d571d16
Merge 'origin/master' into hipblas
SlyEcho Apr 25, 2023
ef51e9e
Merge branch 'ggerganov:master' into hipblas
SlyEcho Apr 26, 2023
ecc0565
only .cu file needs to be complied as device
SlyEcho Apr 27, 2023
a1caa48
add more cuda defines
SlyEcho Apr 28, 2023
3b4a531
Merge 'origin/master' into hipblas
SlyEcho Apr 28, 2023
2ab9d11
Merge 'origin/master' into hipblas
SlyEcho Apr 28, 2023
d194586
Merge 'origin/master' into hipblas
SlyEcho Apr 28, 2023
d8ea75e
Merge 'origin/master' into hipblas
SlyEcho Apr 29, 2023
c73def1
Merge 'origin/master' into hipblas
SlyEcho Apr 30, 2023
fcbc262
Merge 'origin/master' into hipblas
SlyEcho May 1, 2023
b67cc50
Merge 'origin/master' into hipblas
SlyEcho May 3, 2023
d83cfba
Merge 'origin/master' into hipblas
SlyEcho May 4, 2023
04c0d48
Move all HIP stuff to ggml-cuda.cu
SlyEcho May 4, 2023
1107194
Merge 'origin/master' into hipblas
SlyEcho May 5, 2023
289073a
Merge 'origin/master' into hipblas
SlyEcho May 6, 2023
baeb482
Revert to default copy
SlyEcho May 7, 2023
0aefa6a
Merge 'origin/master' into hipblas
SlyEcho May 7, 2023
a3296d5
Merge 'origin/master' into hipblas
SlyEcho May 7, 2023
070cbcc
occupanct function
SlyEcho May 7, 2023
127f68e
Merge 'origin/master' into hipblas
SlyEcho May 11, 2023
605560d
Merge 'origin/master' into hipblas
SlyEcho May 12, 2023
0fe6384
fix makefile
SlyEcho May 12, 2023
2956630
Merge 'origin/master' into hipblas
SlyEcho May 13, 2023
8bab456
Merge 'origin/master' into hipblas
SlyEcho May 14, 2023
a0b2d5f
Merge 'origin/master' into hipblas
SlyEcho May 16, 2023
c66115b
Merge 'origin/master' into hipblas
SlyEcho May 20, 2023
b19fefe
Forwardcompat
SlyEcho May 20, 2023
600ace3
update warp size
SlyEcho May 20, 2023
f80ce7a
Merge branch 'origin/master' into hipblas
SlyEcho May 24, 2023
174bf6a
Merge 'origin/master' into hipblas
SlyEcho May 25, 2023
a593a4f
Add missing parameters
SlyEcho May 25, 2023
30d921a
and makefile
SlyEcho May 25, 2023
4c8b3fb
add configurable vars
SlyEcho May 25, 2023
a4648c1
Merge 'origin/master' into hipblas
SlyEcho May 27, 2023
9fdaa1d
Add more defs
SlyEcho May 27, 2023
33091a9
Merge 'origin/master' into hipblas
SlyEcho Jun 6, 2023
5d6eb72
warp size fixes
SlyEcho Jun 6, 2023
1ba4ce4
Revert "warp size fixes"
SlyEcho Jun 6, 2023
fa5b3d7
fix makefile.
SlyEcho Jun 6, 2023
4362e80
Merge 'origin/master' into hipblas
SlyEcho Jun 6, 2023
85f902d
Merge 'origin/master' into hipblas
SlyEcho Jun 8, 2023
a836529
Merge 'origin/master' into hipblas
SlyEcho Jun 14, 2023
61df8e9
add cudaMemset
SlyEcho Jun 14, 2023
6f7c156
Merge 'origin/master' into hipblas
SlyEcho Jun 17, 2023
67e229b
Merge 'origin/master' into hipblas
SlyEcho Jun 17, 2023
5dd2fbe
Merge 'origin/master' into hipblas
SlyEcho Jun 19, 2023
df7346c
Merge 'origin/master' into hipblas
SlyEcho Jun 22, 2023
35a6031
Merge 'origin/master' into hipblas
SlyEcho Jun 25, 2023
c1e5c83
Merge 'origin/master' into hipblas
SlyEcho Jun 25, 2023
c8ae945
Merge 'origin/master' into hipblas
SlyEcho Jun 27, 2023
bb16eff
headers fix; add kquants_iter for hipblas and add gfx803 (#1)
YellowRoseCx Jun 28, 2023
04419f1
Merge 'origin/master' into hipblas
SlyEcho Jun 28, 2023
15db19a
Merge 'origin/master' into hipblas
SlyEcho Jul 2, 2023
c3e3733
ROCm fixes
SlyEcho Jul 2, 2023
7735c5a
Merge 'origin/master' into hipblas
SlyEcho Jul 4, 2023
80e4e54
Merge 'origin/master' into hipblas
SlyEcho Jul 9, 2023
e610466
Expand arch list and make it overrideable
SlyEcho Jul 11, 2023
8c2c497
Merge 'origin/master' into hipblas
SlyEcho Jul 11, 2023
afcb8fe
Add new config option
SlyEcho Jul 11, 2023
cd36b18
Merge 'origin/master' into hipblas
SlyEcho Jul 13, 2023
2ec4466
Update build flags.
SlyEcho Jul 13, 2023
3db70b5
Merge 'origin/master' into hipblas
SlyEcho Jul 17, 2023
1f6294d
Fix multi GPU on multiple amd architectures with rocblas_initialize()…
YellowRoseCx Jul 24, 2023
8e8054a
Add rocblas to build files
SlyEcho Jul 24, 2023
cde52d6
Merge 'origin/master' into hipblas
SlyEcho Jul 24, 2023
d2ade63
Merge 'origin/master' into hipblas
SlyEcho Jul 29, 2023
f8e3fc6
rocblas init stuff
SlyEcho Jul 29, 2023
4336231
add hipBLAS to README
SlyEcho Jul 29, 2023
c1664a0
Merge 'origin/master' into hipblas
SlyEcho Jul 31, 2023
c1cb70d
new build arg LLAMA_CUDA_MMQ_Y
SlyEcho Jul 31, 2023
d91456a
fix half2 decomposition
ardfork Jul 31, 2023
ab62128
Merge 'origin/master' into hipblas
SlyEcho Aug 8, 2023
4024f91
Add intrinsics polyfills for AMD
SlyEcho Aug 8, 2023
610ba4c
Merge 'origin/master' into hipblas
SlyEcho Aug 9, 2023
8f8ab6c
hipLDFLAG Path change Unix to multisystem in Makefile
YellowRoseCx Aug 9, 2023
29a59b5
Fix merge
SlyEcho Aug 10, 2023
f41920e
AMD assembly optimized __dp4a
Engininja2 Aug 10, 2023
42e055d
ws fix
SlyEcho Aug 10, 2023
e6b6ae5
Undo mess
SlyEcho Aug 11, 2023
c299c4a
New __dp4a assembly
Engininja2 Aug 11, 2023
b815e97
Merge 'origin/master' into hipblas
SlyEcho Aug 11, 2023
4e58a05
Allow overriding CC_TURING
SlyEcho Aug 11, 2023
6415610
gfx1100 support
SlyEcho Aug 12, 2023
70e2f7c
Merge 'origin/master' into hipblas
SlyEcho Aug 14, 2023
68e79cc
Merge 'origin/master' into hipblas
SlyEcho Aug 16, 2023
3de6a9a
reenable LLAMA_CUDA_FORCE_DMMV
SlyEcho Aug 16, 2023
bbbc0ce
makefile rewrite
SlyEcho Aug 16, 2023
c88c2a9
probably lld is not required
SlyEcho Aug 16, 2023
423db74
Merge 'origin/master' into hipblas
SlyEcho Aug 21, 2023
391dd9a
Merge 'origin/master' into hipblas
SlyEcho Aug 22, 2023
5d3e7b2
use "ROCm" instead of "CUDA"
SlyEcho Aug 22, 2023
7b84217
Merge 'origin/master' into hipblas
SlyEcho Aug 24, 2023
058f905
ignore all build dirs
SlyEcho Aug 24, 2023
a60231f
Add Dockerfiles
SlyEcho Aug 24, 2023
81ecaa4
fix llama-bench
SlyEcho Aug 24, 2023
238335f
fix -nommq help for non CUDA/HIP
SlyEcho Aug 24, 2023
9035cfc
Merge 'origin/master' into hipblas
SlyEcho Aug 25, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 35 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ set(LLAMA_CUDA_DMMV_X "32" CACHE STRING "llama: x stride for dmmv CUDA kern
set(LLAMA_CUDA_MMV_Y "1" CACHE STRING "llama: y block size for mmv CUDA kernels")
option(LLAMA_CUDA_DMMV_F16 "llama: use 16 bit floats for dmmv CUDA kernels" OFF)
set(LLAMA_CUDA_KQUANTS_ITER "2" CACHE STRING "llama: iters./thread per block for Q2_K/Q6_K")
option(LLAMA_HIPBLAS "llama: use hipBLAS" OFF)
option(LLAMA_CLBLAST "llama: use CLBlast" OFF)
option(LLAMA_METAL "llama: use Metal" OFF)
option(LLAMA_MPI "llama: use MPI" OFF)
Expand Down Expand Up @@ -346,6 +347,40 @@ if (LLAMA_CLBLAST)
endif()
endif()

if (LLAMA_HIPBLAS)
list(APPEND CMAKE_PREFIX_PATH /opt/rocm)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ROCm path shouldn't be hardcoded to /opt/rocm. It's common to use the env var ROCM_PATH (also ROCM_HOME is sometime used). /opt/rocm should only be a fallback.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I took this from AMD's docs, but they have updated it now: Using CMake. Probably because it is not going to work in Windows.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I hadn't taken a look at AMD's docs. But they at least internally use ROCM_PATH on all the projects that I have seen.

As the CMake config would probably need change anyway for windows, and I don't think a lot of people will be impacted by not using their configured ROCm path, I think it's fine to let it that way for now. But whenever change to CMake config to add support for windows, it would be nice to also add support for one of the ROCM_PATH/HIP_PATH/ROCM_HOME on linux.

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems like the latest docs say to always manually use a CMake prefix for configuring. Guess that makes sense because on Windows, people could install it anywhere.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On Windows, you'd instead have HIP_PATH set IIRC. But someone would need to check the HIP Windows SDK installation to be sure.


if (NOT ${CMAKE_C_COMPILER_ID} MATCHES "Clang")
message(WARNING "Only LLVM is supported for HIP, hint: CC=/opt/rocm/llvm/bin/clang")
endif()
if (NOT ${CMAKE_CXX_COMPILER_ID} MATCHES "Clang")
message(WARNING "Only LLVM is supported for HIP, hint: CXX=/opt/rocm/llvm/bin/clang++")
endif()

find_package(hip)
find_package(hipblas)
find_package(rocblas)

if (${hipblas_FOUND} AND ${hip_FOUND})
message(STATUS "HIP and hipBLAS found")
add_compile_definitions(GGML_USE_HIPBLAS GGML_USE_CUBLAS)
add_library(ggml-rocm OBJECT ggml-cuda.cu ggml-cuda.h)
target_compile_definitions(ggml-rocm PRIVATE GGML_CUDA_DMMV_X=${LLAMA_CUDA_DMMV_X})
target_compile_definitions(ggml-rocm PRIVATE GGML_CUDA_MMV_Y=${LLAMA_CUDA_MMV_Y})
target_compile_definitions(ggml-rocm PRIVATE K_QUANTS_PER_ITERATION=${LLAMA_CUDA_KQUANTS_ITER})
target_compile_definitions(ggml-rocm PRIVATE GGML_CUDA_FORCE_DMMV)
set_source_files_properties(ggml-cuda.cu PROPERTIES LANGUAGE CXX)
target_link_libraries(ggml-rocm PRIVATE hip::device PUBLIC hip::host roc::rocblas roc::hipblas)

if (LLAMA_STATIC)
message(FATAL_ERROR "Static linking not supported for HIP/ROCm")
endif()
set(LLAMA_EXTRA_LIBS ${LLAMA_EXTRA_LIBS} ggml-rocm)
else()
message(WARNING "hipBLAS or HIP not found. Try setting CMAKE_PREFIX_PATH=/opt/rocm")
endif()
endif()

if (LLAMA_ALL_WARNINGS)
if (NOT MSVC)
set(c_flags
Expand Down
21 changes: 21 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -252,6 +252,27 @@ ggml-opencl.o: ggml-opencl.cpp ggml-opencl.h
$(CXX) $(CXXFLAGS) -c $< -o $@
endif # LLAMA_CLBLAST

ifdef LLAMA_HIPBLAS
ROCM_PATH ?= /opt/rocm
SlyEcho marked this conversation as resolved.
Show resolved Hide resolved
CC := $(ROCM_PATH)/llvm/bin/clang
CXX := $(ROCM_PATH)/llvm/bin/clang++
GPU_TARGETS ?= gfx803 gfx900 gfx906 gfx908 gfx90a gfx1030 gfx1100
LLAMA_CUDA_DMMV_X ?= 32
LLAMA_CUDA_MMV_Y ?= 1
LLAMA_CUDA_KQUANTS_ITER ?= 2
CFLAGS += -DGGML_USE_HIPBLAS -DGGML_USE_CUBLAS $(shell $(ROCM_PATH)/bin/hipconfig -C)
CXXFLAGS += -DGGML_USE_HIPBLAS -DGGML_USE_CUBLAS $(shell $(ROCM_PATH)/bin/hipconfig -C)
LDFLAGS += -L/opt/rocm/lib -Wl,-rpath=$(ROCM_PATH)/lib -lhipblas -lamdhip64 -lrocblas
OBJS += ggml-cuda.o
ggml-cuda.o: CXXFLAGS += $(addprefix --offload-arch=,$(GPU_TARGETS))
ggml-cuda.o: CXXFLAGS += -DGGML_CUDA_DMMV_X=$(LLAMA_CUDA_DMMV_X)
ggml-cuda.o: CXXFLAGS += -DGGML_CUDA_MMV_Y=$(LLAMA_CUDA_MMV_Y)
ggml-cuda.o: CXXFLAGS += -DGGML_CUDA_FORCE_DMMV
ggml-cuda.o: CXXFLAGS += -DK_QUANTS_PER_ITERATION=$(LLAMA_CUDA_KQUANTS_ITER)
ggml-cuda.o: ggml-cuda.cu ggml-cuda.h
$(CXX) $(CXXFLAGS) -x hip -c -o $@ $<
endif # LLAMA_HIPBLAS

ifdef LLAMA_METAL
CFLAGS += -DGGML_USE_METAL -DGGML_METAL_NDEBUG
CXXFLAGS += -DGGML_USE_METAL
Expand Down
61 changes: 61 additions & 0 deletions ggml-cuda.cu
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,66 @@
#include <atomic>
#include <assert.h>

#if defined(GGML_USE_HIPBLAS)
#include <hip/hip_runtime.h>
#include <hipblas/hipblas.h>
#include <hip/hip_fp16.h>
#include "rocblas/rocblas.h"
SlyEcho marked this conversation as resolved.
Show resolved Hide resolved
#define CUBLAS_COMPUTE_32F HIPBLAS_R_32F
#define CUBLAS_COMPUTE_32F_FAST_16F HIPBLAS_R_32F
#define CUBLAS_GEMM_DEFAULT HIPBLAS_GEMM_DEFAULT
#define CUBLAS_OP_N HIPBLAS_OP_N
#define CUBLAS_OP_T HIPBLAS_OP_T
#define CUBLAS_STATUS_SUCCESS HIPBLAS_STATUS_SUCCESS
#define CUBLAS_TF32_TENSOR_OP_MATH 0
#define CUDA_R_16F HIPBLAS_R_16F
#define CUDA_R_32F HIPBLAS_R_32F
#define __shfl_xor_sync(mask, var, laneMask, width) __shfl_xor(var, laneMask, width)
#define cublasCreate hipblasCreate
#define cublasGemmEx hipblasGemmEx
#define cublasHandle_t hipblasHandle_t
#define cublasSetMathMode(handle, mode) CUBLAS_STATUS_SUCCESS
#define cublasSetStream hipblasSetStream
#define cublasSgemm hipblasSgemm
#define cublasStatus_t hipblasStatus_t
#define cudaDeviceProp hipDeviceProp_t
#define cudaDeviceSynchronize hipDeviceSynchronize
#define cudaError_t hipError_t
#define cudaEventCreateWithFlags hipEventCreateWithFlags
#define cudaEventDisableTiming hipEventDisableTiming
#define cudaEventRecord hipEventRecord
#define cudaEvent_t hipEvent_t
#define cudaEventDestroy hipEventDestroy
#define cudaFree hipFree
#define cudaFreeHost hipHostFree
#define cudaGetDevice hipGetDevice
#define cudaGetDeviceCount hipGetDeviceCount
#define cudaGetDeviceProperties hipGetDeviceProperties
#define cudaGetErrorString hipGetErrorString
#define cudaGetLastError hipGetLastError
#define cudaMalloc hipMalloc
#define cudaMallocHost(ptr, size) hipHostMalloc(ptr, size, hipHostMallocDefault)
#define cudaMemcpy hipMemcpy
#define cudaMemcpy2DAsync hipMemcpy2DAsync
#define cudaMemcpyAsync hipMemcpyAsync
#define cudaMemcpyDeviceToDevice hipMemcpyDeviceToDevice
#define cudaMemcpyDeviceToHost hipMemcpyDeviceToHost
#define cudaMemcpyHostToDevice hipMemcpyHostToDevice
#define cudaMemcpyKind hipMemcpyKind
#define cudaMemset hipMemset
#define cudaOccupancyMaxPotentialBlockSize hipOccupancyMaxPotentialBlockSize
#define cudaSetDevice hipSetDevice
#define cudaStreamCreateWithFlags hipStreamCreateWithFlags
#define cudaStreamNonBlocking hipStreamNonBlocking
#define cudaStreamSynchronize hipStreamSynchronize
#define cudaStreamWaitEvent(stream, event) hipStreamWaitEvent(stream, event, 0)
#define cudaStream_t hipStream_t
#define cudaSuccess hipSuccess
#else
#include <cuda_runtime.h>
#include <cublas_v2.h>
#include <cuda_fp16.h>
#endif

#include "ggml-cuda.h"
#include "ggml.h"
Expand Down Expand Up @@ -2689,6 +2746,10 @@ void ggml_init_cublas() {
static bool initialized = false;

if (!initialized) {
#ifdef GGML_USE_HIPBLAS
rocblas_initialize();
hipDeviceSynchronize();
#endif
SlyEcho marked this conversation as resolved.
Show resolved Hide resolved
CUDA_CHECK(cudaGetDeviceCount(&g_device_count));
GGML_ASSERT(g_device_count <= GGML_CUDA_MAX_DEVICES);
int64_t total_vram = 0;
Expand Down