Add fix-strncat branch which corrects a buffer overrun.
This commit is contained in:
parent
d164b20935
commit
f1f9c50dd9
|
@ -0,0 +1,8 @@
|
||||||
|
From: Brian Behlendorf <behlendorf1@llnl.gov>
|
||||||
|
Subject: [PATCH] fix strncat
|
||||||
|
|
||||||
|
This look like a typo. The intention was to use strlcat() however
|
||||||
|
strncat() was used instead accidentally this may lead to a buffer
|
||||||
|
overflow. This was caught by gcc -D_FORTIFY_SOURCE=2.
|
||||||
|
|
||||||
|
Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov>
|
|
@ -1642,7 +1642,7 @@ zfs_receive_one(libzfs_handle_t *hdl, int infd, const char *tosnap,
|
||||||
* Determine name of destination snapshot, store in zc_value.
|
* Determine name of destination snapshot, store in zc_value.
|
||||||
*/
|
*/
|
||||||
(void) strcpy(zc.zc_value, tosnap);
|
(void) strcpy(zc.zc_value, tosnap);
|
||||||
(void) strncat(zc.zc_value, drrb->drr_toname+choplen,
|
(void) strlcat(zc.zc_value, drrb->drr_toname+choplen,
|
||||||
sizeof (zc.zc_value));
|
sizeof (zc.zc_value));
|
||||||
if (!zfs_name_valid(zc.zc_value, ZFS_TYPE_SNAPSHOT)) {
|
if (!zfs_name_valid(zc.zc_value, ZFS_TYPE_SNAPSHOT)) {
|
||||||
zcmd_free_nvlists(&zc);
|
zcmd_free_nvlists(&zc);
|
||||||
|
|
Loading…
Reference in New Issue