Commit graph

15625 commits

Author SHA1 Message Date
Torkel Niklasson
0a413c866c gst: deviceprovider: tear down node proxies before releasing core
Destroy the bound node proxies in probe() and stop() while the loop is
locked, before releasing the core. This removes the node listeners so no
node_event_info can fire after the core is gone, fixing the root cause of
the resync() NULL-deref crash and a node-proxy leak.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-06-30 14:21:08 +00:00
Elliot Chen
7ee2416bdd pipewiresrc: fix caps negotiation failure in some cases when changing state from playing to paused
basesrc will do caps negotiation if pad is reconfigured. Should check and
wait if caps negotiation is currently in progress before corking the stream.

Return true when flushing to avoid caps negotiation failure.
2026-06-30 14:20:10 +00:00
Wim Taymans
3c14693bed client-node: clear mix when clearing the node
Even if we don't have a transport we should clear the mix info if there
is any available.

Fixes #5348
2026-06-30 16:17:12 +02:00
Wim Taymans
187b9154a6 filter-chain: pass context to filter-graph
Pass the IO_Position and IO_Latency to the filter graph in the
context.
2026-06-30 12:52:32 +02:00
Wim Taymans
e42657f030 io: flesh out the node IO_Latency
Make this more useful by adding the capture and playback latency.

This structure can be used to say how much latency there is between the
capture and playback hardware.
2026-06-30 12:35:00 +02:00
Wim Taymans
5e521d3532 filter-graph: pass context to plugins
Make it possible to pass context to plugins and nodes in the
filter-chain.

We can use this to make filters aware of the graph clock or
latency, for example.
2026-06-30 12:24:54 +02:00
Wim Taymans
aa075c2a12 filter-graph: add support for multiple handles
Make instantiate create all the related handles in one go.

When a processing node has 1 in/out, multiple handles are created to
support multichannel. By instantiating the handles in one go, the
implementation could do some special multichannel support or do some
optimizations, like parse the config string only once.
2026-06-30 11:58:33 +02:00
Wim Taymans
b3eb2eabb8 filter-graph: return result from instatiate
Instead of returning a handle (and errno on NULL), return a result code
and store the handle in a return variable.

This makes it easier to handle the errors but also makes it possible to
return multiple handles later.
2026-06-30 11:20:15 +02:00
Wim Taymans
978e8c1a4b audioconvert: small cleanups
Move the sync code to before it is used.

We don't need to clear the graph setup state anymore in force mode, we
did that before we did the sync.
2026-06-29 10:36:26 +02:00
Torkel Niklasson
f174b4e688 audioconvert: sync filter-graphs out of data loop before forced rebuild
A forced setup_filter_graphs() deactivates and re-instantiates every graph,
which frees and recreates the underlying plugin handles (node_cleanup sets
node->hndl[i] = NULL before re-instantiating). This was done on a graph that
was still referenced by the RT data-loop snapshot (filter_graph[]), so the
RT thread could run a graph whose handles were NULL mid-rebuild, leading to a
NULL handle dereference in the filter-graph process path.

