OpenBSD/src kJacdamsys/dev/usb uaudio.c

by ratchov on ⎇
   uaudio: Drop UAUDIO_DEBUG defined by mistake in the last commit

   Fixes excessive noise on the console. From weerd@, thanks!
VersionDeltaFile
1.178+1-3sys/dev/usb/uaudio.c
+1-31 files

OpenBSD/src QbqKxKQsys/dev/usb uaudio.c

by ratchov on ⎇
   uaudio: Fix devices that don't support sample rate changes

   Parse the class-specific endpoint descriptor to determine if the
   device supports sample rate changes (i.e. the frequency control
   attribute is set). Then, send the frequency change request only
   to devices that support it.

   For instance this fixes the Dell Slim soundbar that would freeze
   upon a frequency change request.

   With help from Joel Carnat <joel at carnat.net>, thanks!
VersionDeltaFile
1.177+77-28sys/dev/usb/uaudio.c
+77-281 files

OpenBSD/src HEr14Scsys/dev/ic qwzreg.h qwxreg.h, sys/dev/pci if_skreg.h if_bnxtreg.h

   spelling; checked by jmc@, ok miod@ mglocker@ krw@
VersionDeltaFile
1.5+10-10sys/dev/ic/qwzreg.h
1.8+9-9sys/dev/ic/qwxreg.h
1.67+6-6sys/dev/ic/qwx.c
1.8+6-6sys/dev/ic/qwz.c
1.65+5-5sys/dev/pci/if_skreg.h
1.6+4-4sys/dev/pci/if_bnxtreg.h
+40-4048 files not shown
+144-14454 files

OpenBSD/src CqEp6Dasys/dev/usb uaudio.c

   uaudio: Fix confusion between interface numbers and interface indexes

   There is rare hardware for which the interface numbers and indexes are
   not equal. Such devices couldn't attach because the driver claimed the
   wrong interface.
VersionDeltaFile
1.175+34-6sys/dev/usb/uaudio.c
+34-61 files

OpenBSD/src 70UasQFsys/dev/usb uaudio.c

   Skip interfaces already claimed by other uaudio(4) instances.

   Fixes support of devices that attach multiple uaudio(4) drivers.

   Every uaudio(4) instance parses the full set of device descriptors
   because there are multiple interfaces per driver instance. If there is
   a second uaudio(4) instance (i.e. a second control & stream interfaces
   combo), the latter must skip the interfaces already used by the first
   one (if it didn't, multiple uaudio(4) would try to use the same
   interface and neither would work).

   Help from and ok armani@.
VersionDeltaFile
1.174+19-4sys/dev/usb/uaudio.c
+19-41 files

OpenBSD/src ZtFP84ysys/dev/usb uaudio.c

   Return error if the USB request to get the sample rate fails.

   found by mlarkin
VersionDeltaFile
1.173+2-2sys/dev/usb/uaudio.c
+2-21 files

OpenBSD/src Do38b8Wsys/dev audio.c, sys/dev/ic am7930.c

   Make audio(9) get_props() optional, remove it from duplex drivers

   The property bits of audio(9) are obsolete and ought to be removed
   completely.

   sys/dev/audio.c:audio_open() currently uses get_props() to bail out if
   read *and* write was requested on a non-duplex driver.

   Drivers that currently support playing but not recording need adjustment
   before the API can be cleaned up.

   Drivers that advertise themselves as full duplex, i.e. those that always
   return AUDIO_PROP_FULLDUPLEX unconditionally in their get_props() currently
   always succeed this check.

   As this is the only property, losen audio_open()'s DIAGNOSTIC check and only
   do the duplex check if the driver provides get_props().

   This allows for simple removal of get_props() from full-duplex drivers

    [15 lines not shown]
VersionDeltaFile
1.202+9-9sys/dev/audio.c
1.8+5-11sys/dev/ic/am7930.c
1.40+1-10sys/dev/pci/neo.c
1.53+1-10sys/dev/pci/eso.c
1.61+1-10sys/dev/pci/emuxki.c
1.64+1-10sys/dev/pci/eap.c
+18-6029 files not shown
+47-27235 files

