diff options
-rw-r--r-- | fs/dlm/user.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/fs/dlm/user.c b/fs/dlm/user.c index eb6164816948..1acb4c5813cd 100644 --- a/fs/dlm/user.c +++ b/fs/dlm/user.c | |||
@@ -82,7 +82,8 @@ struct dlm_lock_result32 { | |||
82 | }; | 82 | }; |
83 | 83 | ||
84 | static void compat_input(struct dlm_write_request *kb, | 84 | static void compat_input(struct dlm_write_request *kb, |
85 | struct dlm_write_request32 *kb32) | 85 | struct dlm_write_request32 *kb32, |
86 | int max_namelen) | ||
86 | { | 87 | { |
87 | kb->version[0] = kb32->version[0]; | 88 | kb->version[0] = kb32->version[0]; |
88 | kb->version[1] = kb32->version[1]; | 89 | kb->version[1] = kb32->version[1]; |
@@ -112,7 +113,11 @@ static void compat_input(struct dlm_write_request *kb, | |||
112 | kb->i.lock.bastaddr = (void *)(long)kb32->i.lock.bastaddr; | 113 | kb->i.lock.bastaddr = (void *)(long)kb32->i.lock.bastaddr; |
113 | kb->i.lock.lksb = (void *)(long)kb32->i.lock.lksb; | 114 | kb->i.lock.lksb = (void *)(long)kb32->i.lock.lksb; |
114 | memcpy(kb->i.lock.lvb, kb32->i.lock.lvb, DLM_USER_LVB_LEN); | 115 | memcpy(kb->i.lock.lvb, kb32->i.lock.lvb, DLM_USER_LVB_LEN); |
115 | memcpy(kb->i.lock.name, kb32->i.lock.name, kb->i.lock.namelen); | 116 | if (kb->i.lock.namelen <= max_namelen) |
117 | memcpy(kb->i.lock.name, kb32->i.lock.name, | ||
118 | kb->i.lock.namelen); | ||
119 | else | ||
120 | kb->i.lock.namelen = max_namelen; | ||
116 | } | 121 | } |
117 | } | 122 | } |
118 | 123 | ||
@@ -529,7 +534,8 @@ static ssize_t device_write(struct file *file, const char __user *buf, | |||
529 | 534 | ||
530 | if (proc) | 535 | if (proc) |
531 | set_bit(DLM_PROC_FLAGS_COMPAT, &proc->flags); | 536 | set_bit(DLM_PROC_FLAGS_COMPAT, &proc->flags); |
532 | compat_input(kbuf, k32buf); | 537 | compat_input(kbuf, k32buf, |
538 | count - sizeof(struct dlm_write_request32)); | ||
533 | kfree(k32buf); | 539 | kfree(k32buf); |
534 | } | 540 | } |
535 | #endif | 541 | #endif |