diff options
author | dec05eba <dec05eba@protonmail.com> | 2024-07-23 17:28:03 +0200 |
---|---|---|
committer | dec05eba <dec05eba@protonmail.com> | 2024-07-23 17:28:03 +0200 |
commit | 91485ba75d5a598eda5a041505c7c65648297e32 (patch) | |
tree | 9fc74d386b40413e30312ff05a1c389120abfc46 /kms/server | |
parent | 7e07ad1b6ef467df4b6da12c65094a7ebc0b48ed (diff) |
Fix kms capture getting stuck if more than 1 fd per plane
Diffstat (limited to 'kms/server')
-rw-r--r-- | kms/server/kms_server.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/kms/server/kms_server.c b/kms/server/kms_server.c index 2fdbd14..09c1f03 100644 --- a/kms/server/kms_server.c +++ b/kms/server/kms_server.c @@ -54,17 +54,18 @@ static int send_msg_to_client(int client_fd, gsr_kms_response *response) { response_message.msg_iov = &iov; response_message.msg_iovlen = 1; - char cmsgbuf[CMSG_SPACE(sizeof(int) * max_int(1, response->num_items))]; + const int num_fds = count_num_fds(response); + char cmsgbuf[CMSG_SPACE(sizeof(int) * max_int(1, num_fds))]; memset(cmsgbuf, 0, sizeof(cmsgbuf)); - if(response->num_items > 0) { + if(num_fds > 0) { response_message.msg_control = cmsgbuf; response_message.msg_controllen = sizeof(cmsgbuf); struct cmsghdr *cmsg = CMSG_FIRSTHDR(&response_message); cmsg->cmsg_level = SOL_SOCKET; cmsg->cmsg_type = SCM_RIGHTS; - cmsg->cmsg_len = CMSG_LEN(sizeof(int) * count_num_fds(response)); + cmsg->cmsg_len = CMSG_LEN(sizeof(int) * num_fds); int *fds = (int*)CMSG_DATA(cmsg); int fd_index = 0; |