OpenBSD manual page server

Manual Page Search Parameters

MIXERCTL(8) System Manager's Manual MIXERCTL(8)

mixerctlmanipulate controls for audio hardware

mixerctl [-anv] [-f file]

mixerctl [-nv] [-f file] name ...

mixerctl [-qt] [-f file] name ...

mixerctl [-q] [-f file] name=value ...

The mixerctl command displays or sets various controls for audio hardware, such as microphone reference voltage or output level. Where hardware defaults are not the desired ones, controls can be set at system startup using the configuration file mixerctl.conf(5).

mixerctl itself can only be run by the superuser. Common controls should be adjusted at runtime using sndioctl(1), which is intended for every day use and requires no superuser privileges. Manual use of mixerctl is intended for controls which cannot be set using sndioctl(1).

If a list of control names is present on the command line, mixerctl prints the current value of those controls for the specified device.

The options are as follows:

Print all device controls and their current values. This is the default, if no parameters are given to mixerctl.
file
Specify an alternative audio control device. The default is /dev/audioctl0.
Suppress printing of the control name.
Suppress all printing when setting a control.
Toggle. Attempt to select the next possible value of an enum (see below).
Show all possible values of controls. Enum values are shown in ‘[]’ and values belonging to a set are shown in ‘{}’ (see below).
name=value
Attempt to set the control with given name to value.

The exact set of controls that can be manipulated depends on the device. The general format (in both getting and setting a value) is:

class.name=value

The class can have values like “inputs” or “outputs”, indicating that the control affects the input or output, respectively, to the device. The name indicates what part of the device the control affects. Continuous values, e.g. volume, have numeric values in the range 0-255. If value can be set for each channel independently, the values are printed separated by commas. Discrete values, e.g. the recording source, have symbolic names.

Variables may take one of three types, again dependent on the mixer:

  1. Enums. These may take only one out of a possible list of symbolic values or the literal string “toggle”, which toggles the value, e.g. inputs.mic.source=mic0.
  2. Sets. These can take one or more of a possible list of symbolic values; multiple values are specified as a comma-separated list, e.g. record.source=mic,cd. Additionally, value may be omitted to specify the empty set, e.g. record.source=.
  3. Numbers. Numerical values may be specified in either absolute or relative forms. The relative form is indicated by a prefix of ‘+’ or ‘-’ to denote an increase or decrease, respectively.

The audio control device to use.

/dev/audioctl0
Default audio control device.
/etc/mixerctl.conf
mixerctl configuration file.

Show possible values for all controls, and their current settings:

# mixerctl -av
inputs.mic=0,0 volume
inputs.mic.mute=off  [ off on ]
inputs.cd=220,220 volume
inputs.cd.mute=off  [ off on ]
inputs.dac=220,220 volume
inputs.dac.mute=off  [ off on ]
record.record=220,220 volume
record.record.source=mic  [ mic cd dac ]
monitor.monitor=0 volume

Toggle inputs.dac.mute:

# mixerctl -t inputs.dac.mute
inputs.dac.mute: off -> on
# mixerctl inputs.dac.mute=toggle
inputs.dac.mute: on -> off

aucat(1), cdio(1), audio(4), mixerctl.conf(5), audioctl(8), sysctl(8)

The mixerctl command first appeared in OpenBSD 2.4.

April 23, 2020 OpenBSD-7.3