sys_audio
module
This module also includes members of the audio
module for convenience.
Warning
These functions are not to be used in applications, but only by OS settings.
Many of these functions are available in three variants: headphone volume,
speaker volume, and volume. If headphones_are_connected()
returns 1
the “headphone” variant is chosen, else the “speaker” variant is chosen.
- sys_audio.headphones_detection_override(enable: bool, override_state: bool)
Set to ‘enable = True’ if the system should ignore jacksense and use override_state to determine whether headphones are connected (True) or not (False).
Use cases:
If a sleeve contact mic doesn’t pull the detection pin low enough the codec’s built in headphone detection might fail.
If the headset only has a mic connected but we wish to use the internal speaker anyway
Call with ‘enable = 0’ to revert to automatic detection.
- sys_audio.headphones_set_volume_dB(vol_dB: float) float
- sys_audio.speaker_set_volume_dB(vol_dB: float) float
- sys_audio.set_volume_dB(vol_dB: float) float
Attempts to set target volume for the headphone output/onboard speakers respectively, clamps/rounds if necessary and returns the actual volume. Absolute reference arbitrary. Does not unmute, use
audio_{headphones_/speaker_/}set_mute
as needed. Enters fake mute if requested volume is below the value set byaudio_{headphones/speaker}_set_minimum_volume_user
.Note: This function uses a hardware PGA for the coarse value and software for the fine value. These two methods are as of yet not synced so that there may be a transient volume “hiccup”. “p1” badges only use software volume.
- sys_audio.headphones_adjust_volume_dB(vol_dB: float) float
- sys_audio.speaker_adjust_volume_dB(vol_dB: float) float
- sys_audio.adjust_volume_dB(vol_dB: float) float
Like the
audio_{headphones_/speaker_/}set_volume
family but changes relative to last volume value.
- sys_audio.headphones_get_volume_dB() float
- sys_audio.speaker_get_volume_dB() float
- sys_audio.get_volume_dB() float
Returns volume as set with
audio_{headphones/speaker}_set_volume_dB
.
- sys_audio.headphones_get_mute() int
- sys_audio.speaker_get_mute() int
- sys_audio.get_mute() int
Returns 1 if channel is muted, 0 if channel is unmuted.
- sys_audio.headphones_set_mute(mute: int)
- sys_audio.speaker_set_mute(mute: int)
- sys_audio.set_mute(mute: int)
Mutes (mute = 1) or unmutes (mute = 0) the specified channel.
Note: Even if a channel is unmuted it might not play sound depending on the return value of audio_headphone_are_connected. There is no override for this (see HEADPHONE PORT POLICY below).
- sys_audio.headphones_set_minimum_volume_dB(vol_dB: float) float
- sys_audio.speaker_set_minimum_volume_dB(vol_dB: float) float
- sys_audio.headphones_set_maximum_volume_dB(vol_dB: float) float
- sys_audio.speaker_set_maximum_volume_dB(vol_dB: float) float
Set the minimum and maximum allowed volume levels for speakers and headphones respectively. Clamps with hardware limitations. Maximum clamps below the minimum value, minimum clamps above the maximum. Returns clamped value.
- sys_audio.headphones_get_minimum_volume_dB() float
- sys_audio.speaker_get_minimum_volume_dB() float
- sys_audio.headphones_get_maximum_volume_dB() float
- sys_audio.speaker_get_maximum_volume_dB() float
Returns the minimum and maximum allowed volume levels for speakers and headphones respectively. Change with
audio_{headphones/speaker}_set_{minimum/maximum}_volume_dB
.
- sys_audio.headphones_get_volume_relative() float
- sys_audio.speaker_get_volume_relative() float
- sys_audio.get_volume_relative() float
Syntactic sugar for drawing UI: Returns channel volume in a 0..1 range, scaled into a 0.01..1 range according to the values set with
audio_{headphones_/speaker_/}set_{maximum/minimum}_volume_
and 0 if in a fake mute condition.
- sys_audio.headset_mic_set_gain_dB(gain_dB: float)
- sys_audio.headset_mic_get_gain_dB() float
- sys_audio.onboard_mic_set_gain_dB(gain_dB: float)
- sys_audio.onboard_mic_get_gain_dB() float
- sys_audio.line_in_set_gain_dB(gain_dB: float)
- sys_audio.line_in_get_gain_dB() float
Set and get gain for the respective input channels.
- sys_audio.codec_i2c_write(reg: int, data: int)
Write audio codec register. Obviously very unsafe. Do not use in applications that you distribute to users. This can fry your speakers with DC
- sys_audio._codec_configure_dynamic_range_control(enable: bool, attack: int, release: int, make_up_gain_dB: int, comp_ratio: int, comp_threshold_dB: int, exp_ratio: int, exp_threshold_dB: int)
Configures dynamic range control (compressor/expander) in the max98091 codec.
Temporary API for compressor experimentation, to be replaced later.
See page 134 of the datasheet for values:
https://www.analog.com/media/en/technical-documentation/data-sheets/MAX98091.pdf
exp_threshold_dB
is expressed in dB from 35 to 66, not in raw values from 0 to 31.Example:
audio._codec_configure_dynamic_range_control(True, 2, 3, 0, 4, 10, 0, 0)
Will result in enabling the compressor with attack 2 (1.25ms), release 3 (1s), no make up gain, compression ratio 4 (INF:1), compression threshold 10dB, and expander disabled (ratio 1:1)
Headphone port policy
Under normal circumstances it is an important feature to have a reliable speaker mute when plugging in headphones. However, since the headphone port on the badge can also be used for badge link, there are legimate cases where it is desirable to have the speakers unmuted while a cable is plugged into the jack.
As a person who plugs in the headphones on the tram, doesn’t put them on, turns on music to check if it’s not accidentially playing on speakers and then finally puts on headphones (temporarily, of course, intermittent checks if the speakers didn’t magically turn on are scheduled according to our general anxiety level) we wish to make it difficult to accidentially have sound coming from the speakers.
Our proposed logic is as follows (excluding boot conditions):
Badge link TX cannot be enabled for any of the headphone jack pins without a cable detected in the jack. This is to protect users from plugging in headphones while badge link is active and receiving a short but potentially very loud burst of digital data before the software can react to the state change.
If the software detects that the headphone jack has changed from unplugged to plugged it always turns off speakers, no exceptions.
If a user wishes to TX on headphone badge link, they must confirm a warning that having headphones plugged in may potentially cause hearing damage every time.
If a user wishes to RX or TX on headphone badge link while playing sound on the onboard speakers, they must confirm a warning every time.
We understand that these means seem extreme, but we find them to be a sensible default configuration to make sure people can safely operate the device without needing to refer to a manual.
(TX here means any state that is not constantly ~GND with whatever impedance. While there are current limiting resistors (value TBD at the time of writing, but presumably 100R-470R) in series with the GPIOs, they still can generate quite some volume with standard 40Ohm-ish headphones. Ideally the analog switch will never switch to the GPIOs without a cable plugged in.)