Spaces:
Running
Running
Commit
·
643bcdb
1
Parent(s):
d003891
CUDA: fix padding logic for FP16/FP32 (llama/8884)
Browse files- ggml/src/ggml-cuda.cu +1 -1
ggml/src/ggml-cuda.cu
CHANGED
|
@@ -1501,7 +1501,7 @@ static void ggml_cuda_op_mul_mat(
|
|
| 1501 |
}
|
| 1502 |
|
| 1503 |
// If src0 is on a temporary compute buffers (partial offloading) there may be some padding that needs to be cleared:
|
| 1504 |
-
if (ne00 % MATRIX_ROW_PADDING != 0 && ggml_backend_buffer_get_usage(src0->buffer) == GGML_BACKEND_BUFFER_USAGE_COMPUTE && src0->view_src == nullptr) {
|
| 1505 |
const int64_t nbytes_data = ggml_row_size(src0->type, (dev[id].row_high - dev[id].row_low)*ne00);
|
| 1506 |
const int64_t nbytes_padding = ggml_row_size(src0->type, MATRIX_ROW_PADDING - ne00 % MATRIX_ROW_PADDING);
|
| 1507 |
CUDA_CHECK(cudaMemsetAsync(dev[id].src0_dd + nbytes_data , 0, nbytes_padding, stream));
|
|
|
|
| 1501 |
}
|
| 1502 |
|
| 1503 |
// If src0 is on a temporary compute buffers (partial offloading) there may be some padding that needs to be cleared:
|
| 1504 |
+
if (ne00 % MATRIX_ROW_PADDING != 0 && ggml_is_quantized(src0->type) && ggml_backend_buffer_get_usage(src0->buffer) == GGML_BACKEND_BUFFER_USAGE_COMPUTE && src0->view_src == nullptr) {
|
| 1505 |
const int64_t nbytes_data = ggml_row_size(src0->type, (dev[id].row_high - dev[id].row_low)*ne00);
|
| 1506 |
const int64_t nbytes_padding = ggml_row_size(src0->type, MATRIX_ROW_PADDING - ne00 % MATRIX_ROW_PADDING);
|
| 1507 |
CUDA_CHECK(cudaMemsetAsync(dev[id].src0_dd + nbytes_data , 0, nbytes_padding, stream));
|