Skip to content

Conversation

@JohannesGaessler
Copy link
Collaborator

Fixes #10176 .

I think the correct way to fix it is to just create the events unconditionally. Regardless of how the data is split you always need the events on the currently active device for the other devices to wait on. You could maybe reduce the number of events by only initializing those that are actually needed but I don't think that would be worthwhile since for the vast majority of use cases all events are already being created and used anyways.

@JohannesGaessler JohannesGaessler added the Review Complexity : Medium Generally require more time to grok but manageable by beginner to medium expertise level label Nov 5, 2024
@JohannesGaessler JohannesGaessler force-pushed the cuda-fix-event-initialization branch from bde4116 to 38d11f5 Compare November 5, 2024 17:03
@slaren
Copy link
Member

slaren commented Nov 5, 2024

Qwen2.5-0.5B does not work with this change alone, it still crashes in the memcpy later:

CUDA error: invalid argument
  current device: 1, in function ggml_cuda_op_mul_mat at ggml/src/ggml-cuda.cu:1583
  cudaMemcpyPeerAsync( src1_ddq_i, id, src1_ddq_i_source, ctx.device, src1_ncols*src1_padded_col_size*q8_1_ts/q8_1_bs, stream)

@slaren
Copy link
Member

slaren commented Nov 5, 2024

It would also be possible to prevent using a split buffer entirely if the matrix is too small by returning false in the supports_op check.

@JohannesGaessler JohannesGaessler force-pushed the cuda-fix-event-initialization branch from 38d11f5 to e151321 Compare November 8, 2024 20:42
Nexesenex added a commit to Nexesenex/croco.cpp that referenced this pull request Nov 9, 2024
Comment on lines 2981 to 2991
// only use row split if the weight matrix is large enough for every GPU to get data (this solves some edge cases)
// also for small matrices the overhead is very large anyways so splitting is slow
if (a->buffer && ggml_backend_buft_is_cuda_split(a->buffer->buft)) {
ggml_backend_cuda_split_buffer_type_context * buft_ctx = (ggml_backend_cuda_split_buffer_type_context *) a->buffer->buft->context;
int64_t active_devices = 0;
for (int id = 0; id < ggml_backend_cuda_get_device_count(); ++id) {
int64_t row_low;
int64_t row_high;
get_row_split(&row_low, &row_high, a, buft_ctx->tensor_split, id);
active_devices += row_low == row_high;
}
const int64_t rounding = get_row_rounding(buft_ctx->tensor_split);
if (rounding*active_devices < a->ne[1]) {
return false;
}
}
Copy link
Member

Choose a reason for hiding this comment

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

This seems too expensive to do in this function, since this is called many times during inference by ggml_backend_sched. I think it should be possible to compute the minimum tensor size in ggml_backend_cuda_split_buffer_type, and store it in ggml_backend_cuda_split_buffer_type_context, then this function would only need to compare the tensor size to this value.

@JohannesGaessler JohannesGaessler force-pushed the cuda-fix-event-initialization branch from e151321 to 84bcad6 Compare November 9, 2024 19:56
@JohannesGaessler JohannesGaessler merged commit 4a8ccb3 into ggml-org:master Nov 14, 2024
53 checks passed
arthw pushed a commit to arthw/llama.cpp that referenced this pull request Nov 15, 2024
arthw pushed a commit to arthw/llama.cpp that referenced this pull request Nov 17, 2024
arthw pushed a commit to arthw/llama.cpp that referenced this pull request Nov 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Review Complexity : Medium Generally require more time to grok but manageable by beginner to medium expertise level

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Bug: Speculative Decoding "Segmentation fault (core dumped)"

2 participants