mirror of
https://git.libssh.org/projects/libssh.git
synced 2026-02-04 12:20:42 +09:00
Per ecdsa(3ssl), ECDSA_SIG_new does allocate its 'r' and 's' bignum fields.
Fix a bug where the initial 'r' and 's' bignums were being overwritten with
newly-allocated bignums, resulting in a memory leak.
BUG: https://red.libssh.org/issues/175
Signed-off-by: Jon Simons <jon@jonsimons.org>
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
(cherry picked from commit 4745d652b5)
56 lines
2.0 KiB
C
56 lines
2.0 KiB
C
/*
|
|
* This file is part of the SSH Library
|
|
*
|
|
* Copyright (c) 2009 by Aris Adamantiadis
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef DH_H_
|
|
#define DH_H_
|
|
|
|
#include "config.h"
|
|
|
|
#include "libssh/crypto.h"
|
|
|
|
void ssh_print_bignum(const char *which,bignum num);
|
|
int dh_generate_e(ssh_session session);
|
|
int dh_generate_f(ssh_session session);
|
|
int dh_generate_x(ssh_session session);
|
|
int dh_generate_y(ssh_session session);
|
|
|
|
int ssh_crypto_init(void);
|
|
void ssh_crypto_finalize(void);
|
|
|
|
ssh_string dh_get_e(ssh_session session);
|
|
ssh_string dh_get_f(ssh_session session);
|
|
int dh_import_f(ssh_session session,ssh_string f_string);
|
|
int dh_import_e(ssh_session session, ssh_string e_string);
|
|
void dh_import_pubkey(ssh_session session,ssh_string pubkey_string);
|
|
int dh_build_k(ssh_session session);
|
|
int ssh_client_dh_init(ssh_session session);
|
|
int ssh_client_dh_reply(ssh_session session, ssh_buffer packet);
|
|
|
|
int make_sessionid(ssh_session session);
|
|
/* add data for the final cookie */
|
|
int hashbufin_add_cookie(ssh_session session, unsigned char *cookie);
|
|
int hashbufout_add_cookie(ssh_session session);
|
|
int generate_session_keys(ssh_session session);
|
|
bignum make_string_bn(ssh_string string);
|
|
void make_string_bn_inplace(ssh_string string, bignum bnout);
|
|
ssh_string make_bignum_string(bignum num);
|
|
|
|
#endif /* DH_H_ */
|