Commit 080e5563 authored by Ezrak1e's avatar Ezrak1e Committed by David Teigland
Browse files

dlm: validate length in dlm_search_rsb_tree



The len parameter in dlm_dump_rsb_name() is not validated and comes
from network messages. When it exceeds DLM_RESNAME_MAXLEN, it can
cause out-of-bounds write in dlm_search_rsb_tree().

Add length validation to prevent potential buffer overflow.

Signed-off-by: default avatarEzrak1e <ezrakiez@gmail.com>
Signed-off-by: default avatarAlexander Aring <aahringo@redhat.com>
Signed-off-by: default avatarDavid Teigland <teigland@redhat.com>
parent 1416bd50
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -626,7 +626,8 @@ int dlm_search_rsb_tree(struct rhashtable *rhash, const void *name, int len,
			struct dlm_rsb **r_ret)
{
	char key[DLM_RESNAME_MAXLEN] = {};

	if (len > DLM_RESNAME_MAXLEN)
		return -EINVAL;
	memcpy(key, name, len);
	*r_ret = rhashtable_lookup_fast(rhash, &key, dlm_rhash_rsb_params);
	if (*r_ret)