summaryrefslogtreecommitdiffstats
path: root/app/main.cpp
diff options
context:
space:
mode:
authorScott Murray <scott.murray@konsulko.com>2018-12-03 17:52:53 -0500
committerScott Murray <scott.murray@konsulko.com>2018-12-04 12:26:43 -0500
commit37ca895c177f2c33207ae580dda3ad7d87ca609b (patch)
treed9e7eedd5027af201e7febfbef61880b81e48307 /app/main.cpp
parent6d0bddab56b403f6f698f2d758a5c576a3e8da8d (diff)
Demo instrument cluster receiver application to receive a h264 stream sent via RTP from another host running Wayland and Weston with the gst-recorder feature for streaming a virtual display patched in. The gstreamer pipeline used is based on what was being used with gst-launch-1.0 in the previously hand-constructed instrument cluster demo. The use of vaapisink likely constrains use to Intel based platforms at present, future work should allow working on other platforms. The app/surface.{hpp,cpp} files are adapted from code from xdg-launcher: https://gerrit.automotivelinux.org/gerrit/staging/xdg-launcher Note that they are MIT licensed while all other source files are Apache 2.0. Other than significant refactoring to ease integration, the functional differences from the runxdg code in xdg-launcher are that homescreen support has been removed, as the instrument cluster platform does not use it, and the logging has been reworked to use the hmi-debug mechanism used by the windowmanager and homescreen. There is also an implicit assumption that the windowmanager configuration is such that the "app" role will map the receiver's surface to the desired location in the center of the dashboard. Change-Id: Ieddef6463efb744d9c9c28b1508cc930a32981a4 Signed-off-by: Scott Murray <scott.murray@konsulko.com>
Diffstat (limited to 'app/main.cpp')
-rw-r--r--app/main.cpp85
1 files changed, 85 insertions, 0 deletions
diff --git a/app/main.cpp b/app/main.cpp
new file mode 100644
index 0000000..400a066
--- /dev/null
+++ b/app/main.cpp
@@ -0,0 +1,85 @@
+/*
+ * Copyright (C) 2018 Konsulko Group
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+#include <string>
+#include <iostream>
+#include <cstring>
+#include <gst/gst.h>
+#include "surface.hpp"
+
+int main(int argc, char *argv[])
+{
+ int port = 0;
+ std::string token;
+ std::string role = "receiver";
+
+ try {
+ port = std::stol(argv[1]);
+ token = argv[2];
+ } catch (const std::invalid_argument& e) {
+ std::cerr << "Invalid argument" << std::endl;
+ exit(1);
+ } catch (const std::out_of_range& e) {
+ std::cerr << "Port out of range" << std::endl;
+ exit(1);
+ }
+
+ // NOTES:
+ // (1) For reference, the pipeline used is based on the gst-launch-1.0 command in the ad hoc unit
+ // file in the previous hand-rolled CES demo:
+ //
+ // udpsrc port=5005 ! application/x-rtp,media=video,encoding-name=H264 ! queue ! rtph264depay ! h264parse config-interval=1 disable-passthrough=true ! decodebin ! vaapisink
+ //
+ // (2) waylandsink is a bit broken, as it needs a RGB format, but its caps include non-RGB formats
+ // This results in crashes when videoconvert doesn't end up in the pipeline, so care must be taken
+ // if it is used, e.g. for testing:
+ //
+ // videotestsrc pattern=smpte ! video/x-raw,format=BGRx,width=384,height=368 ! waylandsink
+ //
+ std::string pipeline_str = \
+ "udpsrc port=5005 ! application/x-rtp,media=video,encoding-name=H264 ! queue ! rtph264depay ! h264parse config-interval=1 disable-passthrough=true ! decodebin ! vaapisink";
+
+ // Initialize GStreamer
+ gst_init(NULL, NULL);
+
+ // Create our IVI surface handler
+ SurfaceHandler handler(port, token, role);
+
+ GstElement *pipeline = gst_parse_launch(pipeline_str.c_str(), NULL);
+ if(!pipeline) {
+ std::cerr << "gstreamer pipeline construction failed!" << std::endl;
+ exit(1);
+ }
+
+ // Start pipeline
+ gst_element_set_state(pipeline, GST_STATE_PLAYING);
+ std::cout << "gstreamer pipeline running" << std::endl;
+
+ // Wait until error or EOS
+ GstBus *bus = gst_element_get_bus(pipeline);
+ GstMessage *msg = gst_bus_timed_pop_filtered(bus,
+ GST_CLOCK_TIME_NONE,
+ (GstMessageType) (GST_MESSAGE_ERROR | GST_MESSAGE_EOS));
+
+ // Free resources
+ if(msg != NULL)
+ gst_message_unref(msg);
+ gst_object_unref(bus);
+ gst_element_set_state(pipeline, GST_STATE_NULL);
+ gst_object_unref(pipeline);
+
+ return 0;
+}