qusal/salt/sys-audio/README.md

137 lines
4.5 KiB
Markdown
Raw Normal View History

2023-11-13 09:33:28 -05:00
# sys-audio
Audio operations in Qubes OS.
## Table of Contents
* [Description](#description)
* [Installation](#installation)
* [Usage](#usage)
2024-01-04 06:20:43 -05:00
* [Audio control](#audio-control)
* [Client started before it's AudioVM](#client-started-before-its-audiovm)
2024-01-04 06:20:43 -05:00
* [Client turned off with a device attached](#client-turned-off-with-a-device-attached)
2024-01-19 06:16:34 -05:00
* [How to use devices](#how-to-use-devices)
* [How to use Bluetooth](#how-to-use-bluetooth)
* [How to make the Bluetooth icon appear in the system tray](#how-to-make-the-bluetooth-icon-appear-in-the-system-tray)
* [How to attach the Bluetooth controller to the AudioVM persistenly](#how-to-attach-the-bluetooth-controller-to-the-audiovm-persistenly)
2023-11-13 09:33:28 -05:00
## Description
Creates the named disposable "disp-sys-audio" qube for providing audio
operations such as microphone and speakers to and from qubes. By default, you
can use the builtin stereo, JACK and USB , but if you want, you can install
the necessary packages for bluetooth with the provided state.
2023-11-13 09:33:28 -05:00
## Installation
- Top
```sh
qubesctl top.enable sys-audio
2024-01-02 17:01:58 -05:00
qubesctl --targets=tpl-sys-audio,dvm-sys-audio state.apply
2023-11-13 09:33:28 -05:00
qubesctl top.disable sys-audio
```
- State
<!-- pkg:begin:post-install -->
```sh
qubesctl state.apply sys-audio.create
qubesctl --skip-dom0 --targets=tpl-sys-audio state.apply sys-audio.install
2024-01-02 17:01:58 -05:00
qubesctl --skip-dom0 --targets=dvm-sys-audio state.apply sys-audio.configure-dvm
2023-11-13 09:33:28 -05:00
```
<!-- pkg:end:post-install -->
If you need Bluetooth support, install the dependencies:
2023-11-13 09:33:28 -05:00
```sh
qubesctl --skip-dom0 --targets=tpl-sys-audio state.apply sys-audio.install-bluetooth
```
## Usage
2024-01-04 06:20:43 -05:00
### Audio control
The qube `disp-sys-audio` will be used for audio capabilities for speakers and
2024-01-04 06:20:43 -05:00
microphone, with builtin modules, Jack port or Bluetooth. You are be able to
2023-11-13 09:33:28 -05:00
control the volume via the volume icon that appears on the system tray.
2024-01-04 06:20:43 -05:00
The basics are very simple to use:
- Left click toggles the volume; and
- Scrolling the mouse from left to right changes the volume;
For more advanced features, right click the icon and click on `Open Mixer` or
`Prefences`. For greater control, use the command `amixer`.
### Client started before it's AudioVM
2024-01-04 06:20:43 -05:00
Audio will not automatically connect if the AudioVM starts after the client.
To connect the client to audio server, restart the client's Pipewire service:
2024-01-04 06:20:43 -05:00
```sh
systemctl --user restart pipewire
```
### Client turned off with a device attached
If you shutdown a client qube with a device attached, such as a microphone or
speaker, normal operation to attach the device to the same or any other qube
will fail. To be able to use the device again:
- Restart the audio server `disp-sys-audio`;
2024-01-04 06:20:43 -05:00
- Restart the audio client; and
- Attach the device to the audio client;
2024-01-19 06:16:34 -05:00
### How to use devices
Bluetooth and Camera are normally integrated in laptops, but they still are
USB devices internally. They will be held by `(disp-)sys-usb` or
`(disp-)sys-net`, else `dom0`.
Built-in microphones on the other hand, are directly attached to `dom0`.
To use these devices, you have to attach them to their respective qubes:
- audio server: Bluetooth; and
- audio client: cameras, speakers, microphones.
2024-01-19 06:16:34 -05:00
### How to use Bluetooth
#### How to make the Bluetooth icon appear in the system tray
Note that the only way to autostart the Bluetooth icon (blueman-tray) in the
system tray is to attach the Bluetooth controller persistently to the AudioVM.
If you don't do this, you will have to attach the Bluetooth controller
manually to `disp-sys-audio` after it has started and also run `blueman-tray`.
#### How to attach the Bluetooth controller to the AudioVM persistenly
If using Bluetooth, you probably want to have it persistently attached to the
AudioVM. Bluetooth devices are held by the USB stack, thus you need to attach
from you `(disp-)sys-usb` to the `disp-sys-audio`.
2024-01-19 06:16:34 -05:00
Note that if you attach the device, the AudioVM will
[not be able to start](https://github.com/QubesOS/qubes-issues/issues/8877)
without first starting the backend holding the USB stack. You can move the
controller from the USB qube to the Audio qube, but this would decrease your
system security.
First, start the qube holding the USB stack:
```sh
qvm-start disp-sys-usb
```
Identify you Bluetooth controller:
```
qvm-usb list disp-sys-usb
```
If you haven't identified the device, run `lsusb` in the USB stack server:
```sh
qvm-run -p disp-sys-usb -- lsusb
```
Permanently attach the Bluetooth controller to the AudioVM (change `DEVID` for
the one you identified above):
```sh
qvm-usb attach --persistent disp-sys-audio disp-sys-usb:DEVID
```