virNetLibsshSessionAuthAddPasswordAuth: Don't access unlocked 'sess'
'sess->authPath' is modified before locking the 'sess' object. Additionally on failure of 'virAuthGetConfigFilePathURI' 'sess' would be unlocked even when it was not yet locked. Fixes: 6917467c2b0e8f655999f3e568708c4651811689 Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Ján Tomko <jtomko@redhat.com>
This commit is contained in:
parent
c68a07eeb3
commit
76e005d1a5
@ -846,16 +846,17 @@ virNetLibsshSessionAuthAddPasswordAuth(virNetLibsshSession *sess,
|
|||||||
int ret;
|
int ret;
|
||||||
virNetLibsshAuthMethod *auth;
|
virNetLibsshAuthMethod *auth;
|
||||||
|
|
||||||
|
virObjectLock(sess);
|
||||||
|
|
||||||
if (uri) {
|
if (uri) {
|
||||||
VIR_FREE(sess->authPath);
|
VIR_FREE(sess->authPath);
|
||||||
|
|
||||||
if (virAuthGetConfigFilePathURI(uri, &sess->authPath) < 0) {
|
if (virAuthGetConfigFilePathURI(uri, &sess->authPath) < 0) {
|
||||||
ret = -1;
|
virObjectUnlock(sess);
|
||||||
goto cleanup;
|
return -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
virObjectLock(sess);
|
|
||||||
|
|
||||||
if (!(auth = virNetLibsshSessionAuthMethodNew(sess))) {
|
if (!(auth = virNetLibsshSessionAuthMethodNew(sess))) {
|
||||||
ret = -1;
|
ret = -1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user