From 9ebdd89c19ca0e70d193de3699281f2396906be5 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Thu, 29 Sep 2022 00:04:28 +0200 Subject: [PATCH 01/10] CI: Bring back NDK toolchain --- .github/workflows/build.yml | 25 ++++++++----------------- 1 file changed, 8 insertions(+), 17 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 92011cc..3b37816 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -3,12 +3,6 @@ name: Build on: push: -env: - TOOLCHAIN_URL: https://github.com/openlgtv/buildroot-nc4/releases/download/webos-9f5b1a1/arm-webos-linux-gnueabi_sdk-buildroot.tar.gz - TOOLCHAIN_SHA256: de49688d9d04bd533da59beb9a21e940203b95cc6ad4958858273b53502eb99b - TOOLCHAIN_DIR: /opt/arm-webos-linux-gnueabi_sdk-buildroot - TOOLCHAIN_FILE: /opt/arm-webos-linux-gnueabi_sdk-buildroot/share/buildroot/toolchainfile.cmake - jobs: build-native-component: strategy: @@ -23,17 +17,14 @@ jobs: submodules: recursive fetch-depth: 0 - - name: Download and unpack toolchain - working-directory: /opt - run: | - wget -q -O toolchain.tar.gz ${TOOLCHAIN_URL} - echo "${TOOLCHAIN_SHA256} toolchain.tar.gz"|sha256sum -c - - tar xf toolchain.tar.gz + - name: Download webOS NDK + run: wget -q https://github.com/webosbrew/meta-lg-webos-ndk/releases/download/1.0.g-rev.5/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh -P ${{github.workspace}}/temp + + - name: Install webOS NDK + run: chmod 755 ${{github.workspace}}/temp/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh && sudo ${{github.workspace}}/temp/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh -y - - name: Relocate toolchain - working-directory: ${{ env.TOOLCHAIN_DIR }} - run: | - ./relocate-sdk.sh + - name: Initialize NDK Environments + run: env -i bash -c '. /opt/webos-sdk-x86_64/1.0.g/environment-setup-armv7a-neon-webos-linux-gnueabi && env' >> $GITHUB_ENV - name: CMake Version run: cmake --version @@ -44,7 +35,7 @@ jobs: - name: Build component working-directory: ${{github.workspace}}/build shell: bash - run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DCMAKE_TOOLCHAIN_FILE=$TOOLCHAIN_FILE .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend + run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend - name: List files run: find . From ded4c4c5801034c1d8502a2a6a3fea3655e6bff0 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 16:45:55 +0200 Subject: [PATCH 02/10] bring back buildroot with neon --- .github/workflows/build.yml | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 3b37816..70d7ac0 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -3,6 +3,12 @@ name: Build on: push: +env: + TOOLCHAIN_URL: https://github.com/openlgtv/buildroot-nc4/releases/download/webos-c592d84/arm-webos-linux-gnueabi_sdk-buildroot.tar.gz + TOOLCHAIN_SHA256: be5b4249177fc31b3f0120106c761f42ade54fd609a3bd090852899bbdd680b9 + TOOLCHAIN_DIR: /opt/arm-webos-linux-gnueabi_sdk-buildroot + TOOLCHAIN_FILE: /opt/arm-webos-linux-gnueabi_sdk-buildroot/share/buildroot/toolchainfile.cmake + jobs: build-native-component: strategy: @@ -17,14 +23,22 @@ jobs: submodules: recursive fetch-depth: 0 - - name: Download webOS NDK - run: wget -q https://github.com/webosbrew/meta-lg-webos-ndk/releases/download/1.0.g-rev.5/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh -P ${{github.workspace}}/temp + - name: Download and unpack toolchain + working-directory: /opt + run: | + wget -q -O toolchain.tar.gz ${TOOLCHAIN_URL} + echo "${TOOLCHAIN_SHA256} toolchain.tar.gz"|sha256sum -c - + tar xf toolchain.tar.gz - - name: Install webOS NDK - run: chmod 755 ${{github.workspace}}/temp/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh && sudo ${{github.workspace}}/temp/webos-sdk-x86_64-armv7a-neon-toolchain-1.0.g.sh -y + - name: Relocate toolchain + working-directory: ${{ env.TOOLCHAIN_DIR }} + run: | + ./relocate-sdk.sh - - name: Initialize NDK Environments - run: env -i bash -c '. /opt/webos-sdk-x86_64/1.0.g/environment-setup-armv7a-neon-webos-linux-gnueabi && env' >> $GITHUB_ENV + - name: Set environment + run: | + env -i bash -c 'CFLAGS="$CFLAGS -mfpu=neon " && env' >> $GITHUB_ENV + echo $GITHUB_ENV - name: CMake Version run: cmake --version @@ -35,7 +49,7 @@ jobs: - name: Build component working-directory: ${{github.workspace}}/build shell: bash - run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend + run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DLIBYUV_NEON .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend - name: List files run: find . From c731e0331e2561cfceb1fe52f40fd51d00af1134 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 17:21:30 +0200 Subject: [PATCH 03/10] add toolchain in cmake cmd --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 70d7ac0..94143b9 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -49,7 +49,7 @@ jobs: - name: Build component working-directory: ${{github.workspace}}/build shell: bash - run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DLIBYUV_NEON .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend + run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DCMAKE_TOOLCHAIN_FILE=$TOOLCHAIN_FILE -DLIBYUV_NEON .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend - name: List files run: find . From 827f248be021f2855f3f7fe8c351ec67e8fbdc90 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 17:22:52 +0200 Subject: [PATCH 04/10] remove parameter from cmake cmd --- .github/workflows/build.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 94143b9..2779221 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -49,7 +49,7 @@ jobs: - name: Build component working-directory: ${{github.workspace}}/build shell: bash - run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DCMAKE_TOOLCHAIN_FILE=$TOOLCHAIN_FILE -DLIBYUV_NEON .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend + run: cmake -DCMAKE_BUILD_TYPE=${{ matrix.build-type }} -DCMAKE_TOOLCHAIN_FILE=$TOOLCHAIN_FILE .. && make hyperion-webos gm_backend halgal_backend dile_vt_backend vtcapture_backend - name: List files run: find . From 2aa538edd4dcde0bec5dc5fd55c8303bca057e27 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 17:43:54 +0200 Subject: [PATCH 05/10] move flags to cmakelists --- .github/workflows/build.yml | 5 ----- CMakeLists.txt | 2 +- 2 files changed, 1 insertion(+), 6 deletions(-) diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 2779221..eb563d1 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -35,11 +35,6 @@ jobs: run: | ./relocate-sdk.sh - - name: Set environment - run: | - env -i bash -c 'CFLAGS="$CFLAGS -mfpu=neon " && env' >> $GITHUB_ENV - echo $GITHUB_ENV - - name: CMake Version run: cmake --version diff --git a/CMakeLists.txt b/CMakeLists.txt index 9befcc5..29d4dc3 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -36,7 +36,7 @@ add_custom_target(version -P ${CMAKE_SOURCE_DIR}/GenerateVersionHeader.cmake ) -add_compile_options(-Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY) +add_compile_options(-Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY -mfpu=neon -DLIBYUV_NEON) add_executable(hyperion-webos src/main.c src/settings.c From 9b909101d6c00fe316796a93405d42b0218ff56e Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 19:07:21 +0200 Subject: [PATCH 06/10] use var for cflags --- CMakeLists.txt | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 29d4dc3..e7d6634 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,6 +1,9 @@ cmake_minimum_required(VERSION 3.6) project(hyperion-webos VERSION 1.0 LANGUAGES C CXX) +set(COMMON_FLAGS "-march=armv7-a -mfpu=neon -mfloat-abi=softfp -mthumb -mtune=cortex-a9") +string(APPEND CMAKE_C_FLAGS " ${COMMON_FLAGS}") + add_subdirectory(libyuv) add_subdirectory(tv-native-apis) add_subdirectory(flatccrt) @@ -36,7 +39,7 @@ add_custom_target(version -P ${CMAKE_SOURCE_DIR}/GenerateVersionHeader.cmake ) -add_compile_options(-Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY -mfpu=neon -DLIBYUV_NEON) +add_compile_options(-Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY) add_executable(hyperion-webos src/main.c src/settings.c From 0f7a42efc963a0b344172f36d04b70d3e5c94598 Mon Sep 17 00:00:00 2001 From: TBSniller Date: Sun, 2 Oct 2022 19:07:51 +0200 Subject: [PATCH 07/10] use var for cflags --- libyuv/CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/libyuv/CMakeLists.txt b/libyuv/CMakeLists.txt index d14c04e..814a0a8 100644 --- a/libyuv/CMakeLists.txt +++ b/libyuv/CMakeLists.txt @@ -3,7 +3,7 @@ include(ExternalProject) ExternalProject_Add( libyuv URL https://chromium.googlesource.com/libyuv/libyuv/+archive/fdc71956bdade0012b0628b5011b567c06c72308.tar.gz - CMAKE_ARGS "-DBUILD_SHARED_LIBS=OFF" "-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}" "-DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_SOURCE_DIR}" "-DCMAKE_POSITION_INDEPENDENT_CODE=ON" + CMAKE_ARGS "-DCMAKE_C_FLAGS=${COMMON_FLAGS}" "-DBUILD_SHARED_LIBS=OFF" "-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}" "-DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_SOURCE_DIR}" "-DCMAKE_POSITION_INDEPENDENT_CODE=ON" ) add_library(yuv STATIC IMPORTED GLOBAL) From 1e88ca9f6b44f2f7fcc5ddf8784fd2d7cef1e092 Mon Sep 17 00:00:00 2001 From: Stefano Moioli Date: Sun, 2 Oct 2022 19:04:52 +0200 Subject: [PATCH 08/10] Fixed NEON compiler flags --- CMakeLists.txt | 9 ++++++++- libyuv/CMakeLists.txt | 9 ++++++++- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 9befcc5..d830be6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,10 +1,18 @@ cmake_minimum_required(VERSION 3.6) project(hyperion-webos VERSION 1.0 LANGUAGES C CXX) +set(_cflags_list "") +list(APPEND _cflags_list + -mcpu=cortex-a9 -mfloat-abi=softfp -mfpu=neon-fp16 +) +list(JOIN _cflags_list " " COMMON_FLAGS) + add_subdirectory(libyuv) add_subdirectory(tv-native-apis) add_subdirectory(flatccrt) +add_compile_options(${_cflags_list} -Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY) + find_package(PkgConfig REQUIRED) # --- @@ -36,7 +44,6 @@ add_custom_target(version -P ${CMAKE_SOURCE_DIR}/GenerateVersionHeader.cmake ) -add_compile_options(-Wall -Wextra -Wpedantic -Werror -DSECURITY_COMPATIBILITY) add_executable(hyperion-webos src/main.c src/settings.c diff --git a/libyuv/CMakeLists.txt b/libyuv/CMakeLists.txt index d14c04e..bbe151e 100644 --- a/libyuv/CMakeLists.txt +++ b/libyuv/CMakeLists.txt @@ -3,7 +3,14 @@ include(ExternalProject) ExternalProject_Add( libyuv URL https://chromium.googlesource.com/libyuv/libyuv/+archive/fdc71956bdade0012b0628b5011b567c06c72308.tar.gz - CMAKE_ARGS "-DBUILD_SHARED_LIBS=OFF" "-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}" "-DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_SOURCE_DIR}" "-DCMAKE_POSITION_INDEPENDENT_CODE=ON" + CMAKE_ARGS + -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE} + -DCMAKE_C_FLAGS=${COMMON_FLAGS} + -DCMAKE_CXX_FLAGS=${COMMON_FLAGS} + -DBUILD_SHARED_LIBS=OFF + -DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE} + -DCMAKE_INSTALL_PREFIX=${CMAKE_CURRENT_SOURCE_DIR} + -DCMAKE_POSITION_INDEPENDENT_CODE=ON ) add_library(yuv STATIC IMPORTED GLOBAL) From 4026221d9e1f9b4fd0c582e5f9363cb6d7b9d9a5 Mon Sep 17 00:00:00 2001 From: Stefano Moioli Date: Sun, 2 Oct 2022 19:41:09 +0200 Subject: [PATCH 09/10] Use the more conservative -mfpu=neon (for wider compatibility) --- CMakeLists.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index d830be6..5a04fe6 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,7 +3,7 @@ project(hyperion-webos VERSION 1.0 LANGUAGES C CXX) set(_cflags_list "") list(APPEND _cflags_list - -mcpu=cortex-a9 -mfloat-abi=softfp -mfpu=neon-fp16 + -mcpu=cortex-a9 -mfloat-abi=softfp -mfpu=neon ) list(JOIN _cflags_list " " COMMON_FLAGS) From a94be2398359e790aa2a8becd136eccc7e6816cc Mon Sep 17 00:00:00 2001 From: Stephan Sundermann Date: Wed, 20 Jul 2022 06:02:49 -0700 Subject: [PATCH 10/10] Add unix socket support Local unix socket support was added in HyperHDR in https://github.com/awawa-dev/HyperHDR/commit/1100093068196a53eff5f856f0eaaf8e43ca229f Adds the --unix-socket / -l switch in which case a connection over a local unix socket on the specified address is established. On my TV unix sockets are around 20-30% faster. --- src/hyperion_client.c | 130 ++++++++++++++++++++++++++++++------------ src/hyperion_client.h | 3 +- src/main.c | 7 ++- src/service.c | 7 ++- src/settings.c | 4 ++ src/settings.h | 1 + 6 files changed, 109 insertions(+), 43 deletions(-) diff --git a/src/hyperion_client.c b/src/hyperion_client.c index 495a326..a21c7ea 100644 --- a/src/hyperion_client.c +++ b/src/hyperion_client.c @@ -10,11 +10,14 @@ #include #include #include +#include #include #include "hyperion_reply_reader.h" #include "hyperion_request_builder.h" +static int _connect_unix_socket(const char* hostname); +static int _connect_inet_socket(const char* hostname, int port); static int _send_message(const void* buffer, size_t size); static bool _parse_reply(hyperionnet_Reply_table_t reply); @@ -25,53 +28,20 @@ static const char* _origin = NULL; static bool _connected = false; unsigned char recvBuff[1024]; -int hyperion_client(const char* origin, const char* hostname, int port, int priority) +int hyperion_client(const char* origin, const char* hostname, int port, bool unix_socket, int priority) { _origin = origin; _priority = priority; _connected = false; _registered = false; sockfd = 0; - struct sockaddr_in serv_addr; - if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { - WARN("Could not create socket: %s", strerror(errno)); - return 1; - } - struct timeval timeout; - timeout.tv_sec = 1; - timeout.tv_usec = 0; - - if (setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, (char*)&timeout, - sizeof(timeout)) - < 0) { - WARN("setsockopt(SO_SNDTIMEO) failed: %s", strerror(errno)); - return 1; - } - - if (setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO, (char*)&timeout, - sizeof(timeout)) - < 0) { - WARN("setsockopt(SO_RCVTIMEO) failed: %s", strerror(errno)); - return 1; - } - - memset(&serv_addr, '0', sizeof(serv_addr)); - - serv_addr.sin_family = AF_INET; - serv_addr.sin_port = htons(port); - if (inet_pton(AF_INET, hostname, &serv_addr.sin_addr) <= 0) { - WARN("inet_pton error occured (hostname: %s): %s", hostname, strerror(errno)); - return 1; - } - if (connect(sockfd, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) < 0) { - WARN("connect() to %s:%d failed: %s", hostname, port, strerror(errno)); - return 1; + if (unix_socket) { + return _connect_unix_socket(hostname); + } else { + return _connect_inet_socket(hostname, port); } - _connected = true; - - return 0; } int hyperion_read() @@ -197,3 +167,87 @@ bool _parse_reply(hyperionnet_Reply_table_t reply) return false; } + +int _connect_inet_socket(const char* hostname, int port) +{ + struct sockaddr_in serv_addr_in; + + if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { + WARN("Could not create socket: %s", strerror(errno)); + return 1; + } + struct timeval timeout; + timeout.tv_sec = 1; + timeout.tv_usec = 0; + + if (setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, (char*)&timeout, + sizeof(timeout)) + < 0) { + WARN("setsockopt(SO_SNDTIMEO) failed: %s", strerror(errno)); + return 1; + } + + if (setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO, (char*)&timeout, + sizeof(timeout)) + < 0) { + WARN("setsockopt(SO_RCVTIMEO) failed: %s", strerror(errno)); + return 1; + } + + memset(&serv_addr_in, 0, sizeof(serv_addr_in)); + + serv_addr_in.sin_family = AF_INET; + serv_addr_in.sin_port = htons(port); + + if (inet_pton(AF_INET, hostname, &serv_addr_in.sin_addr) <= 0) { + WARN("inet_pton error occured (hostname: %s): %s", hostname, strerror(errno)); + return 1; + } + + if (connect(sockfd, (struct sockaddr*)&serv_addr_in, sizeof(serv_addr_in)) < 0) { + WARN("connect() to %s:%d failed: %s", hostname, port, strerror(errno)); + return 1; + } + _connected = true; + + return 0; +} + +int _connect_unix_socket(const char* hostname) +{ + struct sockaddr_un serv_addr_un; + + if ((sockfd = socket(AF_UNIX, SOCK_STREAM, 0)) == -1) { + WARN("Could not create socket: %s", strerror(errno)); + return 1; + } + struct timeval timeout; + timeout.tv_sec = 1; + timeout.tv_usec = 0; + + if (setsockopt(sockfd, SOL_SOCKET, SO_SNDTIMEO, (char*)&timeout, + sizeof(timeout)) + < 0) { + WARN("setsockopt(SO_SNDTIMEO) failed: %s", strerror(errno)); + return 1; + } + + if (setsockopt(sockfd, SOL_SOCKET, SO_RCVTIMEO, (char*)&timeout, + sizeof(timeout)) < 0) { + WARN("setsockopt(SO_RCVTIMEO) failed: %s", strerror(errno)); + return 1; + } + + memset(&serv_addr_un, 0, sizeof(serv_addr_un)); + + serv_addr_un.sun_family = AF_LOCAL; + strcpy(serv_addr_un.sun_path, hostname); + + if (connect(sockfd, (struct sockaddr*)&serv_addr_un, sizeof(serv_addr_un)) < 0) { + WARN("connect() to unix socket %s failed: %s", hostname, strerror(errno)); + return 1; + } + _connected = true; + + return 0; +} \ No newline at end of file diff --git a/src/hyperion_client.h b/src/hyperion_client.h index 5301949..315dd40 100644 --- a/src/hyperion_client.h +++ b/src/hyperion_client.h @@ -1,6 +1,7 @@ #pragma once +#include -int hyperion_client(const char* origin, const char* hostname, int port, int priority); +int hyperion_client(const char* origin, const char* hostname, int port, bool unix_socket, int priority); int hyperion_read(); int hyperion_destroy(); int hyperion_set_image(const unsigned char* image, int width, int height); diff --git a/src/main.c b/src/main.c index 7cfe246..ac57627 100644 --- a/src/main.c +++ b/src/main.c @@ -24,6 +24,7 @@ static struct option long_options[] = { { "height", required_argument, 0, 'y' }, { "address", required_argument, 0, 'a' }, { "port", required_argument, 0, 'p' }, + { "unix-socket", no_argument, 0, 'l' }, { "fps", required_argument, 0, 'f' }, { "no-video", no_argument, 0, 'V' }, { "no-gui", no_argument, 0, 'G' }, @@ -50,6 +51,7 @@ static void print_usage() printf(" -y, --height=HEIGHT Height of video frame (default 108)\n"); printf(" -a, --address=ADDR IP address of Hyperion server\n"); printf(" -p, --port=PORT Port of Hyperion flatbuffers server (default 19400)\n"); + printf(" -l, --unix-socket Connect through unix socket\n"); printf(" -f, --fps=FPS Framerate for sending video frames (default 0 = unlimited)\n"); printf(" -b, --backend=BE Use specific video capture backend (default auto)\n"); printf(" -u, --ui-backend=BE Use specific ui capture backend (default auto)\n"); @@ -70,7 +72,7 @@ static int parse_options(int argc, char* argv[]) int opt, longindex; int ret; - while ((opt = getopt_long(argc, argv, "x:y:a:p:f:b:u:q:c:vnhdVG", long_options, &longindex)) != -1) { + while ((opt = getopt_long(argc, argv, "x:y:a:p:f:b:u:q:c:lvnhdVG", long_options, &longindex)) != -1) { switch (opt) { case 'x': settings.width = atoi(optarg); @@ -85,6 +87,9 @@ static int parse_options(int argc, char* argv[]) case 'p': settings.port = atol(optarg); break; + case 'l': + settings.unix_socket = true; + break; case 'f': settings.fps = atoi(optarg); break; diff --git a/src/service.c b/src/service.c index 82695b3..010bffb 100644 --- a/src/service.c +++ b/src/service.c @@ -28,7 +28,8 @@ void* connection_loop(void* data) DBG("Starting connection loop"); while (service->connection_loop_running) { INFO("Connecting hyperion-client.."); - if ((hyperion_client("webos", service->settings->address, service->settings->port, service->settings->priority)) != 0) { + if ((hyperion_client("webos", service->settings->address, service->settings->port, + service->settings->unix_socket, service->settings->priority)) != 0) { ERR("Error! hyperion_client."); } else { INFO("hyperion-client connected!"); @@ -407,7 +408,7 @@ static bool videooutput_callback(LSHandle* sh __attribute__((unused)), LSMessage hdr_enabled = true; } - int ret = set_hdr_state(service->settings->address, RPC_PORT, hdr_enabled); + int ret = set_hdr_state(service->settings->unix_socket ? "127.0.0.1" : service->settings->address, RPC_PORT, hdr_enabled); if (ret != 0) { ERR("videooutput_callback: set_hdr_state failed, ret: %d", ret); } @@ -459,7 +460,7 @@ static bool picture_callback(LSHandle* sh __attribute__((unused)), LSMessage* ms hdr_enabled = true; } - int ret = set_hdr_state(service->settings->address, RPC_PORT, hdr_enabled); + int ret = set_hdr_state(service->settings->unix_socket ? "127.0.0.1" : service->settings->address, RPC_PORT, hdr_enabled); if (ret != 0) { ERR("videooutput_callback: set_hdr_state failed, ret: %d", ret); } diff --git a/src/settings.c b/src/settings.c index 4943bc5..3e2c958 100644 --- a/src/settings.c +++ b/src/settings.c @@ -9,6 +9,7 @@ void settings_init(settings_t* settings) settings->address = strdup(""); settings->port = 19400; settings->priority = 150; + settings->unix_socket = false; settings->fps = 30; settings->width = 320; @@ -51,6 +52,8 @@ int settings_load_json(settings_t* settings, jvalue_ref source) jnumber_get_i32(value, &settings->port); if ((value = jobject_get(source, j_cstr_to_buffer("priority"))) && jis_number(value)) jnumber_get_i32(value, &settings->priority); + if ((value = jobject_get(source, j_cstr_to_buffer("unix-socket"))) && jis_boolean(value)) + jboolean_get(value, &settings->unix_socket); if ((value = jobject_get(source, j_cstr_to_buffer("fps"))) && jis_number(value)) jnumber_get_i32(value, &settings->fps); @@ -81,6 +84,7 @@ int settings_save_json(settings_t* settings, jvalue_ref target) jobject_set(target, j_cstr_to_buffer("address"), jstring_create(settings->address)); jobject_set(target, j_cstr_to_buffer("port"), jnumber_create_i32(settings->port)); jobject_set(target, j_cstr_to_buffer("priority"), jnumber_create_i32(settings->priority)); + jobject_set(target, j_cstr_to_buffer("unix-socket"), jboolean_create(settings->unix_socket)); jobject_set(target, j_cstr_to_buffer("fps"), jnumber_create_i32(settings->fps)); jobject_set(target, j_cstr_to_buffer("width"), jnumber_create_i32(settings->width)); diff --git a/src/settings.h b/src/settings.h index 027c3e7..2768af6 100644 --- a/src/settings.h +++ b/src/settings.h @@ -14,6 +14,7 @@ typedef struct _settings_t { char* address; int port; int priority; + bool unix_socket; int fps; int width;