Mirror the safe ordering already used by load_filter_graph()/clean_filter_handles():
before reconfiguring, mark the graphs not-setup and sync_filter_graph() so the
data loop drops them from filter_graph[] under the loop lock. They are
republished by the sync that follows setup. The cheap snapshot swap is done
under the lock; the heavy re-instantiation stays off the RT path.

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
2026-06-29 08:17:07 +00:00
Wim Taymans
10b339bbf8 docs: fix SVG text rendering to always use black
The drawio-exported SVGs used light-dark() CSS to switch text between
black and white based on color scheme. This caused white-on-light text
when viewing in dark mode. Replace all light-dark() values with their
light-mode equivalents so text and strokes are always black.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-06-26 12:52:47 +02:00
Wim Taymans
a988df47a2 docs: escape angle brackets in conf.c and fix page_core_api references
- conf.c: escape <key>, <value>, <action> placeholders in doc comment
- context.h, permission.h: fix \ref page_core_api to \ref api_pw_core

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-06-26 12:46:00 +02:00
Wim Taymans
9710f02837 docs: escape angle brackets and fix @filename and \ref in doc comments
Escape <portname>, <tensorname>, <paramname>, <port>, <rules> and
similar angle-bracket placeholders that doxygen interprets as HTML
tags. Also escape @filename (unknown doxygen command) and fix the
pw_stream::process() reference in thread-loop.h.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-06-26 12:43:56 +02:00
Wim Taymans
f055949cb5 docs: fix broken doxygen references and escape HTML tags
- modules.dox: remove references to non-existent sendspin modules
- access.dox: remove reference to deprecated pipewire-media-session
- dma-buf.dox: fix \ref EnumFormat to \ref SPA_PARAM_EnumFormat,
  fix \ref struct to struct \ref for spa_meta_sync_timeline
