2  *  s2255drv.c - a driver for the Sensoray 2255 USB video capture device
 
   4  *   Copyright (C) 2007-2008 by Sensoray Company Inc.
 
   7  * Some video buffer code based on vivi driver:
 
   9  * Sensoray 2255 device supports 4 simultaneous channels.
 
  10  * The channels are not "crossbar" inputs, they are physically
 
  11  * attached to separate video decoders.
 
  13  * Because of USB2.0 bandwidth limitations. There is only a
 
  14  * certain amount of data which may be transferred at one time.
 
  16  * Example maximum bandwidth utilization:
 
  18  * -full size, color mode YUYV or YUV422P: 2 channels at once
 
  20  * -full or half size Grey scale: all 4 channels at once
 
  22  * -half size, color mode YUYV or YUV422P: all 4 channels at once
 
  24  * -full size, color mode YUYV or YUV422P 1/2 frame rate: all 4 channels
 
  26  *  (TODO: Incorporate videodev2 frame rate(FR) enumeration,
 
  27  *  which is currently experimental.)
 
  29  * This program is free software; you can redistribute it and/or modify
 
  30  * it under the terms of the GNU General Public License as published by
 
  31  * the Free Software Foundation; either version 2 of the License, or
 
  32  * (at your option) any later version.
 
  34  * This program is distributed in the hope that it will be useful,
 
  35  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 
  36  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
  37  * GNU General Public License for more details.
 
  39  * You should have received a copy of the GNU General Public License
 
  40  * along with this program; if not, write to the Free Software
 
  41  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
  44 #include <linux/module.h>
 
  45 #include <linux/firmware.h>
 
  46 #include <linux/kernel.h>
 
  47 #include <linux/mutex.h>
 
  48 #include <linux/videodev2.h>
 
  49 #include <linux/version.h>
 
  51 #include <media/videobuf-vmalloc.h>
 
  52 #include <media/v4l2-common.h>
 
  53 #include <media/v4l2-ioctl.h>
 
  54 #include <linux/vmalloc.h>
 
  55 #include <linux/usb.h>
 
  57 #define FIRMWARE_FILE_NAME "f2255usb.bin"
 
  61 /* default JPEG quality */
 
  62 #define S2255_DEF_JPEG_QUAL     50
 
  63 /* vendor request in */
 
  65 /* vendor request out */
 
  66 #define S2255_VR_OUT            1
 
  68 #define S2255_VR_FW             0x30
 
  69 /* USB endpoint number for configuring the device */
 
  70 #define S2255_CONFIG_EP         2
 
  71 /* maximum time for DSP to start responding after last FW word loaded(ms) */
 
  72 #define S2255_DSP_BOOTTIME      800
 
  73 /* maximum time to wait for firmware to load (ms) */
 
  74 #define S2255_LOAD_TIMEOUT      (5000 + S2255_DSP_BOOTTIME)
 
  75 #define S2255_DEF_BUFS          16
 
  76 #define S2255_SETMODE_TIMEOUT   500
 
  77 #define MAX_CHANNELS            4
 
  78 #define S2255_MARKER_FRAME      0x2255DA4AL
 
  79 #define S2255_MARKER_RESPONSE   0x2255ACACL
 
  80 #define S2255_USB_XFER_SIZE     (16 * 1024)
 
  81 #define MAX_CHANNELS            4
 
  82 #define MAX_PIPE_BUFFERS        1
 
  84 /* maximum size is PAL full size plus room for the marker header(s) */
 
  85 #define SYS_FRAMES_MAXSIZE      (720*288*2*2 + 4096)
 
  86 #define DEF_USB_BLOCK           S2255_USB_XFER_SIZE
 
  87 #define LINE_SZ_4CIFS_NTSC      640
 
  88 #define LINE_SZ_2CIFS_NTSC      640
 
  89 #define LINE_SZ_1CIFS_NTSC      320
 
  90 #define LINE_SZ_4CIFS_PAL       704
 
  91 #define LINE_SZ_2CIFS_PAL       704
 
  92 #define LINE_SZ_1CIFS_PAL       352
 
  93 #define NUM_LINES_4CIFS_NTSC    240
 
  94 #define NUM_LINES_2CIFS_NTSC    240
 
  95 #define NUM_LINES_1CIFS_NTSC    240
 
  96 #define NUM_LINES_4CIFS_PAL     288
 
  97 #define NUM_LINES_2CIFS_PAL     288
 
  98 #define NUM_LINES_1CIFS_PAL     288
 
  99 #define LINE_SZ_DEF             640
 
 100 #define NUM_LINES_DEF           240
 
 103 /* predefined settings */
 
 104 #define FORMAT_NTSC     1
 
 107 #define SCALE_4CIFS     1       /* 640x480(NTSC) or 704x576(PAL) */
 
 108 #define SCALE_2CIFS     2       /* 640x240(NTSC) or 704x288(PAL) */
 
 109 #define SCALE_1CIFS     3       /* 320x240(NTSC) or 352x288(PAL) */
 
 111 #define COLOR_YUVPL     1       /* YUV planar */
 
 112 #define COLOR_YUVPK     2       /* YUV packed */
 
 113 #define COLOR_Y8        4       /* monochrome */
 
 114 #define COLOR_JPG       5       /* JPEG */
 
 115 #define MASK_COLOR      0xff
 
 116 #define MASK_JPG_QUALITY 0xff00
 
 118 /* frame decimation. Not implemented by V4L yet(experimental in V4L) */
 
 119 #define FDEC_1          1       /* capture every frame. default */
 
 120 #define FDEC_2          2       /* capture every 2nd frame */
 
 121 #define FDEC_3          3       /* capture every 3rd frame */
 
 122 #define FDEC_5          5       /* capture every 5th frame */
 
 124 /*-------------------------------------------------------
 
 125  * Default mode parameters.
 
 126  *-------------------------------------------------------*/
 
 127 #define DEF_SCALE       SCALE_4CIFS
 
 128 #define DEF_COLOR       COLOR_YUVPL
 
 129 #define DEF_FDEC        FDEC_1
 
 131 #define DEF_CONTRAST    0x5c
 
 132 #define DEF_SATURATION  0x80
 
 135 /* usb config commands */
 
 136 #define IN_DATA_TOKEN   0x2255c0de
 
 137 #define CMD_2255        0xc2255000
 
 138 #define CMD_SET_MODE    (CMD_2255 | 0x10)
 
 139 #define CMD_START       (CMD_2255 | 0x20)
 
 140 #define CMD_STOP        (CMD_2255 | 0x30)
 
 141 #define CMD_STATUS      (CMD_2255 | 0x40)
 
 144         u32 format;     /* input video format (NTSC, PAL) */
 
 145         u32 scale;      /* output video scale */
 
 146         u32 color;      /* output video color format */
 
 147         u32 fdec;       /* frame decimation */
 
 148         u32 bright;     /* brightness */
 
 149         u32 contrast;   /* contrast */
 
 150         u32 saturation; /* saturation */
 
 151         u32 hue;        /* hue (NTSC only)*/
 
 152         u32 single;     /* capture 1 frame at a time (!=0), continuously (==0)*/
 
 153         u32 usb_block;  /* block size. should be 4096 of DEF_USB_BLOCK */
 
 154         u32 restart;    /* if DSP requires restart */
 
 158 #define S2255_READ_IDLE         0
 
 159 #define S2255_READ_FRAME        1
 
 161 /* frame structure */
 
 162 struct s2255_framei {
 
 164         unsigned long ulState;  /* ulState:S2255_READ_IDLE, S2255_READ_FRAME*/
 
 165         void *lpvbits;          /* image data */
 
 166         unsigned long cur_size; /* current data copied to it */
 
 169 /* image buffer structure */
 
 170 struct s2255_bufferi {
 
 171         unsigned long dwFrames;                 /* number of frames in buffer */
 
 172         struct s2255_framei frame[SYS_FRAMES];  /* array of FRAME structures */
 
 175 #define DEF_MODEI_NTSC_CONT     {FORMAT_NTSC, DEF_SCALE, DEF_COLOR,     \
 
 176                         DEF_FDEC, DEF_BRIGHT, DEF_CONTRAST, DEF_SATURATION, \
 
 177                         DEF_HUE, 0, DEF_USB_BLOCK, 0}
 
 179 struct s2255_dmaqueue {
 
 180         struct list_head        active;
 
 181         /* thread for acquisition */
 
 182         struct task_struct      *kthread;
 
 184         struct s2255_dev        *dev;
 
 188 /* for firmware loading, fw_state */
 
 189 #define S2255_FW_NOTLOADED      0
 
 190 #define S2255_FW_LOADED_DSPWAIT 1
 
 191 #define S2255_FW_SUCCESS        2
 
 192 #define S2255_FW_FAILED         3
 
 193 #define S2255_FW_DISCONNECTING  4
 
 195 #define S2255_FW_MARKER         0x22552f2f
 
 196 /* 2255 read states */
 
 197 #define S2255_READ_IDLE         0
 
 198 #define S2255_READ_FRAME        1
 
 205         wait_queue_head_t     wait_fw;
 
 206         const struct firmware *fw;
 
 209 struct s2255_pipeinfo {
 
 210         u32 max_transfer_size;
 
 211         u32 cur_transfer_size;
 
 218         void *dev;      /* back pointer to s2255_dev struct*/
 
 225 struct s2255_fmt; /*forward declaration */
 
 229         int                     users[MAX_CHANNELS];
 
 231         struct mutex            open_lock;
 
 232         int                     resources[MAX_CHANNELS];
 
 233         struct usb_device       *udev;
 
 234         struct usb_interface    *interface;
 
 237         struct s2255_dmaqueue   vidq[MAX_CHANNELS];
 
 238         struct video_device     *vdev[MAX_CHANNELS];
 
 239         struct list_head        s2255_devlist;
 
 240         struct timer_list       timer;
 
 241         struct s2255_fw *fw_data;
 
 244         struct s2255_pipeinfo   pipes[MAX_PIPE_BUFFERS];
 
 245         struct s2255_bufferi            buffer[MAX_CHANNELS];
 
 246         struct s2255_mode       mode[MAX_CHANNELS];
 
 247         /* jpeg compression */
 
 248         struct v4l2_jpegcompression jc[MAX_CHANNELS];
 
 249         const struct s2255_fmt  *cur_fmt[MAX_CHANNELS];
 
 250         int                     cur_frame[MAX_CHANNELS];
 
 251         int                     last_frame[MAX_CHANNELS];
 
 252         u32                     cc;     /* current channel */
 
 253         int                     b_acquire[MAX_CHANNELS];
 
 254         /* allocated image size */
 
 255         unsigned long           req_image_size[MAX_CHANNELS];
 
 256         /* received packet size */
 
 257         unsigned long           pkt_size[MAX_CHANNELS];
 
 258         int                     bad_payload[MAX_CHANNELS];
 
 259         unsigned long           frame_count[MAX_CHANNELS];
 
 262         int                     jpg_size[MAX_CHANNELS];
 
 263         /* if channel configured to default state */
 
 264         int                     chn_configured[MAX_CHANNELS];
 
 265         wait_queue_head_t       wait_setmode[MAX_CHANNELS];
 
 266         int                     setmode_ready[MAX_CHANNELS];
 
 271 #define to_s2255_dev(d) container_of(d, struct s2255_dev, kref)
 
 279 /* buffer for one video frame */
 
 280 struct s2255_buffer {
 
 281         /* common v4l buffer stuff -- must be first */
 
 282         struct videobuf_buffer vb;
 
 283         const struct s2255_fmt *fmt;
 
 287         struct s2255_dev        *dev;
 
 288         const struct s2255_fmt  *fmt;
 
 291         struct videobuf_queue   vb_vidq;
 
 292         enum v4l2_buf_type      type;
 
 294         /* mode below is the desired mode.
 
 295            mode in s2255_dev is the current mode that was last set */
 
 296         struct s2255_mode       mode;
 
 297         int                     resources[MAX_CHANNELS];
 
 300 #define CUR_USB_FWVER   774     /* current cypress EEPROM firmware version */
 
 301 #define S2255_MAJOR_VERSION     1
 
 302 #define S2255_MINOR_VERSION     13
 
 303 #define S2255_RELEASE           0
 
 304 #define S2255_VERSION           KERNEL_VERSION(S2255_MAJOR_VERSION, \
 
 305                                                S2255_MINOR_VERSION, \
 
 309 #define USB_S2255_VENDOR_ID     0x1943
 
 310 #define USB_S2255_PRODUCT_ID    0x2255
 
 311 #define S2255_NORMS             (V4L2_STD_PAL | V4L2_STD_NTSC)
 
 312 /* frame prefix size (sent once every frame) */
 
 313 #define PREFIX_SIZE             512
 
 315 /* Channels on box are in reverse order */
 
 316 static unsigned long G_chnmap[MAX_CHANNELS] = {3, 2, 1, 0};
 
 318 static LIST_HEAD(s2255_devlist);
 
 321 static int *s2255_debug = &debug;
 
 323 static int s2255_start_readpipe(struct s2255_dev *dev);
 
 324 static void s2255_stop_readpipe(struct s2255_dev *dev);
 
 325 static int s2255_start_acquire(struct s2255_dev *dev, unsigned long chn);
 
 326 static int s2255_stop_acquire(struct s2255_dev *dev, unsigned long chn);
 
 327 static void s2255_fillbuff(struct s2255_dev *dev, struct s2255_buffer *buf,
 
 328                            int chn, int jpgsize);
 
 329 static int s2255_set_mode(struct s2255_dev *dev, unsigned long chn,
 
 330                           struct s2255_mode *mode);
 
 331 static int s2255_board_shutdown(struct s2255_dev *dev);
 
 332 static void s2255_exit_v4l(struct s2255_dev *dev);
 
 333 static void s2255_fwload_start(struct s2255_dev *dev, int reset);
 
 334 static void s2255_destroy(struct kref *kref);
 
 335 static long s2255_vendor_req(struct s2255_dev *dev, unsigned char req,
 
 336                              u16 index, u16 value, void *buf,
 
 337                              s32 buf_len, int bOut);
 
 339 #define dprintk(level, fmt, arg...)                                     \
 
 341                 if (*s2255_debug >= (level)) {                          \
 
 342                         printk(KERN_DEBUG "s2255: " fmt, ##arg);        \
 
 347 static struct usb_driver s2255_driver;
 
 350 /* Declare static vars that will be used as parameters */
 
 351 static unsigned int vid_limit = 16;     /* Video memory limit, in Mb */
 
 353 /* start video number */
 
 354 static int video_nr = -1;       /* /dev/videoN, -1 for autodetect */
 
 356 module_param(debug, int, 0644);
 
 357 MODULE_PARM_DESC(debug, "Debug level(0-100) default 0");
 
 358 module_param(vid_limit, int, 0644);
 
 359 MODULE_PARM_DESC(vid_limit, "video memory limit(Mb)");
 
 360 module_param(video_nr, int, 0644);
 
 361 MODULE_PARM_DESC(video_nr, "start video minor(-1 default autodetect)");
 
 363 /* USB device table */
 
 364 static struct usb_device_id s2255_table[] = {
 
 365         {USB_DEVICE(USB_S2255_VENDOR_ID, USB_S2255_PRODUCT_ID)},
 
 366         { }                     /* Terminating entry */
 
 368 MODULE_DEVICE_TABLE(usb, s2255_table);
 
 371 #define BUFFER_TIMEOUT msecs_to_jiffies(400)
 
 373 /* supported controls */
 
 374 static struct v4l2_queryctrl s2255_qctrl[] = {
 
 376         .id = V4L2_CID_BRIGHTNESS,
 
 377         .type = V4L2_CTRL_TYPE_INTEGER,
 
 378         .name = "Brightness",
 
 385         .id = V4L2_CID_CONTRAST,
 
 386         .type = V4L2_CTRL_TYPE_INTEGER,
 
 391         .default_value = DEF_CONTRAST,
 
 394         .id = V4L2_CID_SATURATION,
 
 395         .type = V4L2_CTRL_TYPE_INTEGER,
 
 396         .name = "Saturation",
 
 400         .default_value = DEF_SATURATION,
 
 404         .type = V4L2_CTRL_TYPE_INTEGER,
 
 409         .default_value = DEF_HUE,
 
 414 static int qctl_regs[ARRAY_SIZE(s2255_qctrl)];
 
 417 static const struct s2255_fmt formats[] = {
 
 419                 .name = "4:2:2, planar, YUV422P",
 
 420                 .fourcc = V4L2_PIX_FMT_YUV422P,
 
 424                 .name = "4:2:2, packed, YUYV",
 
 425                 .fourcc = V4L2_PIX_FMT_YUYV,
 
 429                 .name = "4:2:2, packed, UYVY",
 
 430                 .fourcc = V4L2_PIX_FMT_UYVY,
 
 434                 .fourcc = V4L2_PIX_FMT_JPEG,
 
 438                 .fourcc = V4L2_PIX_FMT_GREY,
 
 443 static int norm_maxw(struct video_device *vdev)
 
 445         return (vdev->current_norm & V4L2_STD_NTSC) ?
 
 446             LINE_SZ_4CIFS_NTSC : LINE_SZ_4CIFS_PAL;
 
 449 static int norm_maxh(struct video_device *vdev)
 
 451         return (vdev->current_norm & V4L2_STD_NTSC) ?
 
 452             (NUM_LINES_1CIFS_NTSC * 2) : (NUM_LINES_1CIFS_PAL * 2);
 
 455 static int norm_minw(struct video_device *vdev)
 
 457         return (vdev->current_norm & V4L2_STD_NTSC) ?
 
 458             LINE_SZ_1CIFS_NTSC : LINE_SZ_1CIFS_PAL;
 
 461 static int norm_minh(struct video_device *vdev)
 
 463         return (vdev->current_norm & V4L2_STD_NTSC) ?
 
 464             (NUM_LINES_1CIFS_NTSC) : (NUM_LINES_1CIFS_PAL);
 
 469  * TODO: fixme: move YUV reordering to hardware
 
 470  * converts 2255 planar format to yuyv or uyvy
 
 472 static void planar422p_to_yuv_packed(const unsigned char *in,
 
 474                                      int width, int height,
 
 480         unsigned long size = height * width;
 
 482         pY = (unsigned char *)in;
 
 483         pCr = (unsigned char *)in + height * width;
 
 484         pCb = (unsigned char *)in + height * width + (height * width / 2);
 
 485         for (i = 0; i < size * 2; i += 4) {
 
 486                 out[i] = (fmt == V4L2_PIX_FMT_YUYV) ? *pY++ : *pCr++;
 
 487                 out[i + 1] = (fmt == V4L2_PIX_FMT_YUYV) ? *pCr++ : *pY++;
 
 488                 out[i + 2] = (fmt == V4L2_PIX_FMT_YUYV) ? *pY++ : *pCb++;
 
 489                 out[i + 3] = (fmt == V4L2_PIX_FMT_YUYV) ? *pCb++ : *pY++;
 
 494 static void s2255_reset_dsppower(struct s2255_dev *dev)
 
 496         s2255_vendor_req(dev, 0x40, 0x0b0b, 0x0b0b, NULL, 0, 1);
 
 498         s2255_vendor_req(dev, 0x50, 0x0000, 0x0000, NULL, 0, 1);
 
 502 /* kickstarts the firmware loading. from probe
 
 504 static void s2255_timer(unsigned long user_data)
 
 506         struct s2255_fw *data = (struct s2255_fw *)user_data;
 
 507         dprintk(100, "s2255 timer\n");
 
 508         if (usb_submit_urb(data->fw_urb, GFP_ATOMIC) < 0) {
 
 509                 printk(KERN_ERR "s2255: can't submit urb\n");
 
 510                 atomic_set(&data->fw_state, S2255_FW_FAILED);
 
 511                 /* wake up anything waiting for the firmware */
 
 512                 wake_up(&data->wait_fw);
 
 518 /* this loads the firmware asynchronously.
 
 519    Originally this was done synchroously in probe.
 
 520    But it is better to load it asynchronously here than block
 
 521    inside the probe function. Blocking inside probe affects boot time.
 
 522    FW loading is triggered by the timer in the probe function
 
 524 static void s2255_fwchunk_complete(struct urb *urb)
 
 526         struct s2255_fw *data = urb->context;
 
 527         struct usb_device *udev = urb->dev;
 
 529         dprintk(100, "udev %p urb %p", udev, urb);
 
 531                 dev_err(&udev->dev, "URB failed with status %d", urb->status);
 
 532                 atomic_set(&data->fw_state, S2255_FW_FAILED);
 
 533                 /* wake up anything waiting for the firmware */
 
 534                 wake_up(&data->wait_fw);
 
 537         if (data->fw_urb == NULL) {
 
 538                 dev_err(&udev->dev, "s2255 disconnected\n");
 
 539                 atomic_set(&data->fw_state, S2255_FW_FAILED);
 
 540                 /* wake up anything waiting for the firmware */
 
 541                 wake_up(&data->wait_fw);
 
 544 #define CHUNK_SIZE 512
 
 545         /* all USB transfers must be done with continuous kernel memory.
 
 546            can't allocate more than 128k in current linux kernel, so
 
 547            upload the firmware in chunks
 
 549         if (data->fw_loaded < data->fw_size) {
 
 550                 len = (data->fw_loaded + CHUNK_SIZE) > data->fw_size ?
 
 551                     data->fw_size % CHUNK_SIZE : CHUNK_SIZE;
 
 553                 if (len < CHUNK_SIZE)
 
 554                         memset(data->pfw_data, 0, CHUNK_SIZE);
 
 556                 dprintk(100, "completed len %d, loaded %d \n", len,
 
 559                 memcpy(data->pfw_data,
 
 560                        (char *) data->fw->data + data->fw_loaded, len);
 
 562                 usb_fill_bulk_urb(data->fw_urb, udev, usb_sndbulkpipe(udev, 2),
 
 563                                   data->pfw_data, CHUNK_SIZE,
 
 564                                   s2255_fwchunk_complete, data);
 
 565                 if (usb_submit_urb(data->fw_urb, GFP_ATOMIC) < 0) {
 
 566                         dev_err(&udev->dev, "failed submit URB\n");
 
 567                         atomic_set(&data->fw_state, S2255_FW_FAILED);
 
 568                         /* wake up anything waiting for the firmware */
 
 569                         wake_up(&data->wait_fw);
 
 572                 data->fw_loaded += len;
 
 574                 atomic_set(&data->fw_state, S2255_FW_LOADED_DSPWAIT);
 
 576         dprintk(100, "2255 complete done\n");
 
 581 static int s2255_got_frame(struct s2255_dev *dev, int chn, int jpgsize)
 
 583         struct s2255_dmaqueue *dma_q = &dev->vidq[chn];
 
 584         struct s2255_buffer *buf;
 
 585         unsigned long flags = 0;
 
 587         dprintk(2, "wakeup: %p channel: %d\n", &dma_q, chn);
 
 588         spin_lock_irqsave(&dev->slock, flags);
 
 590         if (list_empty(&dma_q->active)) {
 
 591                 dprintk(1, "No active queue to serve\n");
 
 595         buf = list_entry(dma_q->active.next,
 
 596                          struct s2255_buffer, vb.queue);
 
 598         if (!waitqueue_active(&buf->vb.done)) {
 
 603         list_del(&buf->vb.queue);
 
 604         do_gettimeofday(&buf->vb.ts);
 
 605         dprintk(100, "[%p/%d] wakeup\n", buf, buf->vb.i);
 
 606         s2255_fillbuff(dev, buf, dma_q->channel, jpgsize);
 
 607         wake_up(&buf->vb.done);
 
 608         dprintk(2, "wakeup [buf/i] [%p/%d]\n", buf, buf->vb.i);
 
 610         spin_unlock_irqrestore(&dev->slock, flags);
 
 615 static const struct s2255_fmt *format_by_fourcc(int fourcc)
 
 619         for (i = 0; i < ARRAY_SIZE(formats); i++) {
 
 620                 if (-1 == formats[i].fourcc)
 
 622                 if (formats[i].fourcc == fourcc)
 
 631 /* video buffer vmalloc implementation based partly on VIVI driver which is
 
 632  *          Copyright (c) 2006 by
 
 633  *                  Mauro Carvalho Chehab <mchehab--a.t--infradead.org>
 
 634  *                  Ted Walther <ted--a.t--enumera.com>
 
 635  *                  John Sokol <sokol--a.t--videotechnology.com>
 
 636  *                  http://v4l.videotechnology.com/
 
 639 static void s2255_fillbuff(struct s2255_dev *dev, struct s2255_buffer *buf,
 
 640                            int chn, int jpgsize)
 
 645         char *vbuf = videobuf_to_vmalloc(&buf->vb);
 
 646         unsigned long last_frame;
 
 647         struct s2255_framei *frm;
 
 652         last_frame = dev->last_frame[chn];
 
 653         if (last_frame != -1) {
 
 654                 frm = &dev->buffer[chn].frame[last_frame];
 
 656                     (const char *)dev->buffer[chn].frame[last_frame].lpvbits;
 
 657                 switch (buf->fmt->fourcc) {
 
 658                 case V4L2_PIX_FMT_YUYV:
 
 659                 case V4L2_PIX_FMT_UYVY:
 
 660                         planar422p_to_yuv_packed((const unsigned char *)tmpbuf,
 
 665                 case V4L2_PIX_FMT_GREY:
 
 666                         memcpy(vbuf, tmpbuf, buf->vb.width * buf->vb.height);
 
 668                 case V4L2_PIX_FMT_JPEG:
 
 669                         buf->vb.size = jpgsize;
 
 670                         memcpy(vbuf, tmpbuf, buf->vb.size);
 
 672                 case V4L2_PIX_FMT_YUV422P:
 
 674                                buf->vb.width * buf->vb.height * 2);
 
 677                         printk(KERN_DEBUG "s2255: unknown format?\n");
 
 679                 dev->last_frame[chn] = -1;
 
 681                 printk(KERN_ERR "s2255: =======no frame\n");
 
 685         dprintk(2, "s2255fill at : Buffer 0x%08lx size= %d\n",
 
 686                 (unsigned long)vbuf, pos);
 
 687         /* tell v4l buffer was filled */
 
 689         buf->vb.field_count = dev->frame_count[chn] * 2;
 
 690         do_gettimeofday(&ts);
 
 692         buf->vb.state = VIDEOBUF_DONE;
 
 696 /* ------------------------------------------------------------------
 
 698    ------------------------------------------------------------------*/
 
 700 static int buffer_setup(struct videobuf_queue *vq, unsigned int *count,
 
 703         struct s2255_fh *fh = vq->priv_data;
 
 705         *size = fh->width * fh->height * (fh->fmt->depth >> 3);
 
 708                 *count = S2255_DEF_BUFS;
 
 710         while (*size * (*count) > vid_limit * 1024 * 1024)
 
 716 static void free_buffer(struct videobuf_queue *vq, struct s2255_buffer *buf)
 
 718         dprintk(4, "%s\n", __func__);
 
 720         videobuf_waiton(&buf->vb, 0, 0);
 
 721         videobuf_vmalloc_free(&buf->vb);
 
 722         buf->vb.state = VIDEOBUF_NEEDS_INIT;
 
 725 static int buffer_prepare(struct videobuf_queue *vq, struct videobuf_buffer *vb,
 
 726                           enum v4l2_field field)
 
 728         struct s2255_fh *fh = vq->priv_data;
 
 729         struct s2255_buffer *buf = container_of(vb, struct s2255_buffer, vb);
 
 731         dprintk(4, "%s, field=%d\n", __func__, field);
 
 735         if ((fh->width < norm_minw(fh->dev->vdev[fh->channel])) ||
 
 736             (fh->width > norm_maxw(fh->dev->vdev[fh->channel])) ||
 
 737             (fh->height < norm_minh(fh->dev->vdev[fh->channel])) ||
 
 738             (fh->height > norm_maxh(fh->dev->vdev[fh->channel]))) {
 
 739                 dprintk(4, "invalid buffer prepare\n");
 
 743         buf->vb.size = fh->width * fh->height * (fh->fmt->depth >> 3);
 
 745         if (0 != buf->vb.baddr && buf->vb.bsize < buf->vb.size) {
 
 746                 dprintk(4, "invalid buffer prepare\n");
 
 751         buf->vb.width = fh->width;
 
 752         buf->vb.height = fh->height;
 
 753         buf->vb.field = field;
 
 756         if (VIDEOBUF_NEEDS_INIT == buf->vb.state) {
 
 757                 rc = videobuf_iolock(vq, &buf->vb, NULL);
 
 762         buf->vb.state = VIDEOBUF_PREPARED;
 
 765         free_buffer(vq, buf);
 
 769 static void buffer_queue(struct videobuf_queue *vq, struct videobuf_buffer *vb)
 
 771         struct s2255_buffer *buf = container_of(vb, struct s2255_buffer, vb);
 
 772         struct s2255_fh *fh = vq->priv_data;
 
 773         struct s2255_dev *dev = fh->dev;
 
 774         struct s2255_dmaqueue *vidq = &dev->vidq[fh->channel];
 
 776         dprintk(1, "%s\n", __func__);
 
 778         buf->vb.state = VIDEOBUF_QUEUED;
 
 779         list_add_tail(&buf->vb.queue, &vidq->active);
 
 782 static void buffer_release(struct videobuf_queue *vq,
 
 783                            struct videobuf_buffer *vb)
 
 785         struct s2255_buffer *buf = container_of(vb, struct s2255_buffer, vb);
 
 786         struct s2255_fh *fh = vq->priv_data;
 
 787         dprintk(4, "%s %d\n", __func__, fh->channel);
 
 788         free_buffer(vq, buf);
 
 791 static struct videobuf_queue_ops s2255_video_qops = {
 
 792         .buf_setup = buffer_setup,
 
 793         .buf_prepare = buffer_prepare,
 
 794         .buf_queue = buffer_queue,
 
 795         .buf_release = buffer_release,
 
 799 static int res_get(struct s2255_dev *dev, struct s2255_fh *fh)
 
 802         mutex_lock(&dev->lock);
 
 803         if (dev->resources[fh->channel]) {
 
 804                 /* no, someone else uses it */
 
 805                 mutex_unlock(&dev->lock);
 
 808         /* it's free, grab it */
 
 809         dev->resources[fh->channel] = 1;
 
 810         fh->resources[fh->channel] = 1;
 
 811         dprintk(1, "s2255: res: get\n");
 
 812         mutex_unlock(&dev->lock);
 
 816 static int res_locked(struct s2255_dev *dev, struct s2255_fh *fh)
 
 818         return dev->resources[fh->channel];
 
 821 static int res_check(struct s2255_fh *fh)
 
 823         return fh->resources[fh->channel];
 
 827 static void res_free(struct s2255_dev *dev, struct s2255_fh *fh)
 
 829         mutex_lock(&dev->lock);
 
 830         dev->resources[fh->channel] = 0;
 
 831         fh->resources[fh->channel] = 0;
 
 832         mutex_unlock(&dev->lock);
 
 833         dprintk(1, "res: put\n");
 
 837 static int vidioc_querycap(struct file *file, void *priv,
 
 838                            struct v4l2_capability *cap)
 
 840         struct s2255_fh *fh = file->private_data;
 
 841         struct s2255_dev *dev = fh->dev;
 
 842         strlcpy(cap->driver, "s2255", sizeof(cap->driver));
 
 843         strlcpy(cap->card, "s2255", sizeof(cap->card));
 
 844         strlcpy(cap->bus_info, dev_name(&dev->udev->dev),
 
 845                 sizeof(cap->bus_info));
 
 846         cap->version = S2255_VERSION;
 
 847         cap->capabilities = V4L2_CAP_VIDEO_CAPTURE | V4L2_CAP_STREAMING;
 
 851 static int vidioc_enum_fmt_vid_cap(struct file *file, void *priv,
 
 852                                struct v4l2_fmtdesc *f)
 
 858         if (index >= ARRAY_SIZE(formats))
 
 861         dprintk(4, "name %s\n", formats[index].name);
 
 862         strlcpy(f->description, formats[index].name, sizeof(f->description));
 
 863         f->pixelformat = formats[index].fourcc;
 
 867 static int vidioc_g_fmt_vid_cap(struct file *file, void *priv,
 
 868                             struct v4l2_format *f)
 
 870         struct s2255_fh *fh = priv;
 
 872         f->fmt.pix.width = fh->width;
 
 873         f->fmt.pix.height = fh->height;
 
 874         f->fmt.pix.field = fh->vb_vidq.field;
 
 875         f->fmt.pix.pixelformat = fh->fmt->fourcc;
 
 876         f->fmt.pix.bytesperline = f->fmt.pix.width * (fh->fmt->depth >> 3);
 
 877         f->fmt.pix.sizeimage = f->fmt.pix.height * f->fmt.pix.bytesperline;
 
 881 static int vidioc_try_fmt_vid_cap(struct file *file, void *priv,
 
 882                               struct v4l2_format *f)
 
 884         const struct s2255_fmt *fmt;
 
 885         enum v4l2_field field;
 
 887         struct s2255_fh *fh = priv;
 
 888         struct s2255_dev *dev = fh->dev;
 
 892             (dev->vdev[fh->channel]->current_norm & V4L2_STD_NTSC) ? 1 : 0;
 
 894         fmt = format_by_fourcc(f->fmt.pix.pixelformat);
 
 899         field = f->fmt.pix.field;
 
 900         if (field == V4L2_FIELD_ANY)
 
 903         dprintk(4, "try format %d \n", is_ntsc);
 
 904         /* supports 3 sizes. see s2255drv.h */
 
 905         dprintk(50, "width test %d, height %d\n",
 
 906                 f->fmt.pix.width, f->fmt.pix.height);
 
 909                 if (f->fmt.pix.height >= NUM_LINES_1CIFS_NTSC * 2) {
 
 910                         f->fmt.pix.height = NUM_LINES_1CIFS_NTSC * 2;
 
 912                                 field = V4L2_FIELD_SEQ_TB;
 
 913                         } else if (!((field == V4L2_FIELD_INTERLACED) ||
 
 914                                       (field == V4L2_FIELD_SEQ_TB) ||
 
 915                                       (field == V4L2_FIELD_INTERLACED_TB))) {
 
 916                                 dprintk(1, "unsupported field setting\n");
 
 920                         f->fmt.pix.height = NUM_LINES_1CIFS_NTSC;
 
 922                                 field = V4L2_FIELD_TOP;
 
 923                         } else if (!((field == V4L2_FIELD_TOP) ||
 
 924                                       (field == V4L2_FIELD_BOTTOM))) {
 
 925                                 dprintk(1, "unsupported field setting\n");
 
 930                 if (f->fmt.pix.width >= LINE_SZ_4CIFS_NTSC)
 
 931                         f->fmt.pix.width = LINE_SZ_4CIFS_NTSC;
 
 932                 else if (f->fmt.pix.width >= LINE_SZ_2CIFS_NTSC)
 
 933                         f->fmt.pix.width = LINE_SZ_2CIFS_NTSC;
 
 934                 else if (f->fmt.pix.width >= LINE_SZ_1CIFS_NTSC)
 
 935                         f->fmt.pix.width = LINE_SZ_1CIFS_NTSC;
 
 937                         f->fmt.pix.width = LINE_SZ_1CIFS_NTSC;
 
 940                 if (f->fmt.pix.height >= NUM_LINES_1CIFS_PAL * 2) {
 
 941                         f->fmt.pix.height = NUM_LINES_1CIFS_PAL * 2;
 
 943                                 field = V4L2_FIELD_SEQ_TB;
 
 944                         } else if (!((field == V4L2_FIELD_INTERLACED) ||
 
 945                                       (field == V4L2_FIELD_SEQ_TB) ||
 
 946                                       (field == V4L2_FIELD_INTERLACED_TB))) {
 
 947                                 dprintk(1, "unsupported field setting\n");
 
 951                         f->fmt.pix.height = NUM_LINES_1CIFS_PAL;
 
 953                                 field = V4L2_FIELD_TOP;
 
 954                         } else if (!((field == V4L2_FIELD_TOP) ||
 
 955                                      (field == V4L2_FIELD_BOTTOM))) {
 
 956                                 dprintk(1, "unsupported field setting\n");
 
 960                 if (f->fmt.pix.width >= LINE_SZ_4CIFS_PAL) {
 
 961                         dprintk(50, "pal 704\n");
 
 962                         f->fmt.pix.width = LINE_SZ_4CIFS_PAL;
 
 963                         field = V4L2_FIELD_SEQ_TB;
 
 964                 } else if (f->fmt.pix.width >= LINE_SZ_2CIFS_PAL) {
 
 965                         dprintk(50, "pal 352A\n");
 
 966                         f->fmt.pix.width = LINE_SZ_2CIFS_PAL;
 
 967                         field = V4L2_FIELD_TOP;
 
 968                 } else if (f->fmt.pix.width >= LINE_SZ_1CIFS_PAL) {
 
 969                         dprintk(50, "pal 352B\n");
 
 970                         f->fmt.pix.width = LINE_SZ_1CIFS_PAL;
 
 971                         field = V4L2_FIELD_TOP;
 
 973                         dprintk(50, "pal 352C\n");
 
 974                         f->fmt.pix.width = LINE_SZ_1CIFS_PAL;
 
 975                         field = V4L2_FIELD_TOP;
 
 979         dprintk(50, "width %d height %d field %d \n", f->fmt.pix.width,
 
 980                 f->fmt.pix.height, f->fmt.pix.field);
 
 981         f->fmt.pix.field = field;
 
 982         f->fmt.pix.bytesperline = (f->fmt.pix.width * fmt->depth) >> 3;
 
 983         f->fmt.pix.sizeimage = f->fmt.pix.height * f->fmt.pix.bytesperline;
 
 987 static int vidioc_s_fmt_vid_cap(struct file *file, void *priv,
 
 988                             struct v4l2_format *f)
 
 990         struct s2255_fh *fh = priv;
 
 991         const struct s2255_fmt *fmt;
 
 992         struct videobuf_queue *q = &fh->vb_vidq;
 
 996         ret = vidioc_try_fmt_vid_cap(file, fh, f);
 
1001         fmt = format_by_fourcc(f->fmt.pix.pixelformat);
 
1006         mutex_lock(&q->vb_lock);
 
1008         if (videobuf_queue_is_busy(&fh->vb_vidq)) {
 
1009                 dprintk(1, "queue busy\n");
 
1014         if (res_locked(fh->dev, fh)) {
 
1015                 dprintk(1, "can't change format after started\n");
 
1021         fh->width = f->fmt.pix.width;
 
1022         fh->height = f->fmt.pix.height;
 
1023         fh->vb_vidq.field = f->fmt.pix.field;
 
1025         norm = norm_minw(fh->dev->vdev[fh->channel]);
 
1026         if (fh->width > norm_minw(fh->dev->vdev[fh->channel])) {
 
1027                 if (fh->height > norm_minh(fh->dev->vdev[fh->channel]))
 
1028                         fh->mode.scale = SCALE_4CIFS;
 
1030                         fh->mode.scale = SCALE_2CIFS;
 
1033                 fh->mode.scale = SCALE_1CIFS;
 
1037         switch (fh->fmt->fourcc) {
 
1038         case V4L2_PIX_FMT_GREY:
 
1039                 fh->mode.color = COLOR_Y8;
 
1041         case V4L2_PIX_FMT_JPEG:
 
1042                 fh->mode.color = COLOR_JPG |
 
1043                         (fh->dev->jc[fh->channel].quality << 8);
 
1045         case V4L2_PIX_FMT_YUV422P:
 
1046                 fh->mode.color = COLOR_YUVPL;
 
1048         case V4L2_PIX_FMT_YUYV:
 
1049         case V4L2_PIX_FMT_UYVY:
 
1051                 fh->mode.color = COLOR_YUVPK;
 
1056         mutex_unlock(&q->vb_lock);
 
1060 static int vidioc_reqbufs(struct file *file, void *priv,
 
1061                           struct v4l2_requestbuffers *p)
 
1064         struct s2255_fh *fh = priv;
 
1065         rc = videobuf_reqbufs(&fh->vb_vidq, p);
 
1069 static int vidioc_querybuf(struct file *file, void *priv, struct v4l2_buffer *p)
 
1072         struct s2255_fh *fh = priv;
 
1073         rc = videobuf_querybuf(&fh->vb_vidq, p);
 
1077 static int vidioc_qbuf(struct file *file, void *priv, struct v4l2_buffer *p)
 
1080         struct s2255_fh *fh = priv;
 
1081         rc = videobuf_qbuf(&fh->vb_vidq, p);
 
1085 static int vidioc_dqbuf(struct file *file, void *priv, struct v4l2_buffer *p)
 
1088         struct s2255_fh *fh = priv;
 
1089         rc = videobuf_dqbuf(&fh->vb_vidq, p, file->f_flags & O_NONBLOCK);
 
1093 #ifdef CONFIG_VIDEO_V4L1_COMPAT
 
1094 static int vidioc_cgmbuf(struct file *file, void *priv, struct video_mbuf *mbuf)
 
1096         struct s2255_fh *fh = priv;
 
1098         return videobuf_cgmbuf(&fh->vb_vidq, mbuf, 8);
 
1102 /* write to the configuration pipe, synchronously */
 
1103 static int s2255_write_config(struct usb_device *udev, unsigned char *pbuf,
 
1110                 pipe = usb_sndbulkpipe(udev, S2255_CONFIG_EP);
 
1111                 retval = usb_bulk_msg(udev, pipe, pbuf, size, &done, 500);
 
1116 static u32 get_transfer_size(struct s2255_mode *mode)
 
1118         int linesPerFrame = LINE_SZ_DEF;
 
1119         int pixelsPerLine = NUM_LINES_DEF;
 
1122         unsigned int mask_mult;
 
1127         if (mode->format == FORMAT_NTSC) {
 
1128                 switch (mode->scale) {
 
1130                         linesPerFrame = NUM_LINES_4CIFS_NTSC * 2;
 
1131                         pixelsPerLine = LINE_SZ_4CIFS_NTSC;
 
1134                         linesPerFrame = NUM_LINES_2CIFS_NTSC;
 
1135                         pixelsPerLine = LINE_SZ_2CIFS_NTSC;
 
1138                         linesPerFrame = NUM_LINES_1CIFS_NTSC;
 
1139                         pixelsPerLine = LINE_SZ_1CIFS_NTSC;
 
1144         } else if (mode->format == FORMAT_PAL) {
 
1145                 switch (mode->scale) {
 
1147                         linesPerFrame = NUM_LINES_4CIFS_PAL * 2;
 
1148                         pixelsPerLine = LINE_SZ_4CIFS_PAL;
 
1151                         linesPerFrame = NUM_LINES_2CIFS_PAL;
 
1152                         pixelsPerLine = LINE_SZ_2CIFS_PAL;
 
1155                         linesPerFrame = NUM_LINES_1CIFS_PAL;
 
1156                         pixelsPerLine = LINE_SZ_1CIFS_PAL;
 
1162         outImageSize = linesPerFrame * pixelsPerLine;
 
1163         if ((mode->color & MASK_COLOR) != COLOR_Y8) {
 
1164                 /* 2 bytes/pixel if not monochrome */
 
1168         /* total bytes to send including prefix and 4K padding;
 
1169            must be a multiple of USB_READ_SIZE */
 
1170         usbInSize = outImageSize + PREFIX_SIZE; /* always send prefix */
 
1171         mask_mult = 0xffffffffUL - DEF_USB_BLOCK + 1;
 
1172         /* if size not a multiple of USB_READ_SIZE */
 
1173         if (usbInSize & ~mask_mult)
 
1174                 usbInSize = (usbInSize & mask_mult) + (DEF_USB_BLOCK);
 
1178 static void dump_verify_mode(struct s2255_dev *sdev, struct s2255_mode *mode)
 
1180         struct device *dev = &sdev->udev->dev;
 
1181         dev_info(dev, "------------------------------------------------\n");
 
1182         dev_info(dev, "verify mode\n");
 
1183         dev_info(dev, "format: %d\n", mode->format);
 
1184         dev_info(dev, "scale: %d\n", mode->scale);
 
1185         dev_info(dev, "fdec: %d\n", mode->fdec);
 
1186         dev_info(dev, "color: %d\n", mode->color);
 
1187         dev_info(dev, "bright: 0x%x\n", mode->bright);
 
1188         dev_info(dev, "restart: 0x%x\n", mode->restart);
 
1189         dev_info(dev, "usb_block: 0x%x\n", mode->usb_block);
 
1190         dev_info(dev, "single: 0x%x\n", mode->single);
 
1191         dev_info(dev, "------------------------------------------------\n");
 
1195  * set mode is the function which controls the DSP.
 
1196  * the restart parameter in struct s2255_mode should be set whenever
 
1197  * the image size could change via color format, video system or image
 
1199  * When the restart parameter is set, we sleep for ONE frame to allow the
 
1200  * DSP time to get the new frame
 
1202 static int s2255_set_mode(struct s2255_dev *dev, unsigned long chn,
 
1203                           struct s2255_mode *mode)
 
1207         unsigned long chn_rev;
 
1209         mutex_lock(&dev->lock);
 
1210         chn_rev = G_chnmap[chn];
 
1211         dprintk(3, "mode scale [%ld] %p %d\n", chn, mode, mode->scale);
 
1212         dprintk(3, "mode scale [%ld] %p %d\n", chn, &dev->mode[chn],
 
1213                 dev->mode[chn].scale);
 
1214         dprintk(2, "mode contrast %x\n", mode->contrast);
 
1216         /* if JPEG, set the quality */
 
1217         if ((mode->color & MASK_COLOR) == COLOR_JPG)
 
1218                 mode->color = (dev->jc[chn].quality << 8) | COLOR_JPG;
 
1221         dev->mode[chn] = *mode;
 
1222         dev->req_image_size[chn] = get_transfer_size(mode);
 
1223         dprintk(1, "transfer size %ld\n", dev->req_image_size[chn]);
 
1225         buffer = kzalloc(512, GFP_KERNEL);
 
1226         if (buffer == NULL) {
 
1227                 dev_err(&dev->udev->dev, "out of mem\n");
 
1228                 mutex_unlock(&dev->lock);
 
1233         buffer[0] = IN_DATA_TOKEN;
 
1234         buffer[1] = (u32) chn_rev;
 
1235         buffer[2] = CMD_SET_MODE;
 
1236         memcpy(&buffer[3], &dev->mode[chn], sizeof(struct s2255_mode));
 
1237         res = s2255_write_config(dev->udev, (unsigned char *)buffer, 512);
 
1239                 dump_verify_mode(dev, mode);
 
1241         dprintk(1, "set mode done chn %lu, %d\n", chn, res);
 
1243         /* wait at least 3 frames before continuing */
 
1244         if (mode->restart) {
 
1245                 dev->setmode_ready[chn] = 0;
 
1246                 wait_event_timeout(dev->wait_setmode[chn],
 
1247                                    (dev->setmode_ready[chn] != 0),
 
1248                                    msecs_to_jiffies(S2255_SETMODE_TIMEOUT));
 
1249                 if (dev->setmode_ready[chn] != 1) {
 
1250                         printk(KERN_DEBUG "s2255: no set mode response\n");
 
1255         /* clear the restart flag */
 
1256         dev->mode[chn].restart = 0;
 
1257         mutex_unlock(&dev->lock);
 
1261 static int vidioc_streamon(struct file *file, void *priv, enum v4l2_buf_type i)
 
1264         struct s2255_fh *fh = priv;
 
1265         struct s2255_dev *dev = fh->dev;
 
1266         struct s2255_mode *new_mode;
 
1267         struct s2255_mode *old_mode;
 
1270         dprintk(4, "%s\n", __func__);
 
1271         if (fh->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) {
 
1272                 dev_err(&dev->udev->dev, "invalid fh type0\n");
 
1275         if (i != fh->type) {
 
1276                 dev_err(&dev->udev->dev, "invalid fh type1\n");
 
1280         if (!res_get(dev, fh)) {
 
1281                 dev_err(&dev->udev->dev, "s2255: stream busy\n");
 
1285         /* send a set mode command everytime with restart.
 
1286            in case we switch resolutions or other parameters */
 
1288         new_mode = &fh->mode;
 
1289         old_mode = &fh->dev->mode[chn];
 
1291         if (new_mode->color != old_mode->color)
 
1292                 new_mode->restart = 1;
 
1293         else if (new_mode->scale != old_mode->scale)
 
1294                 new_mode->restart = 1;
 
1295         else if (new_mode->format != old_mode->format)
 
1296                 new_mode->restart = 1;
 
1298         s2255_set_mode(dev, chn, new_mode);
 
1299         new_mode->restart = 0;
 
1300         *old_mode = *new_mode;
 
1301         dev->cur_fmt[chn] = fh->fmt;
 
1302         dprintk(1, "%s[%d]\n", __func__, chn);
 
1303         dev->last_frame[chn] = -1;
 
1304         dev->bad_payload[chn] = 0;
 
1305         dev->cur_frame[chn] = 0;
 
1306         dev->frame_count[chn] = 0;
 
1307         for (j = 0; j < SYS_FRAMES; j++) {
 
1308                 dev->buffer[chn].frame[j].ulState = S2255_READ_IDLE;
 
1309                 dev->buffer[chn].frame[j].cur_size = 0;
 
1311         res = videobuf_streamon(&fh->vb_vidq);
 
1313                 s2255_start_acquire(dev, chn);
 
1314                 dev->b_acquire[chn] = 1;
 
1321 static int vidioc_streamoff(struct file *file, void *priv, enum v4l2_buf_type i)
 
1324         struct s2255_fh *fh = priv;
 
1325         struct s2255_dev *dev = fh->dev;
 
1327         dprintk(4, "%s\n, channel: %d", __func__, fh->channel);
 
1328         if (fh->type != V4L2_BUF_TYPE_VIDEO_CAPTURE) {
 
1329                 printk(KERN_ERR "invalid fh type0\n");
 
1332         if (i != fh->type) {
 
1333                 printk(KERN_ERR "invalid type i\n");
 
1336         s2255_stop_acquire(dev, fh->channel);
 
1337         res = videobuf_streamoff(&fh->vb_vidq);
 
1344 static int vidioc_s_std(struct file *file, void *priv, v4l2_std_id *i)
 
1346         struct s2255_fh *fh = priv;
 
1347         struct s2255_mode *mode;
 
1348         struct videobuf_queue *q = &fh->vb_vidq;
 
1351         mutex_lock(&q->vb_lock);
 
1352         if (videobuf_queue_is_busy(q)) {
 
1353                 dprintk(1, "queue busy\n");
 
1358         if (res_locked(fh->dev, fh)) {
 
1359                 dprintk(1, "can't change standard after started\n");
 
1365         if (*i & V4L2_STD_NTSC) {
 
1366                 dprintk(4, "vidioc_s_std NTSC\n");
 
1367                 mode->format = FORMAT_NTSC;
 
1368         } else if (*i & V4L2_STD_PAL) {
 
1369                 dprintk(4, "vidioc_s_std PAL\n");
 
1370                 mode->format = FORMAT_PAL;
 
1375         mutex_unlock(&q->vb_lock);
 
1379 /* Sensoray 2255 is a multiple channel capture device.
 
1380    It does not have a "crossbar" of inputs.
 
1381    We use one V4L device per channel. The user must
 
1382    be aware that certain combinations are not allowed.
 
1383    For instance, you cannot do full FPS on more than 2 channels(2 videodevs)
 
1384    at once in color(you can do full fps on 4 channels with greyscale.
 
1386 static int vidioc_enum_input(struct file *file, void *priv,
 
1387                              struct v4l2_input *inp)
 
1389         if (inp->index != 0)
 
1392         inp->type = V4L2_INPUT_TYPE_CAMERA;
 
1393         inp->std = S2255_NORMS;
 
1394         strlcpy(inp->name, "Camera", sizeof(inp->name));
 
1398 static int vidioc_g_input(struct file *file, void *priv, unsigned int *i)
 
1403 static int vidioc_s_input(struct file *file, void *priv, unsigned int i)
 
1410 /* --- controls ---------------------------------------------- */
 
1411 static int vidioc_queryctrl(struct file *file, void *priv,
 
1412                             struct v4l2_queryctrl *qc)
 
1416         for (i = 0; i < ARRAY_SIZE(s2255_qctrl); i++)
 
1417                 if (qc->id && qc->id == s2255_qctrl[i].id) {
 
1418                         memcpy(qc, &(s2255_qctrl[i]), sizeof(*qc));
 
1422         dprintk(4, "query_ctrl -EINVAL %d\n", qc->id);
 
1426 static int vidioc_g_ctrl(struct file *file, void *priv,
 
1427                          struct v4l2_control *ctrl)
 
1431         for (i = 0; i < ARRAY_SIZE(s2255_qctrl); i++)
 
1432                 if (ctrl->id == s2255_qctrl[i].id) {
 
1433                         ctrl->value = qctl_regs[i];
 
1436         dprintk(4, "g_ctrl -EINVAL\n");
 
1441 static int vidioc_s_ctrl(struct file *file, void *priv,
 
1442                          struct v4l2_control *ctrl)
 
1445         struct s2255_fh *fh = priv;
 
1446         struct s2255_dev *dev = fh->dev;
 
1447         struct s2255_mode *mode;
 
1449         dprintk(4, "vidioc_s_ctrl\n");
 
1450         for (i = 0; i < ARRAY_SIZE(s2255_qctrl); i++) {
 
1451                 if (ctrl->id == s2255_qctrl[i].id) {
 
1452                         if (ctrl->value < s2255_qctrl[i].minimum ||
 
1453                             ctrl->value > s2255_qctrl[i].maximum)
 
1456                         qctl_regs[i] = ctrl->value;
 
1457                         /* update the mode to the corresponding value */
 
1459                         case V4L2_CID_BRIGHTNESS:
 
1460                                 mode->bright = ctrl->value;
 
1462                         case V4L2_CID_CONTRAST:
 
1463                                 mode->contrast = ctrl->value;
 
1466                                 mode->hue = ctrl->value;
 
1468                         case V4L2_CID_SATURATION:
 
1469                                 mode->saturation = ctrl->value;
 
1473                         /* set mode here.  Note: stream does not need restarted.
 
1474                            some V4L programs restart stream unnecessarily
 
1477                         s2255_set_mode(dev, fh->channel, mode);
 
1484 static int vidioc_g_jpegcomp(struct file *file, void *priv,
 
1485                          struct v4l2_jpegcompression *jc)
 
1487         struct s2255_fh *fh = priv;
 
1488         struct s2255_dev *dev = fh->dev;
 
1489         *jc = dev->jc[fh->channel];
 
1490         dprintk(2, "getting jpegcompression, quality %d\n", jc->quality);
 
1494 static int vidioc_s_jpegcomp(struct file *file, void *priv,
 
1495                          struct v4l2_jpegcompression *jc)
 
1497         struct s2255_fh *fh = priv;
 
1498         struct s2255_dev *dev = fh->dev;
 
1499         if (jc->quality < 0 || jc->quality > 100)
 
1501         dev->jc[fh->channel].quality = jc->quality;
 
1502         dprintk(2, "setting jpeg quality %d\n", jc->quality);
 
1505 static int s2255_open(struct inode *inode, struct file *file)
 
1507         int minor = iminor(inode);
 
1508         struct s2255_dev *h, *dev = NULL;
 
1509         struct s2255_fh *fh;
 
1510         struct list_head *list;
 
1511         enum v4l2_buf_type type = 0;
 
1513         int cur_channel = -1;
 
1515         dprintk(1, "s2255: open called (minor=%d)\n", minor);
 
1518         list_for_each(list, &s2255_devlist) {
 
1519                 h = list_entry(list, struct s2255_dev, s2255_devlist);
 
1520                 for (i = 0; i < MAX_CHANNELS; i++) {
 
1521                         if (h->vdev[i]->minor == minor) {
 
1524                                 type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
 
1529         if ((NULL == dev) || (cur_channel == -1)) {
 
1531                 printk(KERN_INFO "s2255: openv4l no dev\n");
 
1535         if (atomic_read(&dev->fw_data->fw_state) == S2255_FW_DISCONNECTING) {
 
1537                 printk(KERN_INFO "disconnecting\n");
 
1540         kref_get(&dev->kref);
 
1541         mutex_lock(&dev->open_lock);
 
1543         dev->users[cur_channel]++;
 
1544         dprintk(4, "s2255: open_handles %d\n", dev->users[cur_channel]);
 
1546         switch (atomic_read(&dev->fw_data->fw_state)) {
 
1547         case S2255_FW_FAILED:
 
1548                 err("2255 firmware load failed. retrying.\n");
 
1549                 s2255_fwload_start(dev, 1);
 
1550                 wait_event_timeout(dev->fw_data->wait_fw,
 
1551                                    ((atomic_read(&dev->fw_data->fw_state)
 
1552                                      == S2255_FW_SUCCESS) ||
 
1553                                     (atomic_read(&dev->fw_data->fw_state)
 
1554                                      == S2255_FW_DISCONNECTING)),
 
1555                                    msecs_to_jiffies(S2255_LOAD_TIMEOUT));
 
1557         case S2255_FW_NOTLOADED:
 
1558         case S2255_FW_LOADED_DSPWAIT:
 
1559                 /* give S2255_LOAD_TIMEOUT time for firmware to load in case
 
1560                    driver loaded and then device immediately opened */
 
1561                 printk(KERN_INFO "%s waiting for firmware load\n", __func__);
 
1562                 wait_event_timeout(dev->fw_data->wait_fw,
 
1563                                    ((atomic_read(&dev->fw_data->fw_state)
 
1564                                      == S2255_FW_SUCCESS) ||
 
1565                                     (atomic_read(&dev->fw_data->fw_state)
 
1566                                      == S2255_FW_DISCONNECTING)),
 
1567                         msecs_to_jiffies(S2255_LOAD_TIMEOUT));
 
1569         case S2255_FW_SUCCESS:
 
1573         state = atomic_read(&dev->fw_data->fw_state);
 
1574         if (state != S2255_FW_SUCCESS) {
 
1577                 case S2255_FW_FAILED:
 
1578                         printk(KERN_INFO "2255 FW load failed. %d\n", state);
 
1581                 case S2255_FW_DISCONNECTING:
 
1582                         printk(KERN_INFO "%s: disconnecting\n", __func__);
 
1585                 case S2255_FW_LOADED_DSPWAIT:
 
1586                 case S2255_FW_NOTLOADED:
 
1587                         printk(KERN_INFO "%s: firmware not loaded yet"
 
1588                                "please try again later\n",
 
1593                         printk(KERN_INFO "%s: unknown state\n", __func__);
 
1597                 dev->users[cur_channel]--;
 
1598                 mutex_unlock(&dev->open_lock);
 
1599                 kref_put(&dev->kref, s2255_destroy);
 
1604         /* allocate + initialize per filehandle data */
 
1605         fh = kzalloc(sizeof(*fh), GFP_KERNEL);
 
1607                 dev->users[cur_channel]--;
 
1608                 mutex_unlock(&dev->open_lock);
 
1609                 kref_put(&dev->kref, s2255_destroy);
 
1614         file->private_data = fh;
 
1616         fh->type = V4L2_BUF_TYPE_VIDEO_CAPTURE;
 
1617         fh->mode = dev->mode[cur_channel];
 
1618         fh->fmt = dev->cur_fmt[cur_channel];
 
1619         /* default 4CIF NTSC */
 
1620         fh->width = LINE_SZ_4CIFS_NTSC;
 
1621         fh->height = NUM_LINES_4CIFS_NTSC * 2;
 
1622         fh->channel = cur_channel;
 
1624         /* configure channel to default state */
 
1625         if (!dev->chn_configured[cur_channel]) {
 
1626                 s2255_set_mode(dev, cur_channel, &fh->mode);
 
1627                 dev->chn_configured[cur_channel] = 1;
 
1631         /* Put all controls at a sane state */
 
1632         for (i = 0; i < ARRAY_SIZE(s2255_qctrl); i++)
 
1633                 qctl_regs[i] = s2255_qctrl[i].default_value;
 
1635         dprintk(1, "s2255drv: open minor=%d type=%s users=%d\n",
 
1636                 minor, v4l2_type_names[type], dev->users[cur_channel]);
 
1637         dprintk(2, "s2255drv: open: fh=0x%08lx, dev=0x%08lx, vidq=0x%08lx\n",
 
1638                 (unsigned long)fh, (unsigned long)dev,
 
1639                 (unsigned long)&dev->vidq[cur_channel]);
 
1640         dprintk(4, "s2255drv: open: list_empty active=%d\n",
 
1641                 list_empty(&dev->vidq[cur_channel].active));
 
1643         videobuf_queue_vmalloc_init(&fh->vb_vidq, &s2255_video_qops,
 
1646                                     V4L2_FIELD_INTERLACED,
 
1647                                     sizeof(struct s2255_buffer), fh);
 
1649         mutex_unlock(&dev->open_lock);
 
1655 static unsigned int s2255_poll(struct file *file,
 
1656                                struct poll_table_struct *wait)
 
1658         struct s2255_fh *fh = file->private_data;
 
1660         dprintk(100, "%s\n", __func__);
 
1662         if (V4L2_BUF_TYPE_VIDEO_CAPTURE != fh->type)
 
1665         rc = videobuf_poll_stream(file, &fh->vb_vidq, wait);
 
1669 static void s2255_destroy(struct kref *kref)
 
1671         struct s2255_dev *dev = to_s2255_dev(kref);
 
1672         struct list_head *list;
 
1675                 printk(KERN_ERR "s2255drv: kref problem\n");
 
1678         atomic_set(&dev->fw_data->fw_state, S2255_FW_DISCONNECTING);
 
1679         wake_up(&dev->fw_data->wait_fw);
 
1680         for (i = 0; i < MAX_CHANNELS; i++) {
 
1681                 dev->setmode_ready[i] = 1;
 
1682                 wake_up(&dev->wait_setmode[i]);
 
1684         mutex_lock(&dev->open_lock);
 
1685         /* reset the DSP so firmware can be reload next time */
 
1686         s2255_reset_dsppower(dev);
 
1687         s2255_exit_v4l(dev);
 
1688         /* board shutdown stops the read pipe if it is running */
 
1689         s2255_board_shutdown(dev);
 
1690         /* make sure firmware still not trying to load */
 
1691         del_timer(&dev->timer);  /* only started in .probe and .open */
 
1693         if (dev->fw_data->fw_urb) {
 
1694                 dprintk(2, "kill fw_urb\n");
 
1695                 usb_kill_urb(dev->fw_data->fw_urb);
 
1696                 usb_free_urb(dev->fw_data->fw_urb);
 
1697                 dev->fw_data->fw_urb = NULL;
 
1699         if (dev->fw_data->fw)
 
1700                 release_firmware(dev->fw_data->fw);
 
1701         kfree(dev->fw_data->pfw_data);
 
1702         kfree(dev->fw_data);
 
1703         usb_put_dev(dev->udev);
 
1704         dprintk(1, "%s", __func__);
 
1707         while (!list_empty(&s2255_devlist)) {
 
1708                 list = s2255_devlist.next;
 
1711         mutex_unlock(&dev->open_lock);
 
1714 static int s2255_close(struct inode *inode, struct file *file)
 
1716         struct s2255_fh *fh = file->private_data;
 
1717         struct s2255_dev *dev = fh->dev;
 
1718         int minor = iminor(inode);
 
1722         mutex_lock(&dev->open_lock);
 
1724         /* turn off stream */
 
1725         if (res_check(fh)) {
 
1726                 if (dev->b_acquire[fh->channel])
 
1727                         s2255_stop_acquire(dev, fh->channel);
 
1728                 videobuf_streamoff(&fh->vb_vidq);
 
1732         videobuf_mmap_free(&fh->vb_vidq);
 
1733         dev->users[fh->channel]--;
 
1735         mutex_unlock(&dev->open_lock);
 
1737         kref_put(&dev->kref, s2255_destroy);
 
1738         dprintk(1, "s2255: close called (minor=%d, users=%d)\n",
 
1739                 minor, dev->users[fh->channel]);
 
1744 static int s2255_mmap_v4l(struct file *file, struct vm_area_struct *vma)
 
1746         struct s2255_fh *fh = file->private_data;
 
1751         dprintk(4, "mmap called, vma=0x%08lx\n", (unsigned long)vma);
 
1753         ret = videobuf_mmap_mapper(&fh->vb_vidq, vma);
 
1755         dprintk(4, "vma start=0x%08lx, size=%ld, ret=%d\n",
 
1756                 (unsigned long)vma->vm_start,
 
1757                 (unsigned long)vma->vm_end - (unsigned long)vma->vm_start, ret);
 
1762 static const struct file_operations s2255_fops_v4l = {
 
1763         .owner = THIS_MODULE,
 
1765         .release = s2255_close,
 
1767         .ioctl = video_ioctl2,  /* V4L2 ioctl handler */
 
1768         .compat_ioctl = v4l_compat_ioctl32,
 
1769         .mmap = s2255_mmap_v4l,
 
1770         .llseek = no_llseek,
 
1773 static const struct v4l2_ioctl_ops s2255_ioctl_ops = {
 
1774         .vidioc_querycap = vidioc_querycap,
 
1775         .vidioc_enum_fmt_vid_cap = vidioc_enum_fmt_vid_cap,
 
1776         .vidioc_g_fmt_vid_cap = vidioc_g_fmt_vid_cap,
 
1777         .vidioc_try_fmt_vid_cap = vidioc_try_fmt_vid_cap,
 
1778         .vidioc_s_fmt_vid_cap = vidioc_s_fmt_vid_cap,
 
1779         .vidioc_reqbufs = vidioc_reqbufs,
 
1780         .vidioc_querybuf = vidioc_querybuf,
 
1781         .vidioc_qbuf = vidioc_qbuf,
 
1782         .vidioc_dqbuf = vidioc_dqbuf,
 
1783         .vidioc_s_std = vidioc_s_std,
 
1784         .vidioc_enum_input = vidioc_enum_input,
 
1785         .vidioc_g_input = vidioc_g_input,
 
1786         .vidioc_s_input = vidioc_s_input,
 
1787         .vidioc_queryctrl = vidioc_queryctrl,
 
1788         .vidioc_g_ctrl = vidioc_g_ctrl,
 
1789         .vidioc_s_ctrl = vidioc_s_ctrl,
 
1790         .vidioc_streamon = vidioc_streamon,
 
1791         .vidioc_streamoff = vidioc_streamoff,
 
1792 #ifdef CONFIG_VIDEO_V4L1_COMPAT
 
1793         .vidiocgmbuf = vidioc_cgmbuf,
 
1795         .vidioc_s_jpegcomp = vidioc_s_jpegcomp,
 
1796         .vidioc_g_jpegcomp = vidioc_g_jpegcomp,
 
1799 static struct video_device template = {
 
1801         .fops = &s2255_fops_v4l,
 
1802         .ioctl_ops = &s2255_ioctl_ops,
 
1804         .release = video_device_release,
 
1805         .tvnorms = S2255_NORMS,
 
1806         .current_norm = V4L2_STD_NTSC_M,
 
1809 static int s2255_probe_v4l(struct s2255_dev *dev)
 
1813         int cur_nr = video_nr;
 
1815         /* initialize all video 4 linux */
 
1816         list_add_tail(&dev->s2255_devlist, &s2255_devlist);
 
1817         /* register 4 video devices */
 
1818         for (i = 0; i < MAX_CHANNELS; i++) {
 
1819                 INIT_LIST_HEAD(&dev->vidq[i].active);
 
1820                 dev->vidq[i].dev = dev;
 
1821                 dev->vidq[i].channel = i;
 
1822                 dev->vidq[i].kthread = NULL;
 
1823                 /* register 4 video devices */
 
1824                 dev->vdev[i] = video_device_alloc();
 
1825                 memcpy(dev->vdev[i], &template, sizeof(struct video_device));
 
1826                 dev->vdev[i]->parent = &dev->interface->dev;
 
1828                         ret = video_register_device(dev->vdev[i],
 
1832                         ret = video_register_device(dev->vdev[i],
 
1835                 video_set_drvdata(dev->vdev[i], dev);
 
1838                         dev_err(&dev->udev->dev,
 
1839                                 "failed to register video device!\n");
 
1843         printk(KERN_INFO "Sensoray 2255 V4L driver\n");
 
1847 static void s2255_exit_v4l(struct s2255_dev *dev)
 
1851         for (i = 0; i < MAX_CHANNELS; i++) {
 
1852                 if (-1 != dev->vdev[i]->minor) {
 
1853                         video_unregister_device(dev->vdev[i]);
 
1854                         printk(KERN_INFO "s2255 unregistered\n");
 
1856                         video_device_release(dev->vdev[i]);
 
1857                         printk(KERN_INFO "s2255 released\n");
 
1862 /* this function moves the usb stream read pipe data
 
1863  * into the system buffers.
 
1864  * returns 0 on success, EAGAIN if more data to process( call this
 
1867  * Received frame structure:
 
1868  * bytes 0-3:  marker : 0x2255DA4AL (S2255_MARKER_FRAME)
 
1869  * bytes 4-7:  channel: 0-3
 
1870  * bytes 8-11: payload size:  size of the frame
 
1871  * bytes 12-payloadsize+12:  frame data
 
1873 static int save_frame(struct s2255_dev *dev, struct s2255_pipeinfo *pipe_info)
 
1879         unsigned long copy_size;
 
1882         struct s2255_framei *frm;
 
1883         unsigned char *pdata;
 
1885         dprintk(100, "buffer to user\n");
 
1887         idx = dev->cur_frame[dev->cc];
 
1888         frm = &dev->buffer[dev->cc].frame[idx];
 
1890         if (frm->ulState == S2255_READ_IDLE) {
 
1895                 /* search for marker codes */
 
1896                 pdata = (unsigned char *)pipe_info->transfer_buffer;
 
1897                 for (jj = 0; jj < (pipe_info->cur_transfer_size - 12); jj++) {
 
1898                         switch (*(s32 *) pdata) {
 
1899                         case S2255_MARKER_FRAME:
 
1900                                 pdword = (s32 *)pdata;
 
1901                                 dprintk(4, "found frame marker at offset:"
 
1902                                         " %d [%x %x]\n", jj, pdata[0],
 
1904                                 offset = jj + PREFIX_SIZE;
 
1907                                 if (cc >= MAX_CHANNELS) {
 
1913                                 dev->cc = G_chnmap[cc];
 
1914                                 payload =  pdword[3];
 
1915                                 if (payload > dev->req_image_size[dev->cc]) {
 
1916                                         dev->bad_payload[dev->cc]++;
 
1917                                         /* discard the bad frame */
 
1920                                 dev->pkt_size[dev->cc] = payload;
 
1921                                 dev->jpg_size[dev->cc] = pdword[4];
 
1923                         case S2255_MARKER_RESPONSE:
 
1924                                 pdword = (s32 *)pdata;
 
1925                                 pdata += DEF_USB_BLOCK;
 
1926                                 jj += DEF_USB_BLOCK;
 
1927                                 if (pdword[1] >= MAX_CHANNELS)
 
1929                                 cc = G_chnmap[pdword[1]];
 
1930                                 if (!(cc >= 0 && cc < MAX_CHANNELS))
 
1932                                 switch (pdword[2]) {
 
1934                                         /* check if channel valid */
 
1935                                         /* set mode ready */
 
1936                                         dev->setmode_ready[cc] = 1;
 
1937                                         wake_up(&dev->wait_setmode[cc]);
 
1938                                         dprintk(5, "setmode ready %d\n", cc);
 
1942                                         dev->chn_ready |= (1 << cc);
 
1943                                         if ((dev->chn_ready & 0x0f) != 0x0f)
 
1945                                         /* all channels ready */
 
1946                                         printk(KERN_INFO "s2255: fw loaded\n");
 
1947                                         atomic_set(&dev->fw_data->fw_state,
 
1949                                         wake_up(&dev->fw_data->wait_fw);
 
1952                                         printk(KERN_INFO "s2255 unknwn resp\n");
 
1966         idx = dev->cur_frame[dev->cc];
 
1967         frm = &dev->buffer[dev->cc].frame[idx];
 
1969         /* search done.  now find out if should be acquiring on this channel */
 
1970         if (!dev->b_acquire[dev->cc]) {
 
1971                 /* we found a frame, but this channel is turned off */
 
1972                 frm->ulState = S2255_READ_IDLE;
 
1976         if (frm->ulState == S2255_READ_IDLE) {
 
1977                 frm->ulState = S2255_READ_FRAME;
 
1981         /* skip the marker 512 bytes (and offset if out of sync) */
 
1982         psrc = (u8 *)pipe_info->transfer_buffer + offset;
 
1985         if (frm->lpvbits == NULL) {
 
1986                 dprintk(1, "s2255 frame buffer == NULL.%p %p %d %d",
 
1987                         frm, dev, dev->cc, idx);
 
1991         pdest = frm->lpvbits + frm->cur_size;
 
1993         copy_size = (pipe_info->cur_transfer_size - offset);
 
1995         size = dev->pkt_size[dev->cc] - PREFIX_SIZE;
 
1997         /* sanity check on pdest */
 
1998         if ((copy_size + frm->cur_size) < dev->req_image_size[dev->cc])
 
1999                 memcpy(pdest, psrc, copy_size);
 
2001         frm->cur_size += copy_size;
 
2002         dprintk(4, "cur_size size %lu size %lu \n", frm->cur_size, size);
 
2004         if (frm->cur_size >= size) {
 
2007                 dprintk(2, "****************[%d]Buffer[%d]full*************\n",
 
2009                 dev->last_frame[cc] = dev->cur_frame[cc];
 
2010                 dev->cur_frame[cc]++;
 
2011                 /* end of system frame ring buffer, start at zero */
 
2012                 if ((dev->cur_frame[cc] == SYS_FRAMES) ||
 
2013                     (dev->cur_frame[cc] == dev->buffer[cc].dwFrames))
 
2014                         dev->cur_frame[cc] = 0;
 
2016                 if (dev->b_acquire[cc])
 
2017                         s2255_got_frame(dev, cc, dev->jpg_size[cc]);
 
2018                 dev->frame_count[cc]++;
 
2019                 frm->ulState = S2255_READ_IDLE;
 
2023         /* done successfully */
 
2027 static void s2255_read_video_callback(struct s2255_dev *dev,
 
2028                                       struct s2255_pipeinfo *pipe_info)
 
2031         dprintk(50, "callback read video \n");
 
2033         if (dev->cc >= MAX_CHANNELS) {
 
2035                 dev_err(&dev->udev->dev, "invalid channel\n");
 
2038         /* otherwise copy to the system buffers */
 
2039         res = save_frame(dev, pipe_info);
 
2041                 dprintk(4, "s2255: read callback failed\n");
 
2043         dprintk(50, "callback read video done\n");
 
2047 static long s2255_vendor_req(struct s2255_dev *dev, unsigned char Request,
 
2048                              u16 Index, u16 Value, void *TransferBuffer,
 
2049                              s32 TransferBufferLength, int bOut)
 
2053                 r = usb_control_msg(dev->udev, usb_rcvctrlpipe(dev->udev, 0),
 
2055                                     USB_TYPE_VENDOR | USB_RECIP_DEVICE |
 
2057                                     Value, Index, TransferBuffer,
 
2058                                     TransferBufferLength, HZ * 5);
 
2060                 r = usb_control_msg(dev->udev, usb_sndctrlpipe(dev->udev, 0),
 
2061                                     Request, USB_TYPE_VENDOR | USB_RECIP_DEVICE,
 
2062                                     Value, Index, TransferBuffer,
 
2063                                     TransferBufferLength, HZ * 5);
 
2069  * retrieve FX2 firmware version. future use.
 
2070  * @param dev pointer to device extension
 
2071  * @return -1 for fail, else returns firmware version as an int(16 bits)
 
2073 static int s2255_get_fx2fw(struct s2255_dev *dev)
 
2077         unsigned char transBuffer[64];
 
2078         ret = s2255_vendor_req(dev, S2255_VR_FW, 0, 0, transBuffer, 2,
 
2081                 dprintk(2, "get fw error: %x\n", ret);
 
2082         fw = transBuffer[0] + (transBuffer[1] << 8);
 
2083         dprintk(2, "Get FW %x %x\n", transBuffer[0], transBuffer[1]);
 
2088  * Create the system ring buffer to copy frames into from the
 
2091 static int s2255_create_sys_buffers(struct s2255_dev *dev, unsigned long chn)
 
2094         unsigned long reqsize;
 
2095         dprintk(1, "create sys buffers\n");
 
2096         if (chn >= MAX_CHANNELS)
 
2099         dev->buffer[chn].dwFrames = SYS_FRAMES;
 
2101         /* always allocate maximum size(PAL) for system buffers */
 
2102         reqsize = SYS_FRAMES_MAXSIZE;
 
2104         if (reqsize > SYS_FRAMES_MAXSIZE)
 
2105                 reqsize = SYS_FRAMES_MAXSIZE;
 
2107         for (i = 0; i < SYS_FRAMES; i++) {
 
2108                 /* allocate the frames */
 
2109                 dev->buffer[chn].frame[i].lpvbits = vmalloc(reqsize);
 
2111                 dprintk(1, "valloc %p chan %lu, idx %lu, pdata %p\n",
 
2112                         &dev->buffer[chn].frame[i], chn, i,
 
2113                         dev->buffer[chn].frame[i].lpvbits);
 
2114                 dev->buffer[chn].frame[i].size = reqsize;
 
2115                 if (dev->buffer[chn].frame[i].lpvbits == NULL) {
 
2116                         printk(KERN_INFO "out of memory.  using less frames\n");
 
2117                         dev->buffer[chn].dwFrames = i;
 
2122         /* make sure internal states are set */
 
2123         for (i = 0; i < SYS_FRAMES; i++) {
 
2124                 dev->buffer[chn].frame[i].ulState = 0;
 
2125                 dev->buffer[chn].frame[i].cur_size = 0;
 
2128         dev->cur_frame[chn] = 0;
 
2129         dev->last_frame[chn] = -1;
 
2133 static int s2255_release_sys_buffers(struct s2255_dev *dev,
 
2134                                      unsigned long channel)
 
2137         dprintk(1, "release sys buffers\n");
 
2138         for (i = 0; i < SYS_FRAMES; i++) {
 
2139                 if (dev->buffer[channel].frame[i].lpvbits) {
 
2140                         dprintk(1, "vfree %p\n",
 
2141                                 dev->buffer[channel].frame[i].lpvbits);
 
2142                         vfree(dev->buffer[channel].frame[i].lpvbits);
 
2144                 dev->buffer[channel].frame[i].lpvbits = NULL;
 
2149 static int s2255_board_init(struct s2255_dev *dev)
 
2152         struct s2255_mode mode_def = DEF_MODEI_NTSC_CONT;
 
2154         dprintk(4, "board init: %p", dev);
 
2156         for (j = 0; j < MAX_PIPE_BUFFERS; j++) {
 
2157                 struct s2255_pipeinfo *pipe = &dev->pipes[j];
 
2159                 memset(pipe, 0, sizeof(*pipe));
 
2161                 pipe->cur_transfer_size = S2255_USB_XFER_SIZE;
 
2162                 pipe->max_transfer_size = S2255_USB_XFER_SIZE;
 
2164                 pipe->transfer_buffer = kzalloc(pipe->max_transfer_size,
 
2166                 if (pipe->transfer_buffer == NULL) {
 
2167                         dprintk(1, "out of memory!\n");
 
2173         /* query the firmware */
 
2174         fw_ver = s2255_get_fx2fw(dev);
 
2176         printk(KERN_INFO "2255 usb firmware version %d \n", fw_ver);
 
2177         if (fw_ver < CUR_USB_FWVER)
 
2178                 err("usb firmware not up to date %d\n", fw_ver);
 
2180         for (j = 0; j < MAX_CHANNELS; j++) {
 
2181                 dev->b_acquire[j] = 0;
 
2182                 dev->mode[j] = mode_def;
 
2183                 dev->jc[j].quality = S2255_DEF_JPEG_QUAL;
 
2184                 dev->cur_fmt[j] = &formats[0];
 
2185                 dev->mode[j].restart = 1;
 
2186                 dev->req_image_size[j] = get_transfer_size(&mode_def);
 
2187                 dev->frame_count[j] = 0;
 
2188                 /* create the system buffers */
 
2189                 s2255_create_sys_buffers(dev, j);
 
2191         /* start read pipe */
 
2192         s2255_start_readpipe(dev);
 
2194         dprintk(1, "S2255: board initialized\n");
 
2198 static int s2255_board_shutdown(struct s2255_dev *dev)
 
2202         dprintk(1, "S2255: board shutdown: %p", dev);
 
2204         for (i = 0; i < MAX_CHANNELS; i++) {
 
2205                 if (dev->b_acquire[i])
 
2206                         s2255_stop_acquire(dev, i);
 
2209         s2255_stop_readpipe(dev);
 
2211         for (i = 0; i < MAX_CHANNELS; i++)
 
2212                 s2255_release_sys_buffers(dev, i);
 
2214         /* release transfer buffers */
 
2215         for (i = 0; i < MAX_PIPE_BUFFERS; i++) {
 
2216                 struct s2255_pipeinfo *pipe = &dev->pipes[i];
 
2217                 kfree(pipe->transfer_buffer);
 
2222 static void read_pipe_completion(struct urb *purb)
 
2224         struct s2255_pipeinfo *pipe_info;
 
2225         struct s2255_dev *dev;
 
2229         pipe_info = purb->context;
 
2230         dprintk(100, "read pipe completion %p, status %d\n", purb,
 
2232         if (pipe_info == NULL) {
 
2233                 err("no context !");
 
2237         dev = pipe_info->dev;
 
2239                 err("no context !");
 
2242         status = purb->status;
 
2244                 dprintk(2, "read_pipe_completion: err\n");
 
2248         if (pipe_info->state == 0) {
 
2249                 dprintk(2, "exiting USB pipe");
 
2253         s2255_read_video_callback(dev, pipe_info);
 
2255         pipe_info->err_count = 0;
 
2256         pipe = usb_rcvbulkpipe(dev->udev, dev->read_endpoint);
 
2258         usb_fill_bulk_urb(pipe_info->stream_urb, dev->udev,
 
2260                           pipe_info->transfer_buffer,
 
2261                           pipe_info->cur_transfer_size,
 
2262                           read_pipe_completion, pipe_info);
 
2264         if (pipe_info->state != 0) {
 
2265                 if (usb_submit_urb(pipe_info->stream_urb, GFP_KERNEL)) {
 
2266                         dev_err(&dev->udev->dev, "error submitting urb\n");
 
2267                         usb_free_urb(pipe_info->stream_urb);
 
2270                 dprintk(2, "read pipe complete state 0\n");
 
2275 static int s2255_start_readpipe(struct s2255_dev *dev)
 
2280         struct s2255_pipeinfo *pipe_info = dev->pipes;
 
2281         pipe = usb_rcvbulkpipe(dev->udev, dev->read_endpoint);
 
2282         dprintk(2, "start pipe IN %d\n", dev->read_endpoint);
 
2284         for (i = 0; i < MAX_PIPE_BUFFERS; i++) {
 
2285                 pipe_info->state = 1;
 
2286                 pipe_info->buf_index = (u32) i;
 
2287                 pipe_info->priority_set = 0;
 
2288                 pipe_info->stream_urb = usb_alloc_urb(0, GFP_KERNEL);
 
2289                 if (!pipe_info->stream_urb) {
 
2290                         dev_err(&dev->udev->dev,
 
2291                                 "ReadStream: Unable to alloc URB");
 
2294                 /* transfer buffer allocated in board_init */
 
2295                 usb_fill_bulk_urb(pipe_info->stream_urb, dev->udev,
 
2297                                   pipe_info->transfer_buffer,
 
2298                                   pipe_info->cur_transfer_size,
 
2299                                   read_pipe_completion, pipe_info);
 
2301                 pipe_info->urb_size = sizeof(pipe_info->stream_urb);
 
2302                 dprintk(4, "submitting URB %p\n", pipe_info->stream_urb);
 
2303                 retval = usb_submit_urb(pipe_info->stream_urb, GFP_KERNEL);
 
2305                         printk(KERN_ERR "s2255: start read pipe failed\n");
 
2313 /* starts acquisition process */
 
2314 static int s2255_start_acquire(struct s2255_dev *dev, unsigned long chn)
 
2316         unsigned char *buffer;
 
2318         unsigned long chn_rev;
 
2320         if (chn >= MAX_CHANNELS) {
 
2321                 dprintk(2, "start acquire failed, bad channel %lu\n", chn);
 
2325         chn_rev = G_chnmap[chn];
 
2326         dprintk(1, "S2255: start acquire %lu \n", chn);
 
2328         buffer = kzalloc(512, GFP_KERNEL);
 
2329         if (buffer == NULL) {
 
2330                 dev_err(&dev->udev->dev, "out of mem\n");
 
2334         dev->last_frame[chn] = -1;
 
2335         dev->bad_payload[chn] = 0;
 
2336         dev->cur_frame[chn] = 0;
 
2337         for (j = 0; j < SYS_FRAMES; j++) {
 
2338                 dev->buffer[chn].frame[j].ulState = 0;
 
2339                 dev->buffer[chn].frame[j].cur_size = 0;
 
2342         /* send the start command */
 
2343         *(u32 *) buffer = IN_DATA_TOKEN;
 
2344         *((u32 *) buffer + 1) = (u32) chn_rev;
 
2345         *((u32 *) buffer + 2) = (u32) CMD_START;
 
2346         res = s2255_write_config(dev->udev, (unsigned char *)buffer, 512);
 
2348                 dev_err(&dev->udev->dev, "CMD_START error\n");
 
2350         dprintk(2, "start acquire exit[%lu] %d \n", chn, res);
 
2355 static int s2255_stop_acquire(struct s2255_dev *dev, unsigned long chn)
 
2357         unsigned char *buffer;
 
2359         unsigned long chn_rev;
 
2361         if (chn >= MAX_CHANNELS) {
 
2362                 dprintk(2, "stop acquire failed, bad channel %lu\n", chn);
 
2365         chn_rev = G_chnmap[chn];
 
2367         buffer = kzalloc(512, GFP_KERNEL);
 
2368         if (buffer == NULL) {
 
2369                 dev_err(&dev->udev->dev, "out of mem\n");
 
2373         /* send the stop command */
 
2374         dprintk(4, "stop acquire %lu\n", chn);
 
2375         *(u32 *) buffer = IN_DATA_TOKEN;
 
2376         *((u32 *) buffer + 1) = (u32) chn_rev;
 
2377         *((u32 *) buffer + 2) = CMD_STOP;
 
2378         res = s2255_write_config(dev->udev, (unsigned char *)buffer, 512);
 
2381                 dev_err(&dev->udev->dev, "CMD_STOP error\n");
 
2383         dprintk(4, "stop acquire: releasing states \n");
 
2386         dev->b_acquire[chn] = 0;
 
2391 static void s2255_stop_readpipe(struct s2255_dev *dev)
 
2396                 err("s2255: invalid device");
 
2399         dprintk(4, "stop read pipe\n");
 
2400         for (j = 0; j < MAX_PIPE_BUFFERS; j++) {
 
2401                 struct s2255_pipeinfo *pipe_info = &dev->pipes[j];
 
2403                         if (pipe_info->state == 0)
 
2405                         pipe_info->state = 0;
 
2406                         pipe_info->prev_state = 1;
 
2411         for (j = 0; j < MAX_PIPE_BUFFERS; j++) {
 
2412                 struct s2255_pipeinfo *pipe_info = &dev->pipes[j];
 
2413                 if (pipe_info->stream_urb) {
 
2415                         usb_kill_urb(pipe_info->stream_urb);
 
2416                         usb_free_urb(pipe_info->stream_urb);
 
2417                         pipe_info->stream_urb = NULL;
 
2420         dprintk(2, "s2255 stop read pipe: %d\n", j);
 
2424 static void s2255_fwload_start(struct s2255_dev *dev, int reset)
 
2427                 s2255_reset_dsppower(dev);
 
2428         dev->fw_data->fw_size = dev->fw_data->fw->size;
 
2429         atomic_set(&dev->fw_data->fw_state, S2255_FW_NOTLOADED);
 
2430         memcpy(dev->fw_data->pfw_data,
 
2431                dev->fw_data->fw->data, CHUNK_SIZE);
 
2432         dev->fw_data->fw_loaded = CHUNK_SIZE;
 
2433         usb_fill_bulk_urb(dev->fw_data->fw_urb, dev->udev,
 
2434                           usb_sndbulkpipe(dev->udev, 2),
 
2435                           dev->fw_data->pfw_data,
 
2436                           CHUNK_SIZE, s2255_fwchunk_complete,
 
2438         mod_timer(&dev->timer, jiffies + HZ);
 
2441 /* standard usb probe function */
 
2442 static int s2255_probe(struct usb_interface *interface,
 
2443                        const struct usb_device_id *id)
 
2445         struct s2255_dev *dev = NULL;
 
2446         struct usb_host_interface *iface_desc;
 
2447         struct usb_endpoint_descriptor *endpoint;
 
2449         int retval = -ENOMEM;
 
2453         dprintk(2, "s2255: probe\n");
 
2455         /* allocate memory for our device state and initialize it to zero */
 
2456         dev = kzalloc(sizeof(struct s2255_dev), GFP_KERNEL);
 
2458                 err("s2255: out of memory");
 
2462         dev->fw_data = kzalloc(sizeof(struct s2255_fw), GFP_KERNEL);
 
2466         mutex_init(&dev->lock);
 
2467         mutex_init(&dev->open_lock);
 
2469         /* grab usb_device and save it */
 
2470         dev->udev = usb_get_dev(interface_to_usbdev(interface));
 
2471         if (dev->udev == NULL) {
 
2472                 dev_err(&interface->dev, "null usb device\n");
 
2476         kref_init(&dev->kref);
 
2477         dprintk(1, "dev: %p, kref: %p udev %p interface %p\n", dev, &dev->kref,
 
2478                 dev->udev, interface);
 
2479         dev->interface = interface;
 
2480         /* set up the endpoint information  */
 
2481         iface_desc = interface->cur_altsetting;
 
2482         dprintk(1, "num endpoints %d\n", iface_desc->desc.bNumEndpoints);
 
2483         for (i = 0; i < iface_desc->desc.bNumEndpoints; ++i) {
 
2484                 endpoint = &iface_desc->endpoint[i].desc;
 
2485                 if (!dev->read_endpoint && usb_endpoint_is_bulk_in(endpoint)) {
 
2486                         /* we found the bulk in endpoint */
 
2487                         dev->read_endpoint = endpoint->bEndpointAddress;
 
2491         if (!dev->read_endpoint) {
 
2492                 dev_err(&interface->dev, "Could not find bulk-in endpoint");
 
2497         usb_set_intfdata(interface, dev);
 
2499         dprintk(100, "after intfdata %p\n", dev);
 
2501         init_timer(&dev->timer);
 
2502         dev->timer.function = s2255_timer;
 
2503         dev->timer.data = (unsigned long)dev->fw_data;
 
2505         init_waitqueue_head(&dev->fw_data->wait_fw);
 
2506         for (i = 0; i < MAX_CHANNELS; i++)
 
2507                 init_waitqueue_head(&dev->wait_setmode[i]);
 
2510         dev->fw_data->fw_urb = usb_alloc_urb(0, GFP_KERNEL);
 
2512         if (!dev->fw_data->fw_urb) {
 
2513                 dev_err(&interface->dev, "out of memory!\n");
 
2516         dev->fw_data->pfw_data = kzalloc(CHUNK_SIZE, GFP_KERNEL);
 
2517         if (!dev->fw_data->pfw_data) {
 
2518                 dev_err(&interface->dev, "out of memory!\n");
 
2521         /* load the first chunk */
 
2522         if (request_firmware(&dev->fw_data->fw,
 
2523                              FIRMWARE_FILE_NAME, &dev->udev->dev)) {
 
2524                 printk(KERN_ERR "sensoray 2255 failed to get firmware\n");
 
2527         /* check the firmware is valid */
 
2528         fw_size = dev->fw_data->fw->size;
 
2529         pdata = (__le32 *) &dev->fw_data->fw->data[fw_size - 8];
 
2531         if (*pdata != S2255_FW_MARKER) {
 
2532                 printk(KERN_INFO "Firmware invalid.\n");
 
2536                 /* make sure firmware is the latest */
 
2538                 pRel = (__le32 *) &dev->fw_data->fw->data[fw_size - 4];
 
2539                 printk(KERN_INFO "s2255 dsp fw version %x\n", *pRel);
 
2541         /* loads v4l specific */
 
2542         s2255_probe_v4l(dev);
 
2543         usb_reset_device(dev->udev);
 
2544         /* load 2255 board specific */
 
2545         s2255_board_init(dev);
 
2547         dprintk(4, "before probe done %p\n", dev);
 
2548         spin_lock_init(&dev->slock);
 
2550         s2255_fwload_start(dev, 0);
 
2551         dev_info(&interface->dev, "Sensoray 2255 detected\n");
 
2557 /* disconnect routine. when board is removed physically or with rmmod */
 
2558 static void s2255_disconnect(struct usb_interface *interface)
 
2560         struct s2255_dev *dev = NULL;
 
2562         dprintk(1, "s2255: disconnect interface %p\n", interface);
 
2563         dev = usb_get_intfdata(interface);
 
2566          * wake up any of the timers to allow open_lock to be
 
2569         atomic_set(&dev->fw_data->fw_state, S2255_FW_DISCONNECTING);
 
2570         wake_up(&dev->fw_data->wait_fw);
 
2571         for (i = 0; i < MAX_CHANNELS; i++) {
 
2572                 dev->setmode_ready[i] = 1;
 
2573                 wake_up(&dev->wait_setmode[i]);
 
2576         mutex_lock(&dev->open_lock);
 
2577         usb_set_intfdata(interface, NULL);
 
2578         mutex_unlock(&dev->open_lock);
 
2581                 kref_put(&dev->kref, s2255_destroy);
 
2582                 dprintk(1, "s2255drv: disconnect\n");
 
2583                 dev_info(&interface->dev, "s2255usb now disconnected\n");
 
2587 static struct usb_driver s2255_driver = {
 
2589         .probe = s2255_probe,
 
2590         .disconnect = s2255_disconnect,
 
2591         .id_table = s2255_table,
 
2594 static int __init usb_s2255_init(void)
 
2598         /* register this driver with the USB subsystem */
 
2599         result = usb_register(&s2255_driver);
 
2602                 err("usb_register failed. Error number %d", result);
 
2604         dprintk(2, "s2255_init: done\n");
 
2608 static void __exit usb_s2255_exit(void)
 
2610         usb_deregister(&s2255_driver);
 
2613 module_init(usb_s2255_init);
 
2614 module_exit(usb_s2255_exit);
 
2616 MODULE_DESCRIPTION("Sensoray 2255 Video for Linux driver");
 
2617 MODULE_AUTHOR("Dean Anderson (Sensoray Company Inc.)");
 
2618 MODULE_LICENSE("GPL");