nusb/cam: use setalt()

This commit is contained in:
cinap_lenrek 2022-02-23 18:02:02 +00:00
parent 67750a093f
commit 11e12ea0c0

View file

@ -190,7 +190,7 @@ cvtproc(void *v)
c->abort = 1; c->abort = 1;
free(fbuf); free(fbuf);
closedev(c->ep); closedev(c->ep);
usbcmd(c->dev, 0x01, Rsetiface, 0, c->iface->id, nil, 0); setalt(c->dev, c->iface);
c->ep = nil; c->ep = nil;
c->active = 0; c->active = 0;
c->abort = 0; c->abort = 0;
@ -198,7 +198,7 @@ cvtproc(void *v)
} }
static Ep* static Ep*
selaltc(Cam *c, ProbeControl *pc, Ep *ep) selbw(Cam *c, ProbeControl *pc, Ep *ep)
{ {
uvlong bw, bw1, minbw; uvlong bw, bw1, minbw;
Format *fo; Format *fo;
@ -206,7 +206,8 @@ selaltc(Cam *c, ProbeControl *pc, Ep *ep)
Ep *mink; Ep *mink;
if(getframedesc(c, pc->bFormatIndex, pc->bFrameIndex, &fo, &f) < 0){ if(getframedesc(c, pc->bFormatIndex, pc->bFrameIndex, &fo, &f) < 0){
werrstr("selaltc: PROBE_CONTROL returned invalid bFormatIndex,bFrameIndex=%d,%d", pc->bFormatIndex, pc->bFrameIndex); werrstr("selaltc: PROBE_CONTROL returned invalid bFormatIndex,bFrameIndex=%d,%d",
pc->bFormatIndex, pc->bFrameIndex);
return nil; return nil;
} }
mink = nil; mink = nil;
@ -218,8 +219,8 @@ selaltc(Cam *c, ProbeControl *pc, Ep *ep)
bw1 = ep->maxpkt * ep->ntds * 8 * 1000 * 8; bw1 = ep->maxpkt * ep->ntds * 8 * 1000 * 8;
if(bw1 >= bw) { if(bw1 >= bw) {
if(mink == nil || bw1 < minbw){ if(mink == nil || bw1 < minbw){
minbw = bw1;
mink = ep; mink = ep;
minbw = bw1;
} }
} }
} }
@ -227,10 +228,6 @@ selaltc(Cam *c, ProbeControl *pc, Ep *ep)
werrstr("device does not have enough bandwidth (need %lld bit/s)", bw); werrstr("device does not have enough bandwidth (need %lld bit/s)", bw);
return nil; return nil;
} }
if(usbcmd(c->dev, 0x01, Rsetiface, mink->iface->alt, mink->iface->id, nil, 0) < 0){
werrstr("selaltc: SET_INTERFACE(%d, %d): %r", ep->iface->id, ep->iface->alt);
return nil;
}
return mink; return mink;
} }
@ -275,22 +272,22 @@ err:
} }
if(getconverter(f) == nil) goto err; if(getconverter(f) == nil) goto err;
d = c->dev; d = c->dev;
if(usbcmd(d, 0x01, Rsetiface, 0, c->iface->id, nil, 0) < 0) goto err; if(setalt(d, c->iface) < 0) goto err;
if(usbcmd(d, 0x21, SET_CUR, VS_PROBE_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < sizeof(ProbeControl)) goto err; if(usbcmd(d, 0x21, SET_CUR, VS_PROBE_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < sizeof(ProbeControl)) goto err;
if(usbcmd(d, 0xA1, GET_CUR, VS_PROBE_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < 0) goto err; if(usbcmd(d, 0xA1, GET_CUR, VS_PROBE_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < 0) goto err;
if(usbcmd(d, 0x21, SET_CUR, VS_COMMIT_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < sizeof(ProbeControl)) goto err; if(usbcmd(d, 0x21, SET_CUR, VS_COMMIT_CONTROL << 8, c->iface->id, (uchar *) &c->pc, sizeof(ProbeControl)) < sizeof(ProbeControl)) goto err;
e = selaltc(c, &c->pc, d->usb->ep[c->hdr->bEndpointAddress & Epmax]); e = selbw(c, &c->pc, d->usb->ep[c->hdr->bEndpointAddress & Epmax]);
if(e == nil) if(e == nil || setalt(c->dev, e->iface) < 0)
goto err; return nil;
c->ep = openep(d, e); c->ep = openep(d, e);
if(c->ep == nil){ if(c->ep == nil){
usbcmd(d, 0x01, Rsetiface, 0, c->iface->id, nil, 0); setalt(d, c->iface);
goto err; goto err;
} }
devctl(c->ep, "uframes 1"); devctl(c->ep, "uframes 1");
if(opendevdata(c->ep, OREAD) < 0){ if(opendevdata(c->ep, OREAD) < 0){
usbcmd(d, 0x01, Rsetiface, 0, c->iface->id, nil, 0);
closedev(c->ep); closedev(c->ep);
setalt(d, c->iface);
goto err; goto err;
} }
mkframes(c); mkframes(c);