提交 057ca0da 编写于 作者: F Frank Schaefer 提交者: Mauro Carvalho Chehab

[media] em28xx: create a common function for isoc and bulk USB transfer initialization

- rename em28xx_init_isoc to em28xx_init_usb_xfer
- add parameter for isoc/bulk transfer selection which is passed to em28xx_alloc_urbs
- rename local variable isoc_buf to usb_bufs
Signed-off-by: NFrank Schäfer <fschaefer.oss@googlemail.com>
Signed-off-by: NMauro Carvalho Chehab <mchehab@redhat.com>
上级 6ddd89d0
...@@ -1141,33 +1141,35 @@ EXPORT_SYMBOL_GPL(em28xx_alloc_urbs); ...@@ -1141,33 +1141,35 @@ EXPORT_SYMBOL_GPL(em28xx_alloc_urbs);
/* /*
* Allocate URBs and start IRQ * Allocate URBs and start IRQ
*/ */
int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode, int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode,
int num_packets, int num_bufs, int max_pkt_size, int xfer_bulk, int num_bufs, int max_pkt_size,
int (*isoc_copy) (struct em28xx *dev, struct urb *urb)) int packet_multiplier,
int (*urb_data_copy) (struct em28xx *dev, struct urb *urb))
{ {
struct em28xx_dmaqueue *dma_q = &dev->vidq; struct em28xx_dmaqueue *dma_q = &dev->vidq;
struct em28xx_dmaqueue *vbi_dma_q = &dev->vbiq; struct em28xx_dmaqueue *vbi_dma_q = &dev->vbiq;
struct em28xx_usb_bufs *isoc_bufs; struct em28xx_usb_bufs *usb_bufs;
int i; int i;
int rc; int rc;
int alloc; int alloc;
em28xx_isocdbg("em28xx: called em28xx_init_isoc in mode %d\n", mode); em28xx_isocdbg("em28xx: called em28xx_init_usb_xfer in mode %d\n",
mode);
dev->usb_ctl.urb_data_copy = isoc_copy; dev->usb_ctl.urb_data_copy = urb_data_copy;
if (mode == EM28XX_DIGITAL_MODE) { if (mode == EM28XX_DIGITAL_MODE) {
isoc_bufs = &dev->usb_ctl.digital_bufs; usb_bufs = &dev->usb_ctl.digital_bufs;
/* no need to free/alloc isoc buffers in digital mode */ /* no need to free/alloc usb buffers in digital mode */
alloc = 0; alloc = 0;
} else { } else {
isoc_bufs = &dev->usb_ctl.analog_bufs; usb_bufs = &dev->usb_ctl.analog_bufs;
alloc = 1; alloc = 1;
} }
if (alloc) { if (alloc) {
rc = em28xx_alloc_urbs(dev, mode, 0, num_bufs, rc = em28xx_alloc_urbs(dev, mode, xfer_bulk, num_bufs,
max_pkt_size, num_packets); max_pkt_size, packet_multiplier);
if (rc) if (rc)
return rc; return rc;
} }
...@@ -1178,8 +1180,8 @@ int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode, ...@@ -1178,8 +1180,8 @@ int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode,
em28xx_capture_start(dev, 1); em28xx_capture_start(dev, 1);
/* submit urbs and enables IRQ */ /* submit urbs and enables IRQ */
for (i = 0; i < isoc_bufs->num_bufs; i++) { for (i = 0; i < usb_bufs->num_bufs; i++) {
rc = usb_submit_urb(isoc_bufs->urb[i], GFP_ATOMIC); rc = usb_submit_urb(usb_bufs->urb[i], GFP_ATOMIC);
if (rc) { if (rc) {
em28xx_err("submit of urb %i failed (error=%i)\n", i, em28xx_err("submit of urb %i failed (error=%i)\n", i,
rc); rc);
...@@ -1190,7 +1192,7 @@ int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode, ...@@ -1190,7 +1192,7 @@ int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode,
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(em28xx_init_isoc); EXPORT_SYMBOL_GPL(em28xx_init_usb_xfer);
/* /*
* em28xx_wake_i2c() * em28xx_wake_i2c()
......
...@@ -176,10 +176,11 @@ static int em28xx_start_streaming(struct em28xx_dvb *dvb) ...@@ -176,10 +176,11 @@ static int em28xx_start_streaming(struct em28xx_dvb *dvb)
EM28XX_DVB_NUM_ISOC_PACKETS, EM28XX_DVB_NUM_ISOC_PACKETS,
max_dvb_packet_size); max_dvb_packet_size);
return em28xx_init_isoc(dev, EM28XX_DIGITAL_MODE, return em28xx_init_usb_xfer(dev, EM28XX_DIGITAL_MODE, 0,
EM28XX_DVB_NUM_ISOC_PACKETS, EM28XX_DVB_NUM_BUFS,
EM28XX_DVB_NUM_BUFS, max_dvb_packet_size,
max_dvb_packet_size, em28xx_dvb_isoc_copy); EM28XX_DVB_NUM_ISOC_PACKETS,
em28xx_dvb_isoc_copy);
} }
static int em28xx_stop_streaming(struct em28xx_dvb *dvb) static int em28xx_stop_streaming(struct em28xx_dvb *dvb)
......
...@@ -763,17 +763,17 @@ buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb, ...@@ -763,17 +763,17 @@ buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb,
if (urb_init) { if (urb_init) {
if (em28xx_vbi_supported(dev) == 1) if (em28xx_vbi_supported(dev) == 1)
rc = em28xx_init_isoc(dev, EM28XX_ANALOG_MODE, rc = em28xx_init_usb_xfer(dev, EM28XX_ANALOG_MODE, 0,
EM28XX_NUM_ISOC_PACKETS, EM28XX_NUM_BUFS,
EM28XX_NUM_BUFS, dev->max_pkt_size,
dev->max_pkt_size, EM28XX_NUM_ISOC_PACKETS,
em28xx_isoc_copy_vbi); em28xx_isoc_copy_vbi);
else else
rc = em28xx_init_isoc(dev, EM28XX_ANALOG_MODE, rc = em28xx_init_usb_xfer(dev, EM28XX_ANALOG_MODE, 0,
EM28XX_NUM_ISOC_PACKETS, EM28XX_NUM_BUFS,
EM28XX_NUM_BUFS, dev->max_pkt_size,
dev->max_pkt_size, EM28XX_NUM_ISOC_PACKETS,
em28xx_isoc_copy); em28xx_isoc_copy);
if (rc < 0) if (rc < 0)
goto fail; goto fail;
} }
......
...@@ -664,9 +664,11 @@ int em28xx_resolution_set(struct em28xx *dev); ...@@ -664,9 +664,11 @@ int em28xx_resolution_set(struct em28xx *dev);
int em28xx_set_alternate(struct em28xx *dev); int em28xx_set_alternate(struct em28xx *dev);
int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk, int em28xx_alloc_urbs(struct em28xx *dev, enum em28xx_mode mode, int xfer_bulk,
int num_bufs, int max_pkt_size, int packet_multiplier); int num_bufs, int max_pkt_size, int packet_multiplier);
int em28xx_init_isoc(struct em28xx *dev, enum em28xx_mode mode, int em28xx_init_usb_xfer(struct em28xx *dev, enum em28xx_mode mode,
int num_packets, int num_bufs, int max_pkt_size, int xfer_bulk,
int (*isoc_copy) (struct em28xx *dev, struct urb *urb)); int num_bufs, int max_pkt_size, int packet_multiplier,
int (*urb_data_copy)
(struct em28xx *dev, struct urb *urb));
void em28xx_uninit_usb_xfer(struct em28xx *dev, enum em28xx_mode mode); void em28xx_uninit_usb_xfer(struct em28xx *dev, enum em28xx_mode mode);
void em28xx_stop_urbs(struct em28xx *dev); void em28xx_stop_urbs(struct em28xx *dev);
int em28xx_isoc_dvb_max_packetsize(struct em28xx *dev); int em28xx_isoc_dvb_max_packetsize(struct em28xx *dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册