diff options
author | Andreas Schneider <mail@cynapses.org> | 2009-04-01 20:24:09 +0000 |
---|---|---|
committer | Andreas Schneider <mail@cynapses.org> | 2009-04-01 20:24:09 +0000 |
commit | 1b627b386763e22a7b8f7a7c8de9610c1da56cd2 (patch) | |
tree | 223b3322cb868ac2dfe89b2a6f00d92f6c34ba0b /libssh/socket.c | |
parent | b06c167775ec3aac00ba52935c07ce4b1520721b (diff) | |
download | libssh-1b627b386763e22a7b8f7a7c8de9610c1da56cd2.tar.gz libssh-1b627b386763e22a7b8f7a7c8de9610c1da56cd2.tar.xz libssh-1b627b386763e22a7b8f7a7c8de9610c1da56cd2.zip |
More memory error checks for ssh_socket_new().
git-svn-id: svn+ssh://svn.berlios.de/svnroot/repos/libssh/trunk@329 7dcaeef0-15fb-0310-b436-a5af3365683c
Diffstat (limited to 'libssh/socket.c')
-rw-r--r-- | libssh/socket.c | 40 |
1 files changed, 25 insertions, 15 deletions
diff --git a/libssh/socket.c b/libssh/socket.c index 03797d6..0fe4ad5 100644 --- a/libssh/socket.c +++ b/libssh/socket.c @@ -88,22 +88,32 @@ void ssh_socket_init(void) { * \internal * \brief creates a new Socket object */ -struct socket *ssh_socket_new(SSH_SESSION *session){ - struct socket *s; +struct socket *ssh_socket_new(SSH_SESSION *session) { + struct socket *s; - s = malloc(sizeof(struct socket)); - if (s = NULL) { - return NULL; - } - s->fd=-1; - s->last_errno=-1; - s->session=session; - s->in_buffer=buffer_new(); - s->out_buffer=buffer_new(); - s->data_to_read=0; - s->data_to_write=0; - s->data_except=0; - return s; + s = malloc(sizeof(struct socket)); + if (s == NULL) { + return NULL; + } + s->fd = -1; + s->last_errno = -1; + s->session = session; + s->in_buffer = buffer_new(); + if (s->in_buffer == NULL) { + SAFE_FREE(s); + return NULL; + } + s->out_buffer=buffer_new(); + if (s->out_buffer == NULL) { + buffer_free(s->in_buffer); + SAFE_FREE(s); + return NULL; + } + s->data_to_read = 0; + s->data_to_write = 0; + s->data_except = 0; + + return s; } /* \internal |