node_device: fix possible non-terminated string

Error: STRING_NULL:
/libvirt/src/node_device/node_device_linux_sysfs.c:80:
string_null_argument: Function "saferead" does not terminate string "*buf".
/libvirt/src/util/util.c:101:
string_null_argument: Function "read" fills array "*buf" with a non-terminated string.
/libvirt/src/node_device/node_device_linux_sysfs.c:87:
string_null: Passing unterminated string "buf" to a function expecting a null-terminated string.

(cherry picked from commit 43d1616ff5)
This commit is contained in:
Stefan Berger 2012-05-04 13:22:22 -04:00 committed by Cole Robinson
parent cf2d303d0c
commit cd94771b1d

View File

@ -70,14 +70,13 @@ int read_wwn_linux(int host, const char *file, char **wwn)
{ {
char *p = NULL; char *p = NULL;
int fd = -1, retval = 0; int fd = -1, retval = 0;
char buf[64]; char buf[65] = "";
if (open_wwn_file(LINUX_SYSFS_FC_HOST_PREFIX, host, file, &fd) < 0) { if (open_wwn_file(LINUX_SYSFS_FC_HOST_PREFIX, host, file, &fd) < 0) {
goto out; goto out;
} }
memset(buf, 0, sizeof(buf)); if (saferead(fd, buf, sizeof(buf) - 1) < 0) {
if (saferead(fd, buf, sizeof(buf)) < 0) {
retval = -1; retval = -1;
VIR_DEBUG("Failed to read WWN for host%d '%s'", VIR_DEBUG("Failed to read WWN for host%d '%s'",
host, file); host, file);