OpenBSD/src 0kfBoWssys/dev/isa gus.c ess.c, sys/dev/pci eap.c azalia.c

   Use C99 struct init for struct audio_hw_if

   This audio(9) struct will lose a member, but drivers init their struct quite
   inconsistently, most pre-C99 style.

   Use C99 style everywhere, to get rid of all annoying differences and allow
   for easy member removals/additions:
   - don't change current order of members
   - no explicit NULL members
   - no comments or blank lines
   - trailing comma in last member line

   GENERIC.MP builds fine with this on arm64, amd64, i386 and sparc64.

   macppc and alpha build-tested by miod
   OK ratchov miod
VersionDeltaFile
1.53+35-58sys/dev/isa/gus.c
1.31+33-45sys/dev/isa/ess.c
1.63+29-45sys/dev/pci/eap.c
1.278+17-27sys/dev/pci/azalia.c
1.39+16-27sys/dev/pci/neo.c
1.171+15-26sys/dev/usb/uaudio.c
+145-22831 files not shown
+617-92437 files

OpenBSD/src KRwGR61sys/dev/pci maestro.c, sys/dev/usb uaudio.c

   Constify global tables only used in lookups, OK ratchov
VersionDeltaFile
1.48+2-2sys/dev/pci/maestro.c
1.170+2-2sys/dev/usb/uaudio.c
+4-42 files

OpenBSD/src a3LjziDsys/dev audio.c, sys/dev/fdt simpleaudio.c graphaudio.c

   Constify struct {audio,midi,radio,video}_hw_if. No functional change.

   ok mpi@ ratchov@ "More const is good" deraadt@
VersionDeltaFile
1.4+17-17sys/dev/fdt/simpleaudio.c
1.3+17-17sys/dev/fdt/graphaudio.c
1.50+9-6sys/dev/isa/gus.c
1.32+5-5sys/dev/isa/sb.c
1.61+5-5sys/dev/pci/eap.c
1.198+5-4sys/dev/audio.c
+58-5458 files not shown
+188-18064 files

OpenBSD/src CgBQFTOsys/dev/usb uaudio.c

   ambigus -> ambiguous
VersionDeltaFile
1.168+3-3sys/dev/usb/uaudio.c
+3-31 files

OpenBSD/src 1Q4U9lwsys/dev audio.c, sys/dev/usb ucc.c usb_subr.c

   Currently, wskbd_set_mixervolume() only adjusts the volume of the first
   attached audio device, i.e. audio0. This approach does not work well
   while using additional audio devices equipped with physical volume keys
   since those would only affect the volume of audio0.

   Instead, correlate audio and ucc devices attached over USB in order to
   adjust the volume of the correct audio device. This is done by passing a
   cookie from the common point of attachment which is later used to
   correlate the audio and wskbd device.

   The same approach could be adopted for audio and wskbd devices attaching
   on a different bus. Keep in mind that it's of importance to make use of
   and increment the same global cookie identifier to avoid collisions.

   Makes the volume keys on my Logitech G435 Headset do the right thing.

   ok ratchov@
VersionDeltaFile
1.196+39-6sys/dev/audio.c
1.111+13-5sys/dev/wscons/wskbd.c
1.30+5-4sys/dev/usb/ucc.c
1.158+7-1sys/dev/usb/usb_subr.c
1.167+2-2sys/dev/usb/uaudio.c
1.4+3-1sys/dev/wscons/wskbdvar.h
+69-191 files not shown
+71-207 files

OpenBSD/src bppxIrMsys/arch/macppc/dev snapper.c tumbler.c, sys/arch/sparc64/dev ce4231.c

   Make room for a cookie argument passed to audio_attach_mi(). Currently
   unused but intended to be used to correlate audio and wskbd devices.

   ok ratchov@
