git: 1e807e9107f0 - main - games/moonlight-embedded: Update to 2.7.0
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Sat, 20 Jul 2024 17:38:28 UTC
The branch main has been updated by arrowd: URL: https://cgit.FreeBSD.org/ports/commit/?id=1e807e9107f0315e74d6fc4a3ea6194a3423770e commit 1e807e9107f0315e74d6fc4a3ea6194a3423770e Author: Armin Zhu <lisp_25689@163.com> AuthorDate: 2024-07-20 12:33:01 +0000 Commit: Gleb Popov <arrowd@FreeBSD.org> CommitDate: 2024-07-20 17:38:21 +0000 games/moonlight-embedded: Update to 2.7.0 PR: 280114 --- games/moonlight-embedded/Makefile | 35 +++++-- games/moonlight-embedded/distinfo | 6 +- .../moonlight-embedded/files/patch-CMakeLists.txt | 14 --- .../files/patch-libgamestream_CMakeLists.txt | 8 +- .../files/patch-libgamestream_client.c | 7 +- .../files/patch-libgamestream_http.c | 12 --- .../files/patch-src_audio_audio.h | 9 -- .../moonlight-embedded/files/patch-src_audio_oss.c | 108 --------------------- .../files/patch-src_input_evdev.c | 33 ++----- games/moonlight-embedded/files/patch-src_main.c | 11 ++- .../moonlight-embedded/files/patch-src_platform.c | 12 --- 11 files changed, 48 insertions(+), 207 deletions(-) diff --git a/games/moonlight-embedded/Makefile b/games/moonlight-embedded/Makefile index 7fd965f80162..b29c299b8f13 100644 --- a/games/moonlight-embedded/Makefile +++ b/games/moonlight-embedded/Makefile @@ -1,5 +1,5 @@ PORTNAME= moonlight-embedded -DISTVERSION= 2.6.2 +DISTVERSION= 2.7.0 CATEGORIES= games MASTER_SITES= https://github.com/moonlight-stream/moonlight-embedded/releases/download/v${DISTVERSION}/ @@ -19,28 +19,45 @@ LIB_DEPENDS= libavahi-client.so:net/avahi-app \ libexpat.so:textproc/expat2 \ libopus.so:audio/opus \ libudev.so:devel/libudev-devd \ - libuuid.so:misc/e2fsprogs-libuuid \ - libvdpau.so:multimedia/libvdpau \ - libva.so:multimedia/libva + libuuid.so:misc/e2fsprogs-libuuid -USES= cmake gl localbase:ldflags perl5 pkgconfig sdl ssl tar:xz xorg +USES= cmake localbase:ldflags perl5 pkgconfig sdl ssl tar:xz USE_LDCONFIG= yes -USE_GL= egl glesv2 USE_PERL5= build USE_SDL= sdl2 -USE_XORG= x11 NO_WRKSUBDIR= yes CFLAGS+= -DHAS_SOCKLEN_T=1 -I${LOCALBASE}/include/libepoll-shim/ LDFLAGS+= -lepoll-shim -CMAKE_OFF= ENABLE_CEC ENABLE_PULSE -CMAKE_ON= ENET_NO_INSTALL +CONFLICTS_INSTALL= moonlight-embedded-devel PLIST_FILES= bin/moonlight \ "@sample etc/moonlight.conf.sample" \ share/man/man1/moonlight.1.gz \ share/moonlight/gamecontrollerdb.txt +OPTIONS_DEFAULT= OSS X11 +OSS_DESC= Open Sound System support for embedded(not SDL) platform +PULSE_DESC= PulseAudio sound server support for embedded(not SDL) platform +CEC_DESC= Enable HDMI-CEC(TV controller) feature by using libcec.so +X11_DESC= Enable x11 and x11_vaapi platform using xorg +OPTIONS_SINGLE= SOUND +OPTIONS_SINGLE_SOUND= OSS PULSE +OPTIONS_GROUP= DISPLAY OTHERS +OPTIONS_GROUP_OTHERS= CEC +OPTIONS_GROUP_DISPLAY= X11 +OSS_CMAKE_ON= -DENABLE_PULSE:BOOL=false +PULSE_CMAKE_BOOL= ENABLE_PULSE +PULSE_LIB_DEPENDS= libpulse.so:audio/pulseaudio +CEC_CMAKE_BOOL= ENABLE_CEC +CEC_LIB_DEPENDS= libcec.so:multimedia/libcec \ + libp8-platform.so:devel/p8-platform +X11_USES= xorg gl +X11_USE= xorg=x11 gl=egl,glesv2 +X11_CMAKE_BOOL= ENABLE_X11 +X11_LIB_DEPENDS= libvdpau.so:multimedia/libvdpau \ + libva.so:multimedia/libva + post-extract: @${REINPLACE_CMD} -e 's|/etc/moonlight/|${PREFIX}/etc/moonlight/|g' \ ${WRKSRC}/docs/README.pod diff --git a/games/moonlight-embedded/distinfo b/games/moonlight-embedded/distinfo index fbade7d0fe56..368b842ee506 100644 --- a/games/moonlight-embedded/distinfo +++ b/games/moonlight-embedded/distinfo @@ -1,3 +1,3 @@ -TIMESTAMP = 1701007066 -SHA256 (moonlight-embedded-2.6.2.tar.xz) = 8bcc69b403a628efaf8686d40c0d1428b46defe4c65b06ff6ccc3fe32f0b2356 -SIZE (moonlight-embedded-2.6.2.tar.xz) = 328660 +TIMESTAMP = 1708491885 +SHA256 (moonlight-embedded-2.7.0.tar.xz) = 6527718e678dafd6e1e1876bbc6949538b38986d54ebda0b7fdc3b3f4af4f2dd +SIZE (moonlight-embedded-2.7.0.tar.xz) = 335984 diff --git a/games/moonlight-embedded/files/patch-CMakeLists.txt b/games/moonlight-embedded/files/patch-CMakeLists.txt deleted file mode 100644 index fef9d3015b15..000000000000 --- a/games/moonlight-embedded/files/patch-CMakeLists.txt +++ /dev/null @@ -1,14 +0,0 @@ ---- CMakeLists.txt.orig 2023-11-03 06:08:34 UTC -+++ CMakeLists.txt -@@ -87,6 +87,11 @@ add_executable(moonlight ${SRC_LIST}) - target_link_libraries(moonlight m) - target_link_libraries(moonlight gamestream) - -+if (CMAKE_SYSTEM_NAME MATCHES "FreeBSD") -+ set(ALSA_FOUND FALSE) -+ target_sources(moonlight PRIVATE ./src/audio/oss.c) -+endif() -+ - if (CEC_FOUND) - list(APPEND MOONLIGHT_DEFINITIONS HAVE_LIBCEC) - list(APPEND MOONLIGHT_OPTIONS CEC) diff --git a/games/moonlight-embedded/files/patch-libgamestream_CMakeLists.txt b/games/moonlight-embedded/files/patch-libgamestream_CMakeLists.txt index a758f6c03392..609280935a23 100644 --- a/games/moonlight-embedded/files/patch-libgamestream_CMakeLists.txt +++ b/games/moonlight-embedded/files/patch-libgamestream_CMakeLists.txt @@ -1,6 +1,6 @@ ---- libgamestream/CMakeLists.txt.orig 2023-11-03 06:08:34 UTC +--- libgamestream/CMakeLists.txt.orig 2024-02-20 04:01:31 UTC +++ libgamestream/CMakeLists.txt -@@ -3,7 +3,7 @@ set(SO_VERSION 4) +@@ -3,7 +3,7 @@ find_package(CURL REQUIRED) find_package(LibUUID REQUIRED) find_package(Threads REQUIRED) find_package(CURL REQUIRED) @@ -21,8 +21,8 @@ target_link_libraries(gamestream moonlight-common) set_target_properties(gamestream PROPERTIES SOVERSION ${SO_VERSION} VERSION ${PROJECT_VERSION}) -@@ -28,5 +28,3 @@ target_include_directories(moonlight-common PRIVATE .. - target_link_libraries(gamestream ${CURL_LIBRARIES} ${OPENSSL_LIBRARIES} ${EXPAT_LIBRARIES} ${AVAHI_LIBRARIES} ${LIBUUID_LIBRARIES}) +@@ -28,5 +28,3 @@ target_link_libraries(gamestream ${CMAKE_THREAD_LIBS_I + target_link_libraries(gamestream ${CURL_LIBRARIES} ${OPENSSL_LIBRARIES} ${EXPAT_LIBRARIES} ${AVAHI_LIBRARIES} ${LibUUID_LIBRARIES}) target_link_libraries(gamestream ${CMAKE_THREAD_LIBS_INIT} ${CMAKE_DL_LIBS}) - diff --git a/games/moonlight-embedded/files/patch-libgamestream_client.c b/games/moonlight-embedded/files/patch-libgamestream_client.c index 1efe5f0f8e14..175d9029755d 100644 --- a/games/moonlight-embedded/files/patch-libgamestream_client.c +++ b/games/moonlight-embedded/files/patch-libgamestream_client.c @@ -1,10 +1,9 @@ ---- libgamestream/client.c.orig 2023-11-03 06:08:34 UTC +--- libgamestream/client.c.orig 2024-02-20 04:01:31 UTC +++ libgamestream/client.c -@@ -537,7 +537,16 @@ int gs_pair(PSERVER_DATA server, char* pin) { +@@ -539,7 +539,15 @@ int gs_pair(PSERVER_DATA server, char* pin) { RAND_bytes(client_secret_data, sizeof(client_secret_data)); const ASN1_BIT_STRING *asnSignature; -+ +#ifdef __FreeBSD__ + #if OPENSSL_VERSION_NUMBER >= 0x10100000L && !defined(LIBRESSL_VERSION_NUMBER) X509_get0_signature(&asnSignature, NULL, cert); @@ -15,5 +14,5 @@ + X509_get0_signature(&asnSignature, NULL, cert); +#endif - char challenge_response[16 + SIGNATURE_LEN + sizeof(client_secret_data)]; + challenge_response = malloc(16 + asnSignature->length + sizeof(client_secret_data)); char challenge_response_hash[32]; diff --git a/games/moonlight-embedded/files/patch-libgamestream_http.c b/games/moonlight-embedded/files/patch-libgamestream_http.c deleted file mode 100644 index 112582df9d7c..000000000000 --- a/games/moonlight-embedded/files/patch-libgamestream_http.c +++ /dev/null @@ -1,12 +0,0 @@ ---- libgamestream/http.c.orig 2023-11-03 06:08:34 UTC -+++ libgamestream/http.c -@@ -73,6 +73,9 @@ int http_init(const char* keyDirectory, int logLevel) - int http_request(char* url, PHTTP_DATA data) { - curl_easy_setopt(curl, CURLOPT_WRITEDATA, data); - curl_easy_setopt(curl, CURLOPT_URL, url); -+#ifdef __FreeBSD__ -+ curl_easy_setopt(curl, CURLOPT_FORBID_REUSE, 1); -+#endif - - if (debug) - printf("Request %s\n", url); diff --git a/games/moonlight-embedded/files/patch-src_audio_audio.h b/games/moonlight-embedded/files/patch-src_audio_audio.h deleted file mode 100644 index 66625239ed63..000000000000 --- a/games/moonlight-embedded/files/patch-src_audio_audio.h +++ /dev/null @@ -1,9 +0,0 @@ ---- src/audio/audio.h.orig 2023-11-03 06:08:34 UTC -+++ src/audio/audio.h -@@ -31,3 +31,6 @@ extern AUDIO_RENDERER_CALLBACKS audio_callbacks_sdl; - extern AUDIO_RENDERER_CALLBACKS audio_callbacks_pulse; - bool audio_pulse_init(char* audio_device); - #endif -+#ifdef __FreeBSD__ -+extern AUDIO_RENDERER_CALLBACKS audio_callbacks_oss; -+#endif diff --git a/games/moonlight-embedded/files/patch-src_audio_oss.c b/games/moonlight-embedded/files/patch-src_audio_oss.c deleted file mode 100644 index ddd61c493d8a..000000000000 --- a/games/moonlight-embedded/files/patch-src_audio_oss.c +++ /dev/null @@ -1,108 +0,0 @@ ---- src/audio/oss.c.orig 2024-01-01 05:31:28 UTC -+++ src/audio/oss.c -@@ -0,0 +1,105 @@ -+/* -+ * This file is part of Moonlight Embedded. -+ * -+ * Copyright (C) 2015-2017 Iwan Timmer -+ * -+ * Moonlight is free software; you can redistribute it and/or modify -+ * it under the terms of the GNU General Public License as published by -+ * the Free Software Foundation; either version 3 of the License, or -+ * (at your option) any later version. -+ * -+ * Moonlight is distributed in the hope that it will be useful, -+ * but WITHOUT ANY WARRANTY; without even the implied warranty of -+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -+ * GNU General Public License for more details. -+ * -+ * You should have received a copy of the GNU General Public License -+ * along with Moonlight; if not, see <http://www.gnu.org/licenses/>. -+ */ -+ -+#ifdef __FreeBSD__ -+#include <sys/soundcard.h> -+#include <sys/ioctl.h> -+#include "audio.h" -+ -+#include <opus_multistream.h> -+ -+#include <errno.h> -+#include <fcntl.h> -+#include <stdio.h> -+#include <stdlib.h> -+#include <unistd.h> -+ -+static OpusMSDecoder* decoder; -+static short* pcmBuffer; -+static int samplesPerFrame; -+static int channelCount; -+static int fd = -1; -+ -+static int oss_renderer_init(int audioConfiguration, POPUS_MULTISTREAM_CONFIGURATION opusConfig, void* context, int arFlags) { -+ int rc; -+ decoder = opus_multistream_decoder_create(opusConfig->sampleRate, opusConfig->channelCount, opusConfig->streams, opusConfig->coupledStreams, opusConfig->mapping, &rc); -+ -+ channelCount = opusConfig->channelCount; -+ samplesPerFrame = opusConfig->samplesPerFrame; -+ pcmBuffer = malloc(sizeof(short) * channelCount * samplesPerFrame); -+ if (pcmBuffer == NULL) -+ return -1; -+ -+ const char* oss_name = "/dev/dsp"; -+ fd = open(oss_name, O_WRONLY); -+ if (fd == -1) { -+ printf("Open audio device /dev/dsp failed! error %d\n", errno); -+ return -1; -+ } -+ // buffer size for fragment ,selector 12 is 4096;11 is 2048;10 is 1024; 13is 8192 -+ int frag = 12; -+ if (ioctl(fd, SNDCTL_DSP_SETFRAGMENT, &frag) == -1) -+ printf("Set fragment for /dev/dsp failed."); -+ -+ int format = AFMT_S16_LE; -+ int channels = opusConfig->channelCount; -+ int rate = opusConfig->sampleRate; -+ if (ioctl(fd, SNDCTL_DSP_SETFMT, &format) == -1) -+ printf("Set format for /dev/dsp failed."); -+ if (ioctl(fd, SNDCTL_DSP_CHANNELS, &channels) == -1) -+ printf("Set channels for /dev/dsp failed."); -+ if (ioctl(fd, SNDCTL_DSP_SPEED, &rate) == -1) -+ printf("Set sample rate for /dev/dsp failed."); -+ -+ return 0; -+} -+ -+static void oss_renderer_cleanup() { -+ if (decoder != NULL) { -+ opus_multistream_decoder_destroy(decoder); -+ decoder = NULL; -+ } -+ -+ if (pcmBuffer != NULL) { -+ free(pcmBuffer); -+ pcmBuffer = NULL; -+ } -+ -+ if (fd != -1) { -+ close(fd); -+ fd = -1; -+ } -+} -+ -+static void oss_renderer_decode_and_play_sample(char* data, int length) { -+ int decodeLen = opus_multistream_decode(decoder, data, length, pcmBuffer, samplesPerFrame, 0); -+ if (decodeLen > 0) { -+ write(fd, pcmBuffer, decodeLen * channelCount * sizeof(short)); -+ } else if (decodeLen < 0) { -+ printf("Opus error from decode: %d\n", decodeLen); -+ } -+} -+ -+AUDIO_RENDERER_CALLBACKS audio_callbacks_oss = { -+ .init = oss_renderer_init, -+ .cleanup = oss_renderer_cleanup, -+ .decodeAndPlaySample = oss_renderer_decode_and_play_sample, -+ .capabilities = CAPABILITY_DIRECT_SUBMIT | CAPABILITY_SUPPORTS_ARBITRARY_AUDIO_DURATION, -+}; -+#endif diff --git a/games/moonlight-embedded/files/patch-src_input_evdev.c b/games/moonlight-embedded/files/patch-src_input_evdev.c index f2812ca25ca6..c7f9be90ab9a 100644 --- a/games/moonlight-embedded/files/patch-src_input_evdev.c +++ b/games/moonlight-embedded/files/patch-src_input_evdev.c @@ -1,14 +1,7 @@ ---- src/input/evdev.c.orig 2023-11-03 06:08:34 UTC +--- src/input/evdev.c.orig 2024-02-20 04:01:31 UTC +++ src/input/evdev.c -@@ -38,9 +38,15 @@ - #include <limits.h> - #include <unistd.h> - #include <pthread.h> -+#ifdef __linux__ - #include <endian.h> -+#else -+#include <sys/endian.h> -+#endif +@@ -45,6 +45,8 @@ + #endif #include <math.h> +static bool isUseKbdmux = false; @@ -16,21 +9,7 @@ #if __BYTE_ORDER == __LITTLE_ENDIAN #define int16_to_le(val) val #else -@@ -66,8 +72,13 @@ struct input_device { - int hats_state[3][2]; - int fd; - char modifiers; -+ #ifdef __linux__ - __s32 mouseDeltaX, mouseDeltaY, mouseVScroll, mouseHScroll; - __s32 touchDownX, touchDownY, touchX, touchY; -+ #else -+ int32_t mouseDeltaX, mouseDeltaY, mouseVScroll, mouseHScroll; -+ int32_t touchDownX, touchDownY, touchX, touchY; -+ #endif - struct timeval touchDownTime; - struct timeval btnDownTime; - short controllerId; -@@ -749,7 +760,7 @@ static int evdev_handle(int fd) { +@@ -758,7 +760,7 @@ static int evdev_handle(int fd) { struct input_event ev; while ((rc = libevdev_next_event(devices[i].dev, LIBEVDEV_READ_FLAG_NORMAL, &ev)) >= 0) { if (rc == LIBEVDEV_READ_STATUS_SYNC) @@ -39,7 +18,7 @@ else if (rc == LIBEVDEV_READ_STATUS_SUCCESS) { if (!handler(&ev, &devices[i])) return LOOP_RETURN; -@@ -766,6 +777,39 @@ static int evdev_handle(int fd) { +@@ -775,6 +777,39 @@ static int evdev_handle(int fd) { return LOOP_OK; } @@ -79,7 +58,7 @@ void evdev_create(const char* device, struct mapping* mappings, bool verbose, int rotate) { int fd = open(device, O_RDWR|O_NONBLOCK); if (fd <= 0) { -@@ -840,6 +884,33 @@ void evdev_create(const char* device, struct mapping* +@@ -851,6 +886,33 @@ void evdev_create(const char* device, struct mapping* libevdev_has_event_code(evdev, EV_ABS, ABS_WHEEL) || libevdev_has_event_code(evdev, EV_ABS, ABS_GAS) || libevdev_has_event_code(evdev, EV_ABS, ABS_BRAKE)); diff --git a/games/moonlight-embedded/files/patch-src_main.c b/games/moonlight-embedded/files/patch-src_main.c index 827f3a3ade46..478f6ba2ccfa 100644 --- a/games/moonlight-embedded/files/patch-src_main.c +++ b/games/moonlight-embedded/files/patch-src_main.c @@ -1,4 +1,4 @@ ---- src/main.c.orig 2023-11-03 06:08:34 UTC +--- src/main.c.orig 2024-02-20 04:01:31 UTC +++ src/main.c @@ -42,6 +42,7 @@ #include <client.h> @@ -54,16 +54,17 @@ #ifdef HAVE_SDL if (system == SDL) -@@ -362,6 +363,8 @@ int main(int argc, char* argv[]) { +@@ -362,6 +363,9 @@ int main(int argc, char* argv[]) { mappings = map; } + // test is use kbdmux driver -+ is_use_kbdmux(); ++ if (config.inputsCount <= 0) ++ is_use_kbdmux(); for (int i=0;i<config.inputsCount;i++) { if (config.debug_level > 0) printf("Adding input device %s...\n", config.inputs[i]); -@@ -398,7 +401,8 @@ int main(int argc, char* argv[]) { +@@ -398,7 +402,8 @@ int main(int argc, char* argv[]) { if (config.pin > 0 && config.pin <= 9999) { sprintf(pin, "%04d", config.pin); } else { @@ -73,7 +74,7 @@ } printf("Please enter the following PIN on the target PC: %s\n", pin); fflush(stdout); -@@ -406,6 +410,7 @@ int main(int argc, char* argv[]) { +@@ -406,6 +411,7 @@ int main(int argc, char* argv[]) { fprintf(stderr, "Failed to pair to server: %s\n", gs_error); } else { printf("Succesfully paired\n"); diff --git a/games/moonlight-embedded/files/patch-src_platform.c b/games/moonlight-embedded/files/patch-src_platform.c deleted file mode 100644 index 4fe2435269b2..000000000000 --- a/games/moonlight-embedded/files/patch-src_platform.c +++ /dev/null @@ -1,12 +0,0 @@ ---- src/platform.c.orig 2023-11-03 06:08:34 UTC -+++ src/platform.c -@@ -202,6 +202,9 @@ AUDIO_RENDERER_CALLBACKS* platform_get_audio(enum plat - #ifdef HAVE_ALSA - return &audio_callbacks_alsa; - #endif -+ #ifdef __FreeBSD__ -+ return &audio_callbacks_oss; -+ #endif - } - return NULL; - }