- pipewire.conf.5.md: add explicit {#synopsis} anchor for internal links
- pipewire-client.conf.5.md: fix audio_converter to audio_adapter ref
- pipewire-jack.conf.5.md: escape <id> HTML tags
- pipewire-props.7.md: fix monitor-prop__ to props__ for card profiles ref
- pipewire-pulse.1.md: fix pipewire-env ref to full anchor name
- pipewire.1.md: fix \ref CPU to \ref spa_cpu

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-06-26 12:42:01 +02:00
Wim Taymans
c4b767cba1 docs: rename pulse module files to fix doxygen \file name collisions
Prefix all pulse module source files with pulse- to give them unique
basenames, avoiding ambiguous \file suffix matching in doxygen when
identically-named files exist under src/modules/.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-06-26 12:37:39 +02:00
Simon A. Eugster
2a88fb6ae8 docs: Remove specific user overview page again 2026-06-26 10:00:15 +00:00
Simon A. Eugster
1201b2ed32 docs: Extend description of object types 2026-06-26 10:00:15 +00:00
Simon A. Eugster
24770baaa0 docs: Add Tools and Configuration sections 2026-06-26 10:00:15 +00:00
Simon A. Eugster
8e5617c439 docs: Add routing examples 2026-06-26 10:00:15 +00:00
Simon A. Eugster
8a659f1aaa docs: Explain PipeWire role, add graphics 2026-06-26 10:00:15 +00:00
Simon A. Eugster
6a6feb45fe docs: Add user overview docs for PipeWire 2026-06-26 10:00:15 +00:00
Elliot Chen
9b2ff82aea pipewiresrc: unlock loop when failing to wait negotiated 2026-06-26 09:57:23 +00:00
Val Lorentz
acbcf5cece doc: Fix paths to config files 2026-06-26 09:52:08 +00:00
Wim Taymans
07955ff312 Doc: fix some formatting and syntax issues
In pipewire-props.7.md changed ALSA-specific audio.* entries from @PAR@ node-prop
to plain \par to eliminate duplicate section label anchors.
2026-06-26 11:15:38 +02:00
Wim Taymans
f1658434be docs: fix some signedness compilation warnings 2026-06-26 10:27:34 +02:00
Pauli Virtanen
393da55797 bluez5: backend-native: fix multiple profile registration
Handling pending RegisterProfile callbacks was wrong as it forgot that
there can be multiple profiles to be registered.

Fix the handling by allowing several concurrent register callbacks.
2026-06-25 18:21:46 +03:00
Pauli Virtanen
422765c91d test: bluezenv: check multiple backend-native profiles can be registered 2026-06-25 18:21:46 +03:00
Wim Taymans
7dc35030dc filter-graph: add normalize option for sofa
Add an option to enable the use of the sofa loudness function to
normalize the IR.

See #5322
2026-06-25 16:24:38 +02:00
Barnabás Pőcze
a5ade5f96e spa: {libcamera,v4l2}: device: remove params
No params are implemented, so remove them from the emitted `spa_device_info`.
For v4l2, `n_params` was already set to 0 in 938e2b1451
("v4l2: profiles params are not implement yet"), effectively removing them.

No implementation has materialized in the last 5 years, so remove them
altogether, and do the same in the libcamera plugin as well.
2026-06-25 12:05:04 +02:00
Wim Taymans
2a4222a538 jack: fix race in get_buffer_output()
When a single output port is linked to multiple input ports of the same
client and the client uses multiple threads to process the input ports,
get_buffer_output() is called from multiple threads concurrently and
causes a race.

Multiple threads will try to dequeue a buffer concurrently and set the
HAVE_DATA io status, which causes the port to run out of buffers quickly
and the io are to become corrupted.

Use CAS to make sure only one thread dequeues and sets the io status.
The other concurrent threads will spin until there is a buffer. The fast
path will be that the buffer is already dequeued and then it is simply
reused.

Fixes #5324
2026-06-25 11:21:01 +02:00
Wim Taymans
d97a9bf44b pulse-server: actually print properties of module
When inspecting the loaded modules, actually list the properties that
were used when loading the module instead of the informational generic
ones from the info.

Pulsaudio also does not list the Usage properties when listing modules.
2026-06-25 09:21:27 +02:00
Wim Taymans
9bcbd7b586 pulse: generate Usage from module_args definition
Add some more fields like the type, default value and possible enum
values for the module_args.

Use this to generate the Usage in describe-module and the docs.

This should give more consistent and correct Usage output in all
modules.
2026-06-24 18:59:19 +02:00
AMG
9f7eb63486 refactor: pr 2026-06-24 16:32:43 +00:00
AMG
b4b4e03816 pw-container: Add socket path parameter 2026-06-24 16:32:43 +00:00
Julian Bouzas
62e98466fa conf: fix matching of property values with colons
Use spa_json_begin_array() instead of the relaxed variant when parsing
property values in pw_conf_find_match().

This prevents plain string values containing ':' (such as object.path)
from being incorrectly tokenized while preserving support for actual
JSON array properties.
2026-06-24 10:52:49 -04:00
Wim Taymans
7dac6a71d5 conf: avoid using close_range when undefined
Only call close_range when CLOSE_RANGE_UNSHARE is defined.

Fixes compilation on alpine.
2026-06-23 18:36:52 +02:00
Barnabás Pőcze
559a30b0b4 spa: libcamera: source: reject buffers with incorrect number of planes
`SPA_PARAM_BUFFERS_blocks` is a specific value, the plugin host should
not use any other number of data planes, so reject other values.

For example, the `buffers[i]->n_datas > planes.size()` situation was
not handled correctly, and this removes the need for handling that.
2026-06-23 15:00:15 +00:00
Barnabás Pőcze
44176d4118 spa: libcamera: expose libcamera version
Expose the libcamera header and library versions in the device properties
similarly to `api.v4l2.cap.version` used by the v4l2 plugin.

The keys are not yet promoted into the public `keys.h` header file.
2026-06-23 15:00:15 +00:00
Barnabás Pőcze
6dc55d2cb4 spa: libcamera: move CameraManager acquisition
Now that there is a "libcamera.cpp", move `libcamera_manager_acquire()` into
that file since it is a common function used by all three factories.
2026-06-23 15:00:15 +00:00
Barnabás Pőcze
390a4ce432 spa: libcamera: compile fully as C++
There was one file "libcamera.c" that was a C source file, which
prevents the addition of C++ functions, includes, etc. to "libcamera.h".
So compile that file as C++ as well.
2026-06-23 15:00:15 +00:00
Barnabás Pőcze
d46361a1b9 spa: libcamera: remove some unnecessary includes
Also add the missing include guard.
2026-06-23 15:00:15 +00:00
Barnabás Pőcze
dbc97942f4 spa: libcamera: manager: simplify property emission
There are no conditional properties, so everything can be in the array
initializer, which always deduces the size correctly, so do that.
2026-06-23 15:00:15 +00:00
Julian Bouzas
187187e41f pipewire-pulse: Expose profile preference setting as a message
Makes it easier for libpulse-based clients to modify this setting if they want.
2026-06-23 08:58:12 -04:00
Carlos Rafael Giani
d8f5ed0c13 module-rtp-sink: Add ability to add / remove receivers through commands
This makes it possible to dynamically add / remove receivers, which is
necesary for sending to multiple receivers. Mixed multi- and unicast
receivers are possible. Example pw-cli calls (56 is the ID of the RTP
sink node):

pw-cli c 56 User '{ extra="{ \"command.id\" : \"add-receiver\" , \"destination.ip\" : \"10.42.0.1\", \"destination.port\" : 55001 }" }'
pw-cli c 56 User '{ extra="{ \"command.id\" : \"remove-receiver\", \"destination.ip\" : \"10.42.0.1\" }" }'
pw-cli c 56 User '{ extra="{ \"command.id\" : \"clear-receivers\" }" }'

Commands and their arguments:

* "add-receiver" : Adds a receiver to the sink's list. If the given
  IP address <-> port combination was already added, the command is
  logged, but otherwise ignored. Arguments:
  - "destination.ip" : IP address to send data to. Can be a uni- or
    multicast address, but must be a valid address.
  - "destination.port" : Port to send data to. Must be valid.
  - "local.ifname", "source.ip", "net.ttl", "net.dscp", "net.loop" :
    These are all optional, and work just like in the RTP sink
    module's properties.

* "remove-receiver" : Removes a receiver from the sink's list. The
  receiver is identified by the given IP address. A port can optionally
  be specified as well. If it isn't, then the first receiver with that IP
  address is removed. If no matching receiver is in the sink's list,
  this command does nothing. Arguments:
  - "destination.ip" : IP address to send data to. Can be a uni- or
    multicast address, but must be a valid address.
  - "destination.port" : Port to send data to. This is optional. But, if
    it is set, it must be a valid port number.

* "clear-receivers" : Removes all receivers from the sink's list. If the
  list is empty, this does nothing. This command has no arguments.

If the RTP sink module is created with the "destination.ip" and
"destination.port" properties set, it behaves as if "add-receiver" were
called right after the module was initialized. This means that if none
of these commands are used, the module behaves just as it did prior to
this patch. Note that the "remove-receivers" command can remove this
initial receiver as well.

If no receivers are added, the module continues to work normally.
Adding and removing receivers mid-operation is supported.

NOTE: "destination.ip") handling in stream_props_changed() is removed,
since it never really did anything other than change the param value.
2026-06-23 10:47:36 +00:00
Wim Taymans
f2ccfe12c2 pw-cli: return errno-style error codes from command handlers
So that callers have more information to report useful error
messages.
2026-06-23 11:25:27 +02:00
Wim Taymans
9c5ea39f4e tools: return error when there was an error
Fixes #4286
2026-06-23 11:13:50 +02:00
Wim Taymans
656add0ae8 test: update copyright
Claude gladly transfered copyright to me.
2026-06-23 09:33:23 +02:00
Wim Taymans
208348ff2a conf: use close_range() before execvp()
Avoids leaking fds to the new program.
2026-06-22 14:35:11 +02:00
Wim Taymans
7fafc5f969 filter-graph: small cleanups
Use some constants and rename some variables.
2026-06-22 13:38:02 +02:00
Wim Taymans
a389a553e3 filter-graph: use pffft aligned alloc in all cases
Always use the pffft aligned alloc function. The fftw alloc function
only aligns to 16 bytes and the AVX code uses stores that rely on an
alignment of 32 bytes. The pffft alloc alignes to 64 bytes.

Fixes #5320
2026-06-22 13:05:32 +02:00