MFC r272254:
Instead of creating the full range of possible ports, try to figure out the actual number of so-called "embedded jacks" which are present when a USB MIDI device is attaching. Approved by: re, gjb
This commit is contained in:
parent
a6d8870502
commit
f0d6c23c18
@ -238,7 +238,7 @@ struct uaudio_chan {
|
||||
#define UAUDIO_SYNC_LESS 2
|
||||
};
|
||||
|
||||
#define UMIDI_CABLES_MAX 16 /* units */
|
||||
#define UMIDI_EMB_JACK_MAX 16 /* units */
|
||||
#define UMIDI_TX_FRAMES 256 /* units */
|
||||
#define UMIDI_TX_BUFFER (UMIDI_TX_FRAMES * 4) /* bytes */
|
||||
|
||||
@ -269,7 +269,7 @@ struct umidi_sub_chan {
|
||||
|
||||
struct umidi_chan {
|
||||
|
||||
struct umidi_sub_chan sub[UMIDI_CABLES_MAX];
|
||||
struct umidi_sub_chan sub[UMIDI_EMB_JACK_MAX];
|
||||
struct mtx mtx;
|
||||
|
||||
struct usb_xfer *xfer[UMIDI_N_TRANSFER];
|
||||
@ -281,7 +281,7 @@ struct umidi_chan {
|
||||
uint8_t write_open_refcount;
|
||||
|
||||
uint8_t curr_cable;
|
||||
uint8_t max_cable;
|
||||
uint8_t max_emb_jack;
|
||||
uint8_t valid;
|
||||
uint8_t single_command;
|
||||
};
|
||||
@ -1487,6 +1487,7 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
union uaudio_asid asid = { NULL };
|
||||
union uaudio_asf1d asf1d = { NULL };
|
||||
union uaudio_sed sed = { NULL };
|
||||
struct usb_midi_streaming_endpoint_descriptor *msid = NULL;
|
||||
usb_endpoint_descriptor_audio_t *ed1 = NULL;
|
||||
const struct usb_audio_control_descriptor *acdp = NULL;
|
||||
struct usb_config_descriptor *cd = usbd_get_config_descriptor(udev);
|
||||
@ -1504,6 +1505,7 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
uint8_t bChannels;
|
||||
uint8_t bBitResolution;
|
||||
uint8_t audio_if = 0;
|
||||
uint8_t midi_if = 0;
|
||||
uint8_t uma_if_class;
|
||||
|
||||
while ((desc = usb_desc_foreach(cd, desc))) {
|
||||
@ -1539,7 +1541,8 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
((id->bInterfaceClass == UICLASS_VENDOR) &&
|
||||
(sc->sc_uq_au_vendor_class != 0)));
|
||||
|
||||
if ((uma_if_class != 0) && (id->bInterfaceSubClass == UISUBCLASS_AUDIOSTREAM)) {
|
||||
if ((uma_if_class != 0) &&
|
||||
(id->bInterfaceSubClass == UISUBCLASS_AUDIOSTREAM)) {
|
||||
audio_if = 1;
|
||||
} else {
|
||||
audio_if = 0;
|
||||
@ -1551,13 +1554,16 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
/*
|
||||
* XXX could allow multiple MIDI interfaces
|
||||
*/
|
||||
midi_if = 1;
|
||||
|
||||
if ((sc->sc_midi_chan.valid == 0) &&
|
||||
usbd_get_iface(udev, curidx)) {
|
||||
(usbd_get_iface(udev, curidx) != NULL)) {
|
||||
sc->sc_midi_chan.iface_index = curidx;
|
||||
sc->sc_midi_chan.iface_alt_index = alt_index;
|
||||
sc->sc_midi_chan.valid = 1;
|
||||
}
|
||||
} else {
|
||||
midi_if = 0;
|
||||
}
|
||||
asid.v1 = NULL;
|
||||
asf1d.v1 = NULL;
|
||||
@ -1566,6 +1572,7 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
}
|
||||
|
||||
if (audio_if == 0) {
|
||||
if (midi_if == 0) {
|
||||
if ((acdp == NULL) &&
|
||||
(desc->bDescriptorType == UDESC_CS_INTERFACE) &&
|
||||
(desc->bDescriptorSubtype == UDESCSUB_AC_HEADER) &&
|
||||
@ -1573,7 +1580,17 @@ uaudio_chan_fill_info_sub(struct uaudio_softc *sc, struct usb_device *udev,
|
||||
acdp = (void *)desc;
|
||||
audio_rev = UGETW(acdp->bcdADC);
|
||||
}
|
||||
} else {
|
||||
msid = (void *)desc;
|
||||
|
||||
/* get the maximum number of embedded jacks in use, if any */
|
||||
if (msid->bLength >= sizeof(*msid) &&
|
||||
msid->bDescriptorType == UDESC_CS_ENDPOINT &&
|
||||
msid->bDescriptorSubtype == MS_GENERAL &&
|
||||
msid->bNumEmbMIDIJack > sc->sc_midi_chan.max_emb_jack) {
|
||||
sc->sc_midi_chan.max_emb_jack = msid->bNumEmbMIDIJack;
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Don't collect any USB audio descriptors if
|
||||
* this is not an USB audio stream interface.
|
||||
@ -5225,8 +5242,7 @@ umidi_bulk_read_callback(struct usb_xfer *xfer, usb_error_t error)
|
||||
*/
|
||||
sub = &chan->sub[cn];
|
||||
|
||||
if ((cmd_len != 0) &&
|
||||
(cn < chan->max_cable) &&
|
||||
if ((cmd_len != 0) && (cn < chan->max_emb_jack) &&
|
||||
(sub->read_open != 0)) {
|
||||
|
||||
/* Send data to the application */
|
||||
@ -5462,7 +5478,7 @@ umidi_bulk_write_callback(struct usb_xfer *xfer, usb_error_t error)
|
||||
}
|
||||
|
||||
chan->curr_cable++;
|
||||
if (chan->curr_cable >= chan->max_cable)
|
||||
if (chan->curr_cable >= chan->max_emb_jack)
|
||||
chan->curr_cable = 0;
|
||||
|
||||
if (chan->curr_cable == start_cable) {
|
||||
@ -5499,7 +5515,7 @@ umidi_sub_by_fifo(struct usb_fifo *fifo)
|
||||
struct umidi_sub_chan *sub;
|
||||
uint32_t n;
|
||||
|
||||
for (n = 0; n < UMIDI_CABLES_MAX; n++) {
|
||||
for (n = 0; n < UMIDI_EMB_JACK_MAX; n++) {
|
||||
sub = &chan->sub[n];
|
||||
if ((sub->fifo.fp[USB_FIFO_RX] == fifo) ||
|
||||
(sub->fifo.fp[USB_FIFO_TX] == fifo)) {
|
||||
@ -5682,12 +5698,12 @@ umidi_probe(device_t dev)
|
||||
if (chan->single_command != 0)
|
||||
device_printf(dev, "Single command MIDI quirk enabled\n");
|
||||
|
||||
if ((chan->max_cable > UMIDI_CABLES_MAX) ||
|
||||
(chan->max_cable == 0)) {
|
||||
chan->max_cable = UMIDI_CABLES_MAX;
|
||||
if ((chan->max_emb_jack == 0) ||
|
||||
(chan->max_emb_jack > UMIDI_EMB_JACK_MAX)) {
|
||||
chan->max_emb_jack = UMIDI_EMB_JACK_MAX;
|
||||
}
|
||||
|
||||
for (n = 0; n < chan->max_cable; n++) {
|
||||
for (n = 0; n < chan->max_emb_jack; n++) {
|
||||
|
||||
sub = &chan->sub[n];
|
||||
|
||||
@ -5725,9 +5741,8 @@ umidi_detach(device_t dev)
|
||||
struct umidi_chan *chan = &sc->sc_midi_chan;
|
||||
uint32_t n;
|
||||
|
||||
for (n = 0; n < UMIDI_CABLES_MAX; n++) {
|
||||
for (n = 0; n < UMIDI_EMB_JACK_MAX; n++)
|
||||
usb_fifo_detach(&chan->sub[n].fifo);
|
||||
}
|
||||
|
||||
mtx_lock(&chan->mtx);
|
||||
|
||||
|
@ -119,6 +119,13 @@ struct usb_audio_streaming_endpoint_descriptor {
|
||||
uWord wLockDelay;
|
||||
} __packed;
|
||||
|
||||
struct usb_midi_streaming_endpoint_descriptor {
|
||||
uByte bLength;
|
||||
uByte bDescriptorType;
|
||||
uByte bDescriptorSubtype;
|
||||
uByte bNumEmbMIDIJack;
|
||||
} __packed;
|
||||
|
||||
struct usb_audio_streaming_type1_descriptor {
|
||||
uByte bLength;
|
||||
uByte bDescriptorType;
|
||||
@ -378,6 +385,7 @@ struct usb_audio_extension_unit_1 {
|
||||
|
||||
#define MASTER_CHAN 0
|
||||
|
||||
#define MS_GENERAL 1
|
||||
#define AS_GENERAL 1
|
||||
#define FORMAT_TYPE 2
|
||||
#define FORMAT_SPECIFIC 3
|
||||
|
Loading…
Reference in New Issue
Block a user