1 /* dvb-usb-urb.c is part of the DVB USB library.
3 * Copyright (C) 2004-6 Patrick Boettcher (patrick.boettcher@posteo.de)
4 * see dvb-usb-init.c for copyright information.
6 * This file keeps functions for initializing and handling the
9 #include "dvb-usb-common.h"
11 int dvb_usb_generic_rw(struct dvb_usb_device
*d
, u8
*wbuf
, u16 wlen
, u8
*rbuf
,
12 u16 rlen
, int delay_ms
)
14 int actlen
,ret
= -ENOMEM
;
16 if (!d
|| wbuf
== NULL
|| wlen
== 0)
19 if (d
->props
.generic_bulk_ctrl_endpoint
== 0) {
20 err("endpoint for generic control not specified.");
24 if ((ret
= mutex_lock_interruptible(&d
->usb_mutex
)))
28 debug_dump(wbuf
,wlen
,deb_xfer
);
30 ret
= usb_bulk_msg(d
->udev
,usb_sndbulkpipe(d
->udev
,
31 d
->props
.generic_bulk_ctrl_endpoint
), wbuf
,wlen
,&actlen
,
35 err("bulk message failed: %d (%d/%d)",ret
,wlen
,actlen
);
37 ret
= actlen
!= wlen
? -1 : 0;
39 /* an answer is expected, and no error before */
40 if (!ret
&& rbuf
&& rlen
) {
44 ret
= usb_bulk_msg(d
->udev
,usb_rcvbulkpipe(d
->udev
,
45 d
->props
.generic_bulk_ctrl_endpoint_response
?
46 d
->props
.generic_bulk_ctrl_endpoint_response
:
47 d
->props
.generic_bulk_ctrl_endpoint
),rbuf
,rlen
,&actlen
,
51 err("recv bulk message failed: %d",ret
);
54 debug_dump(rbuf
,actlen
,deb_xfer
);
58 mutex_unlock(&d
->usb_mutex
);
61 EXPORT_SYMBOL(dvb_usb_generic_rw
);
63 int dvb_usb_generic_write(struct dvb_usb_device
*d
, u8
*buf
, u16 len
)
65 return dvb_usb_generic_rw(d
,buf
,len
,NULL
,0,0);
67 EXPORT_SYMBOL(dvb_usb_generic_write
);
69 static void dvb_usb_data_complete(struct usb_data_stream
*stream
, u8
*buffer
, size_t length
)
71 struct dvb_usb_adapter
*adap
= stream
->user_priv
;
72 if (adap
->feedcount
> 0 && adap
->state
& DVB_USB_ADAP_STATE_DVB
)
73 dvb_dmx_swfilter(&adap
->demux
, buffer
, length
);
76 static void dvb_usb_data_complete_204(struct usb_data_stream
*stream
, u8
*buffer
, size_t length
)
78 struct dvb_usb_adapter
*adap
= stream
->user_priv
;
79 if (adap
->feedcount
> 0 && adap
->state
& DVB_USB_ADAP_STATE_DVB
)
80 dvb_dmx_swfilter_204(&adap
->demux
, buffer
, length
);
83 static void dvb_usb_data_complete_raw(struct usb_data_stream
*stream
,
84 u8
*buffer
, size_t length
)
86 struct dvb_usb_adapter
*adap
= stream
->user_priv
;
87 if (adap
->feedcount
> 0 && adap
->state
& DVB_USB_ADAP_STATE_DVB
)
88 dvb_dmx_swfilter_raw(&adap
->demux
, buffer
, length
);
91 int dvb_usb_adapter_stream_init(struct dvb_usb_adapter
*adap
)
94 for (i
= 0; i
< adap
->props
.num_frontends
; i
++) {
96 adap
->fe_adap
[i
].stream
.udev
= adap
->dev
->udev
;
97 if (adap
->props
.fe
[i
].caps
& DVB_USB_ADAP_RECEIVES_204_BYTE_TS
)
98 adap
->fe_adap
[i
].stream
.complete
=
99 dvb_usb_data_complete_204
;
101 if (adap
->props
.fe
[i
].caps
& DVB_USB_ADAP_RECEIVES_RAW_PAYLOAD
)
102 adap
->fe_adap
[i
].stream
.complete
=
103 dvb_usb_data_complete_raw
;
105 adap
->fe_adap
[i
].stream
.complete
= dvb_usb_data_complete
;
106 adap
->fe_adap
[i
].stream
.user_priv
= adap
;
107 ret
= usb_urb_init(&adap
->fe_adap
[i
].stream
,
108 &adap
->props
.fe
[i
].stream
);
115 int dvb_usb_adapter_stream_exit(struct dvb_usb_adapter
*adap
)
118 for (i
= 0; i
< adap
->props
.num_frontends
; i
++)
119 usb_urb_exit(&adap
->fe_adap
[i
].stream
);