108 lines
4.8 KiB
Diff
108 lines
4.8 KiB
Diff
|
From a50c28da704fbf8b9e71ec92054f325a33b9765f Mon Sep 17 00:00:00 2001
|
||
|
From: Fabian Vogt <fabian@ritter-vogt.de>
|
||
|
Date: Sat, 6 Jul 2024 16:27:28 +0200
|
||
|
Subject: [PATCH 1/2] Simpler yet more useful handling of
|
||
|
KPIPEWIRE_FORCE_ENCODER
|
||
|
|
||
|
Previously, it always overrode the encoder type and profile.
|
||
|
|
||
|
Now just force a specific encoder by inlining the encoder selection
|
||
|
in the switch cases.
|
||
|
|
||
|
This means it's no longer possible to force a different encoder type
|
||
|
than the application requested, but it's arguably not that useful to
|
||
|
e.g. force VP9 if the application expects H.264 packets.
|
||
|
|
||
|
(cherry picked from commit 0c3f8b4f9de7d4dcd24d952184dabdbda74b4c35)
|
||
|
---
|
||
|
src/pipewireproduce.cpp | 45 +++++++++--------------------------------
|
||
|
1 file changed, 9 insertions(+), 36 deletions(-)
|
||
|
|
||
|
diff --git a/src/pipewireproduce.cpp b/src/pipewireproduce.cpp
|
||
|
index 3452ce9..416bcd3 100644
|
||
|
--- a/src/pipewireproduce.cpp
|
||
|
+++ b/src/pipewireproduce.cpp
|
||
|
@@ -266,46 +266,19 @@ void PipeWireProduce::stateChanged(pw_stream_state state)
|
||
|
|
||
|
std::unique_ptr<Encoder> PipeWireProduce::makeEncoder()
|
||
|
{
|
||
|
- auto encoderType = m_encoderType;
|
||
|
- bool forceSoftware = false;
|
||
|
- bool forceHardware = false;
|
||
|
-
|
||
|
- if (qEnvironmentVariableIsSet("KPIPEWIRE_FORCE_ENCODER")) {
|
||
|
- auto forcedEncoder = qEnvironmentVariable("KPIPEWIRE_FORCE_ENCODER");
|
||
|
- if (forcedEncoder == u"libvpx") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing VP8 Software encoding";
|
||
|
- encoderType = PipeWireBaseEncodedStream::VP8;
|
||
|
- forceSoftware = true;
|
||
|
- } else if (forcedEncoder == u"libvpx-vp9") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing VP9 Software encoding";
|
||
|
- encoderType = PipeWireBaseEncodedStream::VP9;
|
||
|
- forceSoftware = true;
|
||
|
- } else if (forcedEncoder == u"libx264") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing H264 Software encoding, main profile";
|
||
|
- encoderType = PipeWireBaseEncodedStream::H264Main;
|
||
|
- forceSoftware = true;
|
||
|
- } else if (forcedEncoder == u"h264_vaapi") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing H264 Hardware encoding, main profile";
|
||
|
- encoderType = PipeWireBaseEncodedStream::H264Main;
|
||
|
- forceHardware = true;
|
||
|
- } else if (forcedEncoder == u"libx264_baseline") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing H264 Software encoding, baseline profile";
|
||
|
- encoderType = PipeWireBaseEncodedStream::H264Baseline;
|
||
|
- forceSoftware = true;
|
||
|
- } else if (forcedEncoder == u"h264_vaapi_baseline") {
|
||
|
- qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing H264 Hardware encoding, baseline profile";
|
||
|
- encoderType = PipeWireBaseEncodedStream::H264Baseline;
|
||
|
- forceHardware = true;
|
||
|
- }
|
||
|
+ auto forcedEncoder = qEnvironmentVariable("KPIPEWIRE_FORCE_ENCODER");
|
||
|
+ if (!forcedEncoder.isNull()) {
|
||
|
+ qCWarning(PIPEWIRERECORD_LOGGING) << "Forcing encoder to" << forcedEncoder;
|
||
|
}
|
||
|
|
||
|
auto size = m_stream->size();
|
||
|
|
||
|
- switch (encoderType) {
|
||
|
+ switch (m_encoderType) {
|
||
|
case PipeWireBaseEncodedStream::H264Baseline:
|
||
|
case PipeWireBaseEncodedStream::H264Main: {
|
||
|
auto profile = m_encoderType == PipeWireBaseEncodedStream::H264Baseline ? Encoder::H264Profile::Baseline : Encoder::H264Profile::Main;
|
||
|
- if (!forceSoftware) {
|
||
|
+
|
||
|
+ if (forcedEncoder.isNull() || forcedEncoder == u"h264_vaapi") {
|
||
|
auto hardwareEncoder = std::make_unique<H264VAAPIEncoder>(profile, this);
|
||
|
hardwareEncoder->setQuality(m_quality);
|
||
|
hardwareEncoder->setEncodingPreference(m_encodingPreference);
|
||
|
@@ -314,7 +287,7 @@ std::unique_ptr<Encoder> PipeWireProduce::makeEncoder()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
- if (!forceHardware) {
|
||
|
+ if (forcedEncoder.isNull() || forcedEncoder == u"libx264") {
|
||
|
auto softwareEncoder = std::make_unique<LibX264Encoder>(profile, this);
|
||
|
softwareEncoder->setQuality(m_quality);
|
||
|
softwareEncoder->setEncodingPreference(m_encodingPreference);
|
||
|
@@ -325,7 +298,7 @@ std::unique_ptr<Encoder> PipeWireProduce::makeEncoder()
|
||
|
break;
|
||
|
}
|
||
|
case PipeWireBaseEncodedStream::VP8: {
|
||
|
- if (!forceHardware) {
|
||
|
+ if (forcedEncoder.isNull() || forcedEncoder == u"libvpx") {
|
||
|
auto encoder = std::make_unique<LibVpxEncoder>(this);
|
||
|
encoder->setQuality(m_quality);
|
||
|
if (encoder->initialize(size)) {
|
||
|
@@ -335,7 +308,7 @@ std::unique_ptr<Encoder> PipeWireProduce::makeEncoder()
|
||
|
break;
|
||
|
}
|
||
|
case PipeWireBaseEncodedStream::VP9: {
|
||
|
- if (!forceHardware) {
|
||
|
+ if (forcedEncoder.isNull() || forcedEncoder == u"libvpx-vp9") {
|
||
|
auto encoder = std::make_unique<LibVpxVp9Encoder>(this);
|
||
|
encoder->setQuality(m_quality);
|
||
|
if (encoder->initialize(size)) {
|
||
|
--
|
||
|
2.45.2
|
||
|
|