libssh2_channel_process_startup: simplify the code
clang-analyzer pointed out how 'data' could be accessed as a NULL pointer if the wrong state was set, and while I don't see that happen in real-life the code flow is easier to read and follow by moving the LIBSSH2_FREE() call into the block that is supposed to deal with the data pointer anyway.
Этот коммит содержится в:
родитель
88ac2dd43c
Коммит
21f55d0006
@ -1251,6 +1251,7 @@ _libssh2_channel_process_startup(LIBSSH2_CHANNEL *channel,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (channel->process_state == libssh2_NB_state_sent) {
|
if (channel->process_state == libssh2_NB_state_sent) {
|
||||||
|
unsigned char code;
|
||||||
rc = _libssh2_packet_requirev(session, reply_codes, &data, &data_len,
|
rc = _libssh2_packet_requirev(session, reply_codes, &data, &data_len,
|
||||||
1, channel->process_local_channel, 4,
|
1, channel->process_local_channel, 4,
|
||||||
&channel->process_packet_requirev_state);
|
&channel->process_packet_requirev_state);
|
||||||
@ -1262,14 +1263,14 @@ _libssh2_channel_process_startup(LIBSSH2_CHANNEL *channel,
|
|||||||
"Failed waiting for channel success");
|
"Failed waiting for channel success");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (data[0] == SSH_MSG_CHANNEL_SUCCESS) {
|
code = data[0];
|
||||||
LIBSSH2_FREE(session, data);
|
LIBSSH2_FREE(session, data);
|
||||||
channel->process_state = libssh2_NB_state_idle;
|
channel->process_state = libssh2_NB_state_idle;
|
||||||
|
|
||||||
|
if (code == SSH_MSG_CHANNEL_SUCCESS)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
LIBSSH2_FREE(session, data);
|
|
||||||
channel->process_state = libssh2_NB_state_idle;
|
channel->process_state = libssh2_NB_state_idle;
|
||||||
return _libssh2_error(session, LIBSSH2_ERROR_CHANNEL_REQUEST_DENIED,
|
return _libssh2_error(session, LIBSSH2_ERROR_CHANNEL_REQUEST_DENIED,
|
||||||
"Unable to complete request for "
|
"Unable to complete request for "
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user