mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-24 01:00:37 +00:00
gst/tcp/: Memory leak fixes
Original commit message from CVS: * gst/tcp/gsttcp.c: (gst_tcp_gdp_read_header), (gst_tcp_gdp_read_caps), (gst_tcp_gdp_write_header), (gst_tcp_gdp_write_caps): * gst/tcp/gsttcpclientsrc.c: (gst_tcpclientsrc_get): * gst/tcp/gsttcpserversrc.c: (gst_tcpserversrc_gdp_read_caps), (gst_tcpserversrc_gdp_read_header), (gst_tcpserversrc_get): Memory leak fixes
This commit is contained in:
parent
920d5bc922
commit
fbd9b71c3a
4 changed files with 31 additions and 5 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2004-06-08 Wim Taymans <wim@fluendo.com>
|
||||||
|
|
||||||
|
* gst/tcp/gsttcp.c: (gst_tcp_gdp_read_header),
|
||||||
|
(gst_tcp_gdp_read_caps), (gst_tcp_gdp_write_header),
|
||||||
|
(gst_tcp_gdp_write_caps):
|
||||||
|
* gst/tcp/gsttcpclientsrc.c: (gst_tcpclientsrc_get):
|
||||||
|
* gst/tcp/gsttcpserversrc.c: (gst_tcpserversrc_gdp_read_caps),
|
||||||
|
(gst_tcpserversrc_gdp_read_header), (gst_tcpserversrc_get):
|
||||||
|
Memory leak fixes
|
||||||
|
|
||||||
2004-06-08 Thomas Vander Stichele <thomas at apestaart dot org>
|
2004-06-08 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
* ext/vorbis/Makefile.am:
|
* ext/vorbis/Makefile.am:
|
||||||
|
|
|
@ -143,7 +143,6 @@ gst_tcp_gdp_read_header (GstElement * this, int socket)
|
||||||
GstBuffer *buffer;
|
GstBuffer *buffer;
|
||||||
|
|
||||||
header = g_malloc (header_length);
|
header = g_malloc (header_length);
|
||||||
|
|
||||||
readsize = header_length;
|
readsize = header_length;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (this, "Reading %d bytes for buffer packet header",
|
GST_DEBUG_OBJECT (this, "Reading %d bytes for buffer packet header",
|
||||||
|
@ -152,11 +151,13 @@ gst_tcp_gdp_read_header (GstElement * this, int socket)
|
||||||
/* if we read 0 bytes, and we're blocking, we hit eos */
|
/* if we read 0 bytes, and we're blocking, we hit eos */
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
GST_DEBUG ("blocking read returns 0, EOS");
|
GST_DEBUG ("blocking read returns 0, EOS");
|
||||||
|
g_free (header);
|
||||||
gst_element_set_eos (GST_ELEMENT (this));
|
gst_element_set_eos (GST_ELEMENT (this));
|
||||||
return GST_DATA (gst_event_new (GST_EVENT_EOS));
|
return GST_DATA (gst_event_new (GST_EVENT_EOS));
|
||||||
}
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
|
g_free (header);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (ret != readsize) {
|
if (ret != readsize) {
|
||||||
|
@ -173,6 +174,7 @@ gst_tcp_gdp_read_header (GstElement * this, int socket)
|
||||||
GST_DEBUG_OBJECT (this, "validated buffer packet header");
|
GST_DEBUG_OBJECT (this, "validated buffer packet header");
|
||||||
|
|
||||||
buffer = gst_dp_buffer_from_header (header_length, header);
|
buffer = gst_dp_buffer_from_header (header_length, header);
|
||||||
|
g_free (header);
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (this, "created new buffer %p from packet header", buffer);
|
GST_DEBUG_OBJECT (this, "created new buffer %p from packet header", buffer);
|
||||||
return GST_DATA (buffer);
|
return GST_DATA (buffer);
|
||||||
|
@ -192,11 +194,12 @@ gst_tcp_gdp_read_caps (GstElement * this, int socket)
|
||||||
gchar *string;
|
gchar *string;
|
||||||
|
|
||||||
header = g_malloc (header_length);
|
header = g_malloc (header_length);
|
||||||
|
|
||||||
readsize = header_length;
|
readsize = header_length;
|
||||||
|
|
||||||
GST_LOG_OBJECT (this, "Reading %d bytes for caps packet header", readsize);
|
GST_LOG_OBJECT (this, "Reading %d bytes for caps packet header", readsize);
|
||||||
ret = read (socket, header, readsize);
|
ret = read (socket, header, readsize);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
|
g_free (header);
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -240,10 +243,11 @@ gst_tcp_gdp_read_caps (GstElement * this, int socket)
|
||||||
caps = gst_dp_caps_from_packet (header_length, header, payload);
|
caps = gst_dp_caps_from_packet (header_length, header, payload);
|
||||||
string = gst_caps_to_string (caps);
|
string = gst_caps_to_string (caps);
|
||||||
GST_DEBUG_OBJECT (this, "retrieved GDP caps from packet payload: %s", string);
|
GST_DEBUG_OBJECT (this, "retrieved GDP caps from packet payload: %s", string);
|
||||||
|
g_free (string);
|
||||||
|
|
||||||
g_free (header);
|
g_free (header);
|
||||||
g_free (payload);
|
g_free (payload);
|
||||||
g_free (string);
|
|
||||||
return caps;
|
return caps;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -265,6 +269,7 @@ gst_tcp_gdp_write_header (GstElement * this, int socket, GstBuffer * buffer,
|
||||||
|
|
||||||
GST_LOG_OBJECT (this, "writing %d bytes for GDP buffer header", length);
|
GST_LOG_OBJECT (this, "writing %d bytes for GDP buffer header", length);
|
||||||
wrote = gst_tcp_socket_write (socket, header, length);
|
wrote = gst_tcp_socket_write (socket, header, length);
|
||||||
|
g_free (header);
|
||||||
if (wrote != length) {
|
if (wrote != length) {
|
||||||
if (fatal)
|
if (fatal)
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
||||||
|
@ -297,6 +302,8 @@ gst_tcp_gdp_write_caps (GstElement * this, int socket, const GstCaps * caps,
|
||||||
GST_LOG_OBJECT (this, "writing %d bytes for GDP caps header", length);
|
GST_LOG_OBJECT (this, "writing %d bytes for GDP caps header", length);
|
||||||
wrote = gst_tcp_socket_write (socket, header, length);
|
wrote = gst_tcp_socket_write (socket, header, length);
|
||||||
if (wrote != length) {
|
if (wrote != length) {
|
||||||
|
g_free (header);
|
||||||
|
g_free (payload);
|
||||||
if (fatal)
|
if (fatal)
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
||||||
(_("Error while sending gdp header data to \"%s:%d\"."), host, port),
|
(_("Error while sending gdp header data to \"%s:%d\"."), host, port),
|
||||||
|
@ -306,8 +313,10 @@ gst_tcp_gdp_write_caps (GstElement * this, int socket, const GstCaps * caps,
|
||||||
}
|
}
|
||||||
|
|
||||||
length = gst_dp_header_payload_length (header);
|
length = gst_dp_header_payload_length (header);
|
||||||
|
g_free (header);
|
||||||
GST_LOG_OBJECT (this, "writing %d bytes for GDP caps payload", length);
|
GST_LOG_OBJECT (this, "writing %d bytes for GDP caps payload", length);
|
||||||
wrote = gst_tcp_socket_write (socket, payload, length);
|
wrote = gst_tcp_socket_write (socket, payload, length);
|
||||||
|
g_free (payload);
|
||||||
if (wrote != length) {
|
if (wrote != length) {
|
||||||
if (fatal)
|
if (fatal)
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
GST_ELEMENT_ERROR (this, RESOURCE, WRITE,
|
||||||
|
|
|
@ -279,6 +279,7 @@ gst_tcpclientsrc_get (GstPad * pad)
|
||||||
ret = gst_tcp_socket_read (src->sock_fd, GST_BUFFER_DATA (buf), readsize);
|
ret = gst_tcp_socket_read (src->sock_fd, GST_BUFFER_DATA (buf), readsize);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (src, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (src, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
|
gst_buffer_unref (buf);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -194,6 +194,7 @@ gst_tcpserversrc_gdp_read_caps (GstTCPServerSrc * this)
|
||||||
ret = read (this->client_sock_fd, header, readsize);
|
ret = read (this->client_sock_fd, header, readsize);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
|
g_free (header);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
g_assert (ret == readsize);
|
g_assert (ret == readsize);
|
||||||
|
@ -212,6 +213,7 @@ gst_tcpserversrc_gdp_read_caps (GstTCPServerSrc * this)
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
g_free (header);
|
g_free (header);
|
||||||
|
g_free (payload);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
g_assert (ret == readsize);
|
g_assert (ret == readsize);
|
||||||
|
@ -227,10 +229,11 @@ gst_tcpserversrc_gdp_read_caps (GstTCPServerSrc * this)
|
||||||
caps = gst_dp_caps_from_packet (header_length, header, payload);
|
caps = gst_dp_caps_from_packet (header_length, header, payload);
|
||||||
string = gst_caps_to_string (caps);
|
string = gst_caps_to_string (caps);
|
||||||
GST_DEBUG_OBJECT (this, "retrieved GDP caps from packet payload: %s", string);
|
GST_DEBUG_OBJECT (this, "retrieved GDP caps from packet payload: %s", string);
|
||||||
|
g_free (string);
|
||||||
|
|
||||||
g_free (header);
|
g_free (header);
|
||||||
g_free (payload);
|
g_free (payload);
|
||||||
g_free (string);
|
|
||||||
return caps;
|
return caps;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -248,18 +251,20 @@ gst_tcpserversrc_gdp_read_header (GstTCPServerSrc * this)
|
||||||
GstBuffer *buffer;
|
GstBuffer *buffer;
|
||||||
|
|
||||||
header = g_malloc (header_length);
|
header = g_malloc (header_length);
|
||||||
|
|
||||||
readsize = header_length;
|
readsize = header_length;
|
||||||
|
|
||||||
GST_LOG_OBJECT (this, "Reading %d bytes for buffer packet header", readsize);
|
GST_LOG_OBJECT (this, "Reading %d bytes for buffer packet header", readsize);
|
||||||
ret = read (this->client_sock_fd, header, readsize);
|
ret = read (this->client_sock_fd, header, readsize);
|
||||||
/* if we read 0 bytes, and we're blocking, we hit eos */
|
/* if we read 0 bytes, and we're blocking, we hit eos */
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
GST_DEBUG ("blocking read returns 0, EOS");
|
GST_DEBUG ("blocking read returns 0, EOS");
|
||||||
gst_element_set_eos (GST_ELEMENT (this));
|
gst_element_set_eos (GST_ELEMENT (this));
|
||||||
|
g_free (header);
|
||||||
return GST_DATA (gst_event_new (GST_EVENT_EOS));
|
return GST_DATA (gst_event_new (GST_EVENT_EOS));
|
||||||
}
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (this, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
|
g_free (header);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (ret != readsize) {
|
if (ret != readsize) {
|
||||||
|
@ -371,6 +376,7 @@ gst_tcpserversrc_get (GstPad * pad)
|
||||||
readsize);
|
readsize);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
GST_ELEMENT_ERROR (src, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
GST_ELEMENT_ERROR (src, RESOURCE, READ, (NULL), GST_ERROR_SYSTEM);
|
||||||
|
gst_buffer_unref (buf);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue