Developing multimedia applications with DCCP
DCCP GStreamer Plugin
GStreamer is a plugin-based framework, and each plugin contains elements. Each of these elements provides a specific function – such as encoding, displaying, or rendering data – as well as the ability to read from or write to files. By combining and linking those elements, the programmer can build a pipeline for performing more complex functions. For example, it is possible to create a pipeline for reading from an MP3 file, decoding its contents, and playing the MP3.
Figure 1 represents a GStreamer pipeline composed by three elements. Data flows from Element 1 to Element 2 and finally to Element 3. Element 1 is the source element, which is responsible for providing data to the pipeline, whereas Element 3 is responsible for consuming data from the pipeline. Between the source element and the sink element, the pipeline is permitted to use other elements, such as Element 2 (shown in Figure 1). These intermediary elements are responsible for processing and modifying the content as the data passes along the pipeline.
We developed the DCCP plugin for GStreamer to deal with data transmission using the DCCP protocol. This plug-in has four elements: dccpserversrc, dccpserversink, dccpclientsrc, and dccpclientsink.
The source elements (dccpserversrc and dccpclientsrc) are responsible for reading data from a DCCP socket and pushing it into the pipeline, and the sink elements (dccpserversink and dccpclientsink) are responsible for receiving data from the pipeline and writing it to a DCCP socket.
The dccpserversrc and the dccpserversink elements behave as the server, but only dccpserversink can transmit and only dccpserversrc can receive data. When the server element is initialized, it stays in a wait mode, which means the plugin is able to accept a new connection from a client element. The dccpclientsink element can connect to dccp-serversrc, and dccpclientsrc can connect to dccpserversink.
If you want to send data from the server to the client, you need to use dccpclientsrc and dccpserversink elements. To send data from the client to server, you need to use the dccpclientsink and dccpserversrc elements.
GStreamer's gst-launch command supports the creation of pipelines, and it is also used to debug plugins.
The basic syntax is:
gst-launch <gst-launch parameters> <element> <element parameters> ! <element> <element parameters> ! <element> <element parameters> ...
Note the ! character that links the plug-in elements, which is similar to the character "|" in the Linux shell prompt. This means that the output of an element is the input to the next specified plugin element.
As an example of the gst-launch command, consider two pipelines to transmit an MP3 stream over the network with DCCP: One works as a DCCP server that streams an MP3 audio file, and the second pipeline is associated with a DCCP client that connects to the remote DCCP server and reproduces the audio content transmitted by the server.
To make the example work, you must install GStreamer. In this case, you need the GStreamer-Core, Gst-Base-Plugins, and Gst-Ugly-Plugins packages. Do not worry about the GStreamer installation; GStreamer is a widely used framework available in many Linux package systems for a variety of distributions, such as Debian, Gentoo, Mandriva, Red Hat, and Ubuntu. Once you perform the GStreamer installation, the last step is to compile and install the DCCP Plugin for GStreamer (see the box titled "Installing the GStreamer DCCP Plugin").
The following gst-launch example runs a server accepting DCCP connections. Once a client connects, the server starts to stream the audio file named yourmusic.mp3. Note that you can specify the CCID with the ccid parameter.
gst-launch -v filesrc location=yourmusic.mp3 ! mp3parse ! dccpserversink port=9011 ccid=2
This pipeline initializes the server in DCCP port 9011. The server will be waiting for a client to connect to it. When the connection occurs, the server starts to transmit the MP3 stream using CCID-2. The mp3parse element is responsible for transmitting a stream. To see more information about mp3parse and the other parameters that are available, run gst-inspect dccpserversink.
Next, start the corresponding client:
gst-launch -v dccpclientsrc host=localhost port=9011 ccid=2 ! decodebin ! alsasink
This GStreamer pipeline initializes the client and connects to the host localhost in port 9011. Once connected, the client starts to receive the MP3 stream, decodes the stream using the decodebin element, and pipes the stream to the alsasink element, which reproduces the multimedia content in the default audio output device.
Installing the GStreamer DCCP Plugin
The DCCP plugin for GStreamer is part of the DCCP and E-Phone project for the Nokia maemo platform [11]. After you have downloaded the plugin [12], run the following commands:
./autogen --prefix=/usr make make install
Multimedia Application
Now it is time to write a complete multimedia application using the DCCP plug-in. The next example is for readers who want to use a programming language and embed the DCCP plugin into their applications. I'll create the pipeline shown in the previous examples, but this time through the C programming language and GObject, a programming library available for GStreamer application and plugin development.
Start by initializing the GStreamer settings, as shown in Listing 3. Note that Listing 3 also defines GstElements filesrc, mp3parse, and dccpserversink.
The next step is to instantiate a bus callback function to listen to GStreamer pipeline events. A bus is a system that takes care of forwarding messages from the pipeline to the application. The idea is to set up a message handler on the bus that leads the application to control the pipeline when necessary. Put the function shown in Listing 4 above the main function defined in Listing 3.
Listing 3
Initializing (gst_dccp_server.c)
Listing 4
GStreamer Bus (gst_dccp_server.c)
Every time an event occurs in the pipeline, GStreamer calls the gboolean bus_call function. For example, if you implement a GUI interface for your application, you can show a message announcing the end of the stream or deactivate the GUI stop button when the type of the GStreamer bus message is GST_MESSAGE_EOS. Now comes the most important part of this example – defining the elements and building the GStreamer pipeline. Insert the code shown in Listing 5 into the main function (after checking the parameter count).
Listing 5
GStreamer Elements
Listing 5 first instantiates a new pipeline, dccp-audio-sender, which can be used for future references in the code. Then the code instantiates the filesrc element with the name file-source. This element will be used to read the specified MP3 file as an argument of the application. Use the same process to instantiate the elements mp3parse and dccpserversink. Once all the necessary elements are instantiated, certify that all are properly loaded. For this case, proceed as shown in Listing 6.
Listing 6
Verifying Elements
The next step is to set the respective element parameters, as shown in Listing 7. For this application, we need to set two parameters: the port, where the server will listen and accept client connection from, and the audio file path, represented by the parameter location.
Listing 7
Setting Parameters
Once all the elements are instantiated and the parameters are defined, it is time to attach the bus callback defined in Listing 4 to the bus of the pipeline. Also, you need to add the elements to the pipeline and link them (Listing 8). Listing 9 shows how to execute the pipeline. Note that GStreamer runs in a main loop (line 5). This means that when this main loop finishes – for example, when the user types Ctrl+C – it is necessary to do some clean up (lines 9 and 11). The easiest part is to compile the server application – just run the following command, which will link the GStreamer libs with the example application:
gcc -Wall $(pkg-config --cflags --libs gstreamer-0.10) gst_dccp_server.c -o gst_dccp_server
To run the gst_dccp_server application, enter the following command:
./gst_dccp_server 9011 yourmusic.mp3
Note that the example uses port 9011, which the server will use to open the DCCP socket and transmit the stream through the network to the remote DCCP client.
Listing 8
Attaching bus_event_callback
Listing 9
Executing the Pipeline
Now it is time to build a corresponding client application that acts just like the gst-launch client command discussed previously. The DCCP client application is similar to the server application (Listing 10). Basically, you must initialize GStreamer, check command-line parameters, instantiate the necessary elements, and link them to build the GStreamer pipeline.
Listing 10
DCCP Client Application
Finally, to compile and run the client application, enter the following command:
gcc -Wall $(pkg-config --cflags --libs gstreamer-0.10) gst_dccp_client.c -o gst_dccp_client ./<applicationName> localhost 9011
Conclusion
I've presented the basic concepts of DCCP – how to enable DCCP in Linux, and how to build a DCCP-based application using the GStreamer DCCP plugin. Network analysis and testing applications, such as TTCP, tcpdump, and Wireshark already provide support for the DCCP protocol, and multimedia tools such as the open source VLC player accommodate DCCP streaming. As multimedia developers become aware of its benefits, you can expect to hear more about DCCP in the coming years.
Infos
- RFC 4340: Datagram Congestion Control Protocol (DCCP)
- Leandro M. Sales, Hyggo O. Almeida, Angelo Perkusich and Marcello Sales Jr: "On the Performance of TCP, UDP, and DCCP over 802.11g Networks." In Proceedings of the SAC 2008 23rd ACM Symposium on Applied Computing Fortaleza, CE, Brazil, pages 2074-2080, 1 2008.
- RFC 4341: "Profile for Datagram Congestion Control Protocol (DCCP) Congestion Control ID 2: TCP-like Congestion Control"
- RFC 4342: "Profile for Datagram Congestion Control Protocol (DCCP) Congestion Control ID 3: TCP-Friendly Rate Control (TFRC)"
- RFC 3448: "TCP Friendly Rate Control (TFRC): Protocol Specification"
- DCCP Git Repository: http://git://eden-feed.erg.abdn.ac.uk/dccp_exp
- DCCP on Linux wiki: http://www.linux-foundation.org/en/Net:DCCP
- Linux kernel documentation: http://www.kernel.org/doc/
- IPerf: http://www.erg.abdn.ac.uk/users/gerrit/dccp/apps/#iperf
- GStreamer: http://gstreamer.freedesktop.org/
- Maemo: http://www.maemo.org/
- DCCP plugin for GStreamer: https://garage.maemo.org/frs/?group_id=297
« Previous 1 2
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Fedora 41 Beta Available with Some Interesting Additions
If you're a Fedora fan, you'll be excited to hear the beta version of the latest release is now available for testing and includes plenty of updates.
-
AlmaLinux Unveils New Hardware Certification Process
The AlmaLinux Hardware Certification Program run by the Certification Special Interest Group (SIG) aims to ensure seamless compatibility between AlmaLinux and a wide range of hardware configurations.
-
Wind River Introduces eLxr Pro Linux Solution
eLxr Pro offers an end-to-end Linux solution backed by expert commercial support.
-
Juno Tab 3 Launches with Ubuntu 24.04
Anyone looking for a full-blown Linux tablet need look no further. Juno has released the Tab 3.
-
New KDE Slimbook Plasma Available for Preorder
Powered by an AMD Ryzen CPU, the latest KDE Slimbook laptop is powerful enough for local AI tasks.
-
Rhino Linux Announces Latest "Quick Update"
If you prefer your Linux distribution to be of the rolling type, Rhino Linux delivers a beautiful and reliable experience.
-
Plasma Desktop Will Soon Ask for Donations
The next iteration of Plasma has reached the soft feature freeze for the 6.2 version and includes a feature that could be divisive.
-
Linux Market Share Hits New High
For the first time, the Linux market share has reached a new high for desktops, and the trend looks like it will continue.
-
LibreOffice 24.8 Delivers New Features
LibreOffice is often considered the de facto standard office suite for the Linux operating system.
-
Deepin 23 Offers Wayland Support and New AI Tool
Deepin has been considered one of the most beautiful desktop operating systems for a long time and the arrival of version 23 has bolstered that reputation.