VersionDeltaFile
1.195+5-2sys/dev/audio.c
1.27+3-3sys/dev/isa/ess.c
1.37+3-2sys/dev/audio_if.h
1.40+2-2sys/arch/macppc/dev/snapper.c
1.10+2-2sys/arch/macppc/dev/tumbler.c
1.38+2-2sys/arch/sparc64/dev/ce4231.c
+17-1336 files not shown
+89-8542 files

OpenBSD/src cu8mJvlsys/dev/pci if_bnxtreg.h if_iwxreg.h, sys/dev/usb uaudio.c

   When it's the possessive of 'it', it's spelled "its", without the
   apostrophe.
VersionDeltaFile
1.5+7-7sys/dev/pci/if_bnxtreg.h
1.165+3-3sys/dev/usb/uaudio.c
1.34+2-2sys/net/ifq.h
1.201+2-2sys/kern/kern_exit.c
1.244+2-2sys/net80211/ieee80211_input.c
1.35+2-2sys/dev/pci/if_iwxreg.h
+18-181 files not shown
+20-207 files

OpenBSD/src XPo07VQsys/dev/ic aic79xx.c, sys/dev/pci if_bnxtreg.h if_iwxreg.h

   spelling
   feedback and ok tb@ jmc@ ok ratchov@
VersionDeltaFile
1.4+40-40sys/dev/pci/if_bnxtreg.h
1.34+29-29sys/dev/pci/if_iwxreg.h
1.67+27-27sys/dev/pci/if_iwmreg.h
1.67+23-23sys/dev/ic/aic79xx.c
1.113+20-20sys/dev/pci/if_em_hw.c
1.97+20-20sys/dev/pcmcia/if_malo.c
+159-159309 files not shown
+1,018-1,018315 files

OpenBSD/src VwlKsk3sys/dev/usb uaudio.c

   spelling
   ok ratchov@
VersionDeltaFile
1.163+15-15sys/dev/usb/uaudio.c
+15-151 files

OpenBSD/src y738tD2sys/dev/usb uaudio.c udl.c

   Align memory allocation for USB device drivers and USB HC drivers:

   * USB device drivers use M_USBDEV instead of M_DEVBUF.
   * USB HC drivers use M_USBHC instead of M_DEVBUF.

   In a vanilla setup, this enlarges the USB memory pool.

   ok anton@
VersionDeltaFile
1.162+24-24sys/dev/usb/uaudio.c
1.96+8-8sys/dev/usb/udl.c
1.214+5-5sys/dev/usb/uvideo.c
1.12+5-5sys/dev/usb/utvfu.c
1.75+5-5sys/dev/usb/if_wi_usb.c
1.62+3-3sys/dev/usb/umass_scsi.c
+50-508 files not shown
+66-6614 files

OpenBSD/src BgJhrw2sys/dev/usb uaudio.c

   Add pre-DMA-write barrier after data is stored to memory

   There's already such a barrier in usbd_transfer() code-path, but this
   one is called when the frames are queued to the HC ring. The audio
   samples are stored in memory by userland later, *after* the frames are
   scheduled (but before they are sent on the wire) so a barrier is
   needed there. Without this change, the data produced by userland may
   stay in the CPU caches and is not "seen" by the HC's DMA engine, in
   turn the device plays noise on certain arm64 machines (RPI4, for
   instance).

   Fix mostly from Luca Castagnini with few tweaks from me. OK patrick@
VersionDeltaFile
1.161+4-1sys/dev/usb/uaudio.c
+4-11 files

OpenBSD/src GXzwlkcsys/dev/usb uaudio.c

   When detaching uaudio, wait for device ref counter to drop to 0

   To maintain the correct refs count, blocking calls to uaudio are
   wrapped in usbd_ref_incr() and usbd_ref_decr() calls.

   suggested by mpi@ and ok visa@
VersionDeltaFile
1.160+46-7sys/dev/usb/uaudio.c
+46-71 files

OpenBSD/src C1qi7QBsys/dev/usb uaudio.c

   Remove redundant code testing if a terminal is a usb stream.

   Fixes coverity CID 1492830.

   ok sthen, deraadt
VersionDeltaFile
1.159+1-5sys/dev/usb/uaudio.c
+1-51 files

OpenBSD/src 85LVohJsys/dev/usb uaudio.c

   If there's only one input (output) name it simply "input" ("output")

   Besides making things simpler, this allows libsndio to figure out that
   this is a control affecting all inputs (outputs) that needs to be
   exposed.
VersionDeltaFile
1.158+27-4sys/dev/usb/uaudio.c
+27-41 files

OpenBSD/src lLcJuSrsys/dev/usb uaudio.c

   Use "inputs" class instead of "record"

   There's no reliable way to decide whether a control must belong
   to "inputs" or to "record". In other words both classes were
   used for the same thing. Furthermore we've no "play" class which
   tends to make things more confusing.
VersionDeltaFile
1.157+5-11sys/dev/usb/uaudio.c
+5-111 files

OpenBSD/src 3tV2CLUsys/dev/usb uaudio.c

   Use "dac" instead of "play" in mixer control names

   All other drivers use "dac" and libsndio needs the control name to
   be "dac" for the control to be exposed.
VersionDeltaFile
1.156+2-2sys/dev/usb/uaudio.c
+2-21 files

OpenBSD/src n6w49fgsys/dev/usb uaudio.c

   Set terminal and clock names after all units are parsed

   Makes the code simpler and more flexible as the naming is done in a
   single place where the full units list is available.
VersionDeltaFile
1.155+25-13sys/dev/usb/uaudio.c
+25-131 files

OpenBSD/src 1EYxXUVsys/dev/usb uaudio.c

   Use macros instead of hardcoded "play" and "record" string constants

   No object change.
VersionDeltaFile
1.154+10-4sys/dev/usb/uaudio.c
+10-41 files

OpenBSD/src N2v8ws9sys/dev/usb uaudio.c

   Skip "all-channels" controls if there are equivalend per-channel ones

   Hardware may expose per-channel controls and equivalent ones affecting
   all channels, which is redundant. In this case expose only the
   per-channel ones as they are more flexible.
VersionDeltaFile
1.153+28-2sys/dev/usb/uaudio.c
+28-21 files

OpenBSD/src Jse8sIRsys/dev/usb uaudio.c

   Suffix per-channel non-numeric controls with channel number

   The audio(9) mixer API can't represent such per-channel controls with
   a single entry, so we've to expose one mixer entry (with an unique
   name) per control.

   Fixes name clashes on usb audio devices with per-channel mute
   controls.
VersionDeltaFile
1.152+8-3sys/dev/usb/uaudio.c
+8-31 files

OpenBSD/src 8R5DtRlsys/dev/usb uaudio.c

   If samples per frame is larger than the device usb packet size,
   fail early in uaudio(4).  This prevents negative safe_blksz and
   integer overflow in nframes_max in case of a bad call to
   uaudio_stream_open() or a hardware bug.
   OK ratchov@
VersionDeltaFile
1.151+5-1sys/dev/usb/uaudio.c
+5-11 files

OpenBSD/src EESdL3Osys/dev/usb uaudio.c

   If an USB audio device supports less rates for recording than for
   playing, the uaudio(4) driver selected a wrong rate.  Then recording
   failed with "block size too large".  The v1_rates field of the
   parameters contains the correct intersection of valid rates.  Use
   it for v1 devices.
   OK ratchov@
VersionDeltaFile
1.150+8-2sys/dev/usb/uaudio.c
+8-21 files

OpenBSD/src zAHEDxtsys/dev/usb uaudio.c

   Fix use of uninitilized variable in case of emty AC descriptor.

   USB audio devices with empty AC descriptor (i.e. emtpy devices) don't
   exist as they would be of no use. So this fix is mostly to properly
   skip broken hardware.

   Found by coverity.
VersionDeltaFile
1.149+2-2sys/dev/usb/uaudio.c
+2-21 files