mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-04-26 06:54:49 +00:00
gst-plugins-good/gst/udp/: Allow udpsrc and dynudpsink to take a sockfd as a parameter. For udpsrc, overrides the por...
Original commit message from CVS: 2005-01-07 Philippe Khalaf <philippe.kalaf@collabora.co.uk> * gst-plugins-good/gst/udp/gstdynudpsink.c: * gst-plugins-good/gst/udp/gstudpsrc.c: Allow udpsrc and dynudpsink to take a sockfd as a parameter. For udpsrc, overrides the port or multicast parameters. Fixes bugs #323021.
This commit is contained in:
parent
cc627c9c81
commit
8189a4da72
4 changed files with 75 additions and 28 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
2005-01-07 Philippe Khalaf <philippe.kalaf@collabora.co.uk>
|
||||||
|
|
||||||
|
* gst-plugins-good/gst/udp/gstdynudpsink.c:
|
||||||
|
* gst-plugins-good/gst/udp/gstudpsrc.c:
|
||||||
|
Allow udpsrc and dynudpsink to take a sockfd as a parameter. For udpsrc,
|
||||||
|
overrides the port or multicast parameters. Fixes bugs #323021.
|
||||||
|
|
||||||
2006-01-06 Tim-Philipp Müller <tim at centricular dot net>
|
2006-01-06 Tim-Philipp Müller <tim at centricular dot net>
|
||||||
|
|
||||||
* ext/gconf/Makefile.am:
|
* ext/gconf/Makefile.am:
|
||||||
|
|
2
common
2
common
|
@ -1 +1 @@
|
||||||
Subproject commit 5f10c872cafb3eb8058d63e438cae029ed9e8d73
|
Subproject commit e0b121388ece524c0b7035a72bddd191d122d8bf
|
|
@ -1,5 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) <2005> Philippe Khalaf <burger@speedy.org>
|
* Copyright (C) <2005> Philippe Khalaf <burger@speedy.org>
|
||||||
|
* Copyright (C) <2005> Nokia Corporation <kai.vehmanen@nokia.com>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -54,7 +55,8 @@ enum
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
/* FILL ME */
|
PROP_SOCKFD
|
||||||
|
/* FILL ME */
|
||||||
};
|
};
|
||||||
|
|
||||||
static void gst_dynudpsink_base_init (gpointer g_class);
|
static void gst_dynudpsink_base_init (gpointer g_class);
|
||||||
|
@ -139,6 +141,11 @@ gst_dynudpsink_class_init (GstDynUDPSink * klass)
|
||||||
NULL, NULL, gst_udp_marshal_BOXED__STRING_INT, G_TYPE_VALUE_ARRAY, 2,
|
NULL, NULL, gst_udp_marshal_BOXED__STRING_INT, G_TYPE_VALUE_ARRAY, 2,
|
||||||
G_TYPE_STRING, G_TYPE_INT);
|
G_TYPE_STRING, G_TYPE_INT);
|
||||||
|
|
||||||
|
g_object_class_install_property (gobject_class, PROP_SOCKFD,
|
||||||
|
g_param_spec_int ("sockfd", "socket handle",
|
||||||
|
"Socket to use for UDP reception.",
|
||||||
|
0, G_MAXINT16, 0, G_PARAM_READWRITE));
|
||||||
|
|
||||||
gstelement_class->change_state = gst_dynudpsink_change_state;
|
gstelement_class->change_state = gst_dynudpsink_change_state;
|
||||||
|
|
||||||
gstbasesink_class->get_times = gst_dynudpsink_get_times;
|
gstbasesink_class->get_times = gst_dynudpsink_get_times;
|
||||||
|
@ -151,6 +158,11 @@ gst_dynudpsink_class_init (GstDynUDPSink * klass)
|
||||||
static void
|
static void
|
||||||
gst_dynudpsink_init (GstDynUDPSink * sink)
|
gst_dynudpsink_init (GstDynUDPSink * sink)
|
||||||
{
|
{
|
||||||
|
GstDynUDPSink *udpsink;
|
||||||
|
|
||||||
|
udpsink = GST_DYNUDPSINK (sink);
|
||||||
|
|
||||||
|
sink->sock = -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -231,6 +243,11 @@ gst_dynudpsink_set_property (GObject * object, guint prop_id,
|
||||||
udpsink = GST_DYNUDPSINK (object);
|
udpsink = GST_DYNUDPSINK (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
|
case PROP_SOCKFD:
|
||||||
|
udpsink->sock = g_value_get_int (value);
|
||||||
|
GST_DEBUG ("setting SOCKFD to %d", udpsink->sock);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -246,6 +263,10 @@ gst_dynudpsink_get_property (GObject * object, guint prop_id, GValue * value,
|
||||||
udpsink = GST_DYNUDPSINK (object);
|
udpsink = GST_DYNUDPSINK (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
|
case PROP_SOCKFD:
|
||||||
|
g_value_set_int (value, udpsink->sock);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -260,15 +281,18 @@ gst_dynudpsink_init_send (GstDynUDPSink * sink)
|
||||||
guint bc_val;
|
guint bc_val;
|
||||||
gint ret;
|
gint ret;
|
||||||
|
|
||||||
/* create sender socket */
|
if (sink->sock == -1) {
|
||||||
if ((sink->sock = socket (AF_INET, SOCK_DGRAM, 0)) == -1)
|
/* create sender socket if none available */
|
||||||
goto no_socket;
|
|
||||||
|
|
||||||
bc_val = 1;
|
if ((sink->sock = socket (AF_INET, SOCK_DGRAM, 0)) == -1)
|
||||||
if ((ret =
|
goto no_socket;
|
||||||
setsockopt (sink->sock, SOL_SOCKET, SO_BROADCAST, &bc_val,
|
|
||||||
sizeof (bc_val))) < 0)
|
bc_val = 1;
|
||||||
goto no_broadcast;
|
if ((ret =
|
||||||
|
setsockopt (sink->sock, SOL_SOCKET, SO_BROADCAST, &bc_val,
|
||||||
|
sizeof (bc_val))) < 0)
|
||||||
|
goto no_broadcast;
|
||||||
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) <2005> Wim Taymans <wim@fluendo.com>
|
* Copyright (C) <2005> Wim Taymans <wim@fluendo.com>
|
||||||
|
* Copyright (C) <2005> Nokia Corporation <kai.vehmanen@nokia.com>
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU Library General Public
|
* modify it under the terms of the GNU Library General Public
|
||||||
|
@ -76,7 +77,8 @@ enum
|
||||||
PROP_MULTICAST_GROUP,
|
PROP_MULTICAST_GROUP,
|
||||||
PROP_URI,
|
PROP_URI,
|
||||||
PROP_CAPS,
|
PROP_CAPS,
|
||||||
/* FILL ME */
|
PROP_SOCKFD
|
||||||
|
/* FILL ME */
|
||||||
};
|
};
|
||||||
|
|
||||||
static void gst_udpsrc_uri_handler_init (gpointer g_iface, gpointer iface_data);
|
static void gst_udpsrc_uri_handler_init (gpointer g_iface, gpointer iface_data);
|
||||||
|
@ -149,6 +151,10 @@ gst_udpsrc_class_init (GstUDPSrcClass * klass)
|
||||||
g_object_class_install_property (gobject_class, PROP_CAPS,
|
g_object_class_install_property (gobject_class, PROP_CAPS,
|
||||||
g_param_spec_boxed ("caps", "Caps",
|
g_param_spec_boxed ("caps", "Caps",
|
||||||
"The caps of the source pad", GST_TYPE_CAPS, G_PARAM_READWRITE));
|
"The caps of the source pad", GST_TYPE_CAPS, G_PARAM_READWRITE));
|
||||||
|
g_object_class_install_property (gobject_class, PROP_SOCKFD,
|
||||||
|
g_param_spec_int ("sockfd", "socket handle",
|
||||||
|
"Socket to use for UDP reception.",
|
||||||
|
0, G_MAXINT16, 0, G_PARAM_READWRITE));
|
||||||
|
|
||||||
gstbasesrc_class->start = gst_udpsrc_start;
|
gstbasesrc_class->start = gst_udpsrc_start;
|
||||||
gstbasesrc_class->stop = gst_udpsrc_stop;
|
gstbasesrc_class->stop = gst_udpsrc_stop;
|
||||||
|
@ -403,6 +409,10 @@ gst_udpsrc_set_property (GObject * object, guint prop_id, const GValue * value,
|
||||||
gst_pad_set_caps (GST_BASE_SRC (udpsrc)->srcpad, new_caps);
|
gst_pad_set_caps (GST_BASE_SRC (udpsrc)->srcpad, new_caps);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case PROP_SOCKFD:
|
||||||
|
udpsrc->sock = g_value_get_int (value);
|
||||||
|
GST_DEBUG ("setting SOCKFD to %d", udpsrc->sock);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -427,6 +437,9 @@ gst_udpsrc_get_property (GObject * object, guint prop_id, GValue * value,
|
||||||
case PROP_CAPS:
|
case PROP_CAPS:
|
||||||
gst_value_set_caps (value, udpsrc->caps);
|
gst_value_set_caps (value, udpsrc->caps);
|
||||||
break;
|
break;
|
||||||
|
case PROP_SOCKFD:
|
||||||
|
g_value_set_int (value, udpsrc->sock);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -454,27 +467,30 @@ gst_udpsrc_start (GstBaseSrc * bsrc)
|
||||||
fcntl (READ_SOCKET (src), F_SETFL, O_NONBLOCK);
|
fcntl (READ_SOCKET (src), F_SETFL, O_NONBLOCK);
|
||||||
fcntl (WRITE_SOCKET (src), F_SETFL, O_NONBLOCK);
|
fcntl (WRITE_SOCKET (src), F_SETFL, O_NONBLOCK);
|
||||||
|
|
||||||
if ((ret = socket (AF_INET, SOCK_DGRAM, 0)) < 0)
|
if (src->sock == -1) {
|
||||||
goto no_socket;
|
if ((ret = socket (AF_INET, SOCK_DGRAM, 0)) < 0)
|
||||||
|
goto no_socket;
|
||||||
|
|
||||||
src->sock = ret;
|
src->sock = ret;
|
||||||
|
|
||||||
reuse = 1;
|
reuse = 1;
|
||||||
if ((ret =
|
if ((ret =
|
||||||
setsockopt (src->sock, SOL_SOCKET, SO_REUSEADDR, &reuse,
|
setsockopt (src->sock, SOL_SOCKET, SO_REUSEADDR, &reuse,
|
||||||
sizeof (reuse))) < 0)
|
sizeof (reuse))) < 0)
|
||||||
goto setsockopt_error;
|
goto setsockopt_error;
|
||||||
|
|
||||||
memset (&src->myaddr, 0, sizeof (src->myaddr));
|
/* XXX-kvehmanen: add ability to select a random, free port */
|
||||||
src->myaddr.sin_family = AF_INET; /* host byte order */
|
memset (&src->myaddr, 0, sizeof (src->myaddr));
|
||||||
src->myaddr.sin_port = htons (src->port); /* short, network byte order */
|
src->myaddr.sin_family = AF_INET; /* host byte order */
|
||||||
src->myaddr.sin_addr.s_addr = INADDR_ANY;
|
src->myaddr.sin_port = htons (src->port); /* short, network byte order */
|
||||||
|
src->myaddr.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
|
||||||
GST_DEBUG_OBJECT (src, "binding on port %d", src->port);
|
GST_DEBUG_OBJECT (src, "binding on port %d", src->port);
|
||||||
if ((ret =
|
if ((ret =
|
||||||
bind (src->sock, (struct sockaddr *) &src->myaddr,
|
bind (src->sock, (struct sockaddr *) &src->myaddr,
|
||||||
sizeof (src->myaddr))) < 0)
|
sizeof (src->myaddr))) < 0)
|
||||||
goto bind_error;
|
goto bind_error;
|
||||||
|
}
|
||||||
|
|
||||||
if (inet_aton (src->multi_group, &(src->multi_addr.imr_multiaddr))) {
|
if (inet_aton (src->multi_group, &(src->multi_addr.imr_multiaddr))) {
|
||||||
if (src->multi_addr.imr_multiaddr.s_addr) {
|
if (src->multi_addr.imr_multiaddr.s_addr) {
|
||||||
|
|
Loading…
Reference in a new issue