2 * Copyright (C) 2010 Bluecherry, LLC www.bluecherrydvr.com
3 * Copyright (C) 2010 Ben Collins <bcollins@bluecherry.net>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
20 #include <linux/kernel.h>
21 #include <linux/module.h>
22 #include <linux/kthread.h>
23 #include <linux/freezer.h>
24 #include <media/v4l2-ioctl.h>
25 #include <media/v4l2-common.h>
26 #include <media/videobuf-dma-sg.h>
29 #include "solo6x10-jpeg.h"
31 #define MIN_VID_BUFFERS 4
32 #define FRAME_BUF_SIZE (128 * 1024)
35 static int solo_enc_thread(void *data
);
37 extern unsigned video_nr
;
40 struct solo_enc_dev
*enc
;
44 enum solo_enc_types type
;
45 struct videobuf_queue vidq
;
46 struct list_head vidq_active
;
47 struct task_struct
*kthread
;
48 struct p2m_desc desc
[SOLO_NR_P2M_DESC
];
51 static const u32 solo_user_ctrls
[] = {
60 static const u32 solo_mpeg_ctrls
[] = {
61 V4L2_CID_MPEG_VIDEO_ENCODING
,
62 V4L2_CID_MPEG_VIDEO_GOP_SIZE
,
66 static const u32 solo_private_ctrls
[] = {
67 V4L2_CID_MOTION_ENABLE
,
68 V4L2_CID_MOTION_THRESHOLD
,
72 static const u32 solo_fmtx_ctrls
[] = {
73 V4L2_CID_RDS_TX_RADIO_TEXT
,
77 static const u32
*solo_ctrl_classes
[] = {
85 static int solo_is_motion_on(struct solo_enc_dev
*solo_enc
)
87 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
90 if (solo_dev
->motion_mask
& (1 << ch
))
95 static void solo_motion_toggle(struct solo_enc_dev
*solo_enc
, int on
)
97 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
100 spin_lock(&solo_enc
->lock
);
103 solo_dev
->motion_mask
|= (1 << ch
);
105 solo_dev
->motion_mask
&= ~(1 << ch
);
107 /* Do this regardless of if we are turning on or off */
108 solo_reg_write(solo_enc
->solo_dev
, SOLO_VI_MOT_CLEAR
,
110 solo_enc
->motion_detected
= 0;
112 solo_reg_write(solo_dev
, SOLO_VI_MOT_ADR
,
113 SOLO_VI_MOTION_EN(solo_dev
->motion_mask
) |
114 (SOLO_MOTION_EXT_ADDR(solo_dev
) >> 16));
116 if (solo_dev
->motion_mask
)
117 solo_irq_on(solo_dev
, SOLO_IRQ_MOTION
);
119 solo_irq_off(solo_dev
, SOLO_IRQ_MOTION
);
121 spin_unlock(&solo_enc
->lock
);
124 /* Should be called with solo_enc->lock held */
125 static void solo_update_mode(struct solo_enc_dev
*solo_enc
)
127 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
129 assert_spin_locked(&solo_enc
->lock
);
131 solo_enc
->interlaced
= (solo_enc
->mode
& 0x08) ? 1 : 0;
132 solo_enc
->bw_weight
= max(solo_dev
->fps
/ solo_enc
->interval
, 1);
134 switch (solo_enc
->mode
) {
135 case SOLO_ENC_MODE_CIF
:
136 solo_enc
->width
= solo_dev
->video_hsize
>> 1;
137 solo_enc
->height
= solo_dev
->video_vsize
;
139 case SOLO_ENC_MODE_D1
:
140 solo_enc
->width
= solo_dev
->video_hsize
;
141 solo_enc
->height
= solo_dev
->video_vsize
<< 1;
142 solo_enc
->bw_weight
<<= 2;
145 WARN(1, "mode is unknown\n");
149 /* Should be called with solo_enc->lock held */
150 static int solo_enc_on(struct solo_enc_fh
*fh
)
152 struct solo_enc_dev
*solo_enc
= fh
->enc
;
153 u8 ch
= solo_enc
->ch
;
154 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
157 assert_spin_locked(&solo_enc
->lock
);
162 solo_update_mode(solo_enc
);
164 /* Make sure to bw check on first reader */
165 if (!atomic_read(&solo_enc
->readers
)) {
166 if (solo_enc
->bw_weight
> solo_dev
->enc_bw_remain
)
169 solo_dev
->enc_bw_remain
-= solo_enc
->bw_weight
;
173 fh
->rd_idx
= solo_enc
->solo_dev
->enc_wr_idx
;
175 if (fh
->type
== SOLO_ENC_TYPE_EXT
)
176 solo_reg_write(solo_dev
, SOLO_CAP_CH_COMP_ENA_E(ch
), 1);
178 if (atomic_inc_return(&solo_enc
->readers
) > 1)
181 /* Disable all encoding for this channel */
182 solo_reg_write(solo_dev
, SOLO_CAP_CH_SCALE(ch
), 0);
184 /* Common for both std and ext encoding */
185 solo_reg_write(solo_dev
, SOLO_VE_CH_INTL(ch
),
186 solo_enc
->interlaced
? 1 : 0);
188 if (solo_enc
->interlaced
)
189 interval
= solo_enc
->interval
- 1;
191 interval
= solo_enc
->interval
;
193 /* Standard encoding only */
194 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP(ch
), solo_enc
->gop
);
195 solo_reg_write(solo_dev
, SOLO_VE_CH_QP(ch
), solo_enc
->qp
);
196 solo_reg_write(solo_dev
, SOLO_CAP_CH_INTV(ch
), interval
);
198 /* Extended encoding only */
199 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP_E(ch
), solo_enc
->gop
);
200 solo_reg_write(solo_dev
, SOLO_VE_CH_QP_E(ch
), solo_enc
->qp
);
201 solo_reg_write(solo_dev
, SOLO_CAP_CH_INTV_E(ch
), interval
);
203 /* Enables the standard encoder */
204 solo_reg_write(solo_dev
, SOLO_CAP_CH_SCALE(ch
), solo_enc
->mode
);
206 /* Settle down Beavis... */
212 static void solo_enc_off(struct solo_enc_fh
*fh
)
214 struct solo_enc_dev
*solo_enc
= fh
->enc
;
215 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
221 kthread_stop(fh
->kthread
);
225 solo_dev
->enc_bw_remain
+= solo_enc
->bw_weight
;
228 if (atomic_dec_return(&solo_enc
->readers
) > 0)
231 solo_reg_write(solo_dev
, SOLO_CAP_CH_SCALE(solo_enc
->ch
), 0);
232 solo_reg_write(solo_dev
, SOLO_CAP_CH_COMP_ENA_E(solo_enc
->ch
), 0);
235 static int solo_start_fh_thread(struct solo_enc_fh
*fh
)
237 struct solo_enc_dev
*solo_enc
= fh
->enc
;
239 fh
->kthread
= kthread_run(solo_enc_thread
, fh
, SOLO6X10_NAME
"_enc");
241 /* Oops, we had a problem */
242 if (IS_ERR(fh
->kthread
)) {
243 spin_lock(&solo_enc
->lock
);
245 spin_unlock(&solo_enc
->lock
);
247 return PTR_ERR(fh
->kthread
);
253 static void enc_reset_gop(struct solo_dev
*solo_dev
, u8 ch
)
255 BUG_ON(ch
>= solo_dev
->nr_chans
);
256 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP(ch
), 1);
257 solo_dev
->v4l2_enc
[ch
]->reset_gop
= 1;
260 static int enc_gop_reset(struct solo_dev
*solo_dev
, u8 ch
, u8 vop
)
262 BUG_ON(ch
>= solo_dev
->nr_chans
);
263 if (!solo_dev
->v4l2_enc
[ch
]->reset_gop
)
267 solo_dev
->v4l2_enc
[ch
]->reset_gop
= 0;
268 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP(ch
),
269 solo_dev
->v4l2_enc
[ch
]->gop
);
273 static void enc_write_sg(struct scatterlist
*sglist
, void *buf
, int size
)
275 struct scatterlist
*sg
;
278 for (sg
= sglist
; sg
&& size
> 0; sg
= sg_next(sg
)) {
280 size_t len
= sg_dma_len(sg
);
283 for (i
= 0; i
< len
&& size
; i
++)
288 static int enc_get_mpeg_dma_sg(struct solo_dev
*solo_dev
,
289 struct p2m_desc
*desc
,
290 struct scatterlist
*sglist
, int skip
,
291 unsigned int off
, unsigned int size
)
295 if (off
> SOLO_MP4E_EXT_SIZE(solo_dev
))
298 if (off
+ size
<= SOLO_MP4E_EXT_SIZE(solo_dev
)) {
299 return solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_MP4E
,
300 desc
, 0, sglist
, skip
,
301 SOLO_MP4E_EXT_ADDR(solo_dev
) + off
, size
);
305 ret
= solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_MP4E
, desc
, 0,
306 sglist
, skip
, SOLO_MP4E_EXT_ADDR(solo_dev
) + off
,
307 SOLO_MP4E_EXT_SIZE(solo_dev
) - off
);
309 ret
|= solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_MP4E
, desc
, 0,
310 sglist
, skip
+ SOLO_MP4E_EXT_SIZE(solo_dev
) - off
,
311 SOLO_MP4E_EXT_ADDR(solo_dev
),
312 size
+ off
- SOLO_MP4E_EXT_SIZE(solo_dev
));
317 static int enc_get_mpeg_dma_t(struct solo_dev
*solo_dev
,
318 dma_addr_t buf
, unsigned int off
,
323 if (off
> SOLO_MP4E_EXT_SIZE(solo_dev
))
326 if (off
+ size
<= SOLO_MP4E_EXT_SIZE(solo_dev
)) {
327 return solo_p2m_dma_t(solo_dev
, SOLO_P2M_DMA_ID_MP4E
, 0, buf
,
328 SOLO_MP4E_EXT_ADDR(solo_dev
) + off
, size
);
332 ret
= solo_p2m_dma_t(solo_dev
, SOLO_P2M_DMA_ID_MP4E
, 0, buf
,
333 SOLO_MP4E_EXT_ADDR(solo_dev
) + off
,
334 SOLO_MP4E_EXT_SIZE(solo_dev
) - off
);
336 ret
|= solo_p2m_dma_t(solo_dev
, SOLO_P2M_DMA_ID_MP4E
, 0,
337 buf
+ SOLO_MP4E_EXT_SIZE(solo_dev
) - off
,
338 SOLO_MP4E_EXT_ADDR(solo_dev
),
339 size
+ off
- SOLO_MP4E_EXT_SIZE(solo_dev
));
344 static int enc_get_mpeg_dma(struct solo_dev
*solo_dev
, void *buf
,
345 unsigned int off
, unsigned int size
)
349 dma_addr_t dma_addr
= pci_map_single(solo_dev
->pdev
, buf
, size
,
351 ret
= enc_get_mpeg_dma_t(solo_dev
, dma_addr
, off
, size
);
352 pci_unmap_single(solo_dev
->pdev
, dma_addr
, size
, PCI_DMA_FROMDEVICE
);
357 static int enc_get_jpeg_dma_sg(struct solo_dev
*solo_dev
,
358 struct p2m_desc
*desc
,
359 struct scatterlist
*sglist
, int skip
,
360 unsigned int off
, unsigned int size
)
364 if (off
> SOLO_JPEG_EXT_SIZE(solo_dev
))
367 if (off
+ size
<= SOLO_JPEG_EXT_SIZE(solo_dev
)) {
368 return solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_JPEG
,
369 desc
, 0, sglist
, skip
,
370 SOLO_JPEG_EXT_ADDR(solo_dev
) + off
, size
);
374 ret
= solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_JPEG
, desc
, 0,
375 sglist
, skip
, SOLO_JPEG_EXT_ADDR(solo_dev
) + off
,
376 SOLO_JPEG_EXT_SIZE(solo_dev
) - off
);
378 ret
|= solo_p2m_dma_sg(solo_dev
, SOLO_P2M_DMA_ID_JPEG
, desc
, 0,
379 sglist
, skip
+ SOLO_JPEG_EXT_SIZE(solo_dev
) - off
,
380 SOLO_JPEG_EXT_ADDR(solo_dev
),
381 size
+ off
- SOLO_JPEG_EXT_SIZE(solo_dev
));
386 /* Returns true of __chk is within the first __range bytes of __off */
387 #define OFF_IN_RANGE(__off, __range, __chk) \
388 ((__off <= __chk) && ((__off + __range) >= __chk))
390 static void solo_jpeg_header(struct solo_enc_dev
*solo_enc
,
391 struct videobuf_dmabuf
*vbuf
)
393 struct scatterlist
*sg
;
394 void *src
= jpeg_header
;
396 size_t to_copy
= sizeof(jpeg_header
);
398 for (sg
= vbuf
->sglist
; sg
&& copied
< to_copy
; sg
= sg_next(sg
)) {
399 size_t this_copy
= min(sg_dma_len(sg
),
400 (unsigned int)(to_copy
- copied
));
403 memcpy(p
, src
+ copied
, this_copy
);
405 if (OFF_IN_RANGE(copied
, this_copy
, SOF0_START
+ 5))
406 p
[(SOF0_START
+ 5) - copied
] =
407 0xff & (solo_enc
->height
>> 8);
408 if (OFF_IN_RANGE(copied
, this_copy
, SOF0_START
+ 6))
409 p
[(SOF0_START
+ 6) - copied
] = 0xff & solo_enc
->height
;
410 if (OFF_IN_RANGE(copied
, this_copy
, SOF0_START
+ 7))
411 p
[(SOF0_START
+ 7) - copied
] =
412 0xff & (solo_enc
->width
>> 8);
413 if (OFF_IN_RANGE(copied
, this_copy
, SOF0_START
+ 8))
414 p
[(SOF0_START
+ 8) - copied
] = 0xff & solo_enc
->width
;
420 static int solo_fill_jpeg(struct solo_enc_fh
*fh
, struct solo_enc_buf
*enc_buf
,
421 struct videobuf_buffer
*vb
,
422 struct videobuf_dmabuf
*vbuf
)
424 struct solo_dev
*solo_dev
= fh
->enc
->solo_dev
;
425 int size
= enc_buf
->jpeg_size
;
427 /* Copy the header first (direct write) */
428 solo_jpeg_header(fh
->enc
, vbuf
);
430 vb
->size
= size
+ sizeof(jpeg_header
);
432 /* Grab the jpeg frame */
433 return enc_get_jpeg_dma_sg(solo_dev
, fh
->desc
, vbuf
->sglist
,
435 enc_buf
->jpeg_off
, size
);
438 static inline int vop_interlaced(__le32
*vh
)
440 return (__le32_to_cpu(vh
[0]) >> 30) & 1;
443 static inline u32
vop_size(__le32
*vh
)
445 return __le32_to_cpu(vh
[0]) & 0xFFFFF;
448 static inline u8
vop_hsize(__le32
*vh
)
450 return (__le32_to_cpu(vh
[1]) >> 8) & 0xFF;
453 static inline u8
vop_vsize(__le32
*vh
)
455 return __le32_to_cpu(vh
[1]) & 0xFF;
458 /* must be called with *bits % 8 = 0 */
459 static void write_bytes(u8
**out
, unsigned *bits
, const u8
*src
, unsigned count
)
461 memcpy(*out
, src
, count
);
466 static void write_bits(u8
**out
, unsigned *bits
, u32 value
, unsigned count
)
469 value
<<= 32 - count
; // shift to the right
473 **out
|= !!(value
& (1 << 31)); /* MSB */
475 if (++(*bits
) % 8 == 0)
480 static void write_ue(u8
**out
, unsigned *bits
, unsigned value
) /* H.264 only */
482 uint32_t max
= 0, cnt
= 0;
484 while (value
> max
) {
485 max
= (max
+ 2) * 2 - 2;
488 write_bits(out
, bits
, 1, cnt
+ 1);
489 write_bits(out
, bits
, ~(max
- value
), cnt
);
492 static void write_se(u8
**out
, unsigned *bits
, int value
) /* H.264 only */
495 write_ue(out
, bits
, -value
* 2);
497 write_ue(out
, bits
, value
* 2 - 1);
500 static void write_mpeg4_end(u8
**out
, unsigned *bits
)
502 write_bits(out
, bits
, 0, 1);
503 /* align on 32-bit boundary */
505 write_bits(out
, bits
, 0xFFFFFFFF, 32 - *bits
% 32);
508 static void write_h264_end(u8
**out
, unsigned *bits
, int align
)
510 write_bits(out
, bits
, 1, 1);
512 write_bits(out
, bits
, 0, 1);
515 write_bits(out
, bits
, 0, 1);
518 static void mpeg4_write_vol(u8
**out
, struct solo_dev
*solo_dev
,
519 __le32
*vh
, unsigned fps
, unsigned interval
)
521 static const u8 hdr
[] = {
522 0, 0, 1, 0x00 /* video_object_start_code */,
523 0, 0, 1, 0x20 /* video_object_layer_start_code */
526 unsigned width
= vop_hsize(vh
) << 4;
527 unsigned height
= vop_vsize(vh
) << 4;
528 unsigned interlaced
= vop_interlaced(vh
);
530 write_bytes(out
, &bits
, hdr
, sizeof(hdr
));
531 write_bits(out
, &bits
, 0, 1); /* random_accessible_vol */
532 write_bits(out
, &bits
, 0x04, 8); /* video_object_type_indication: main */
533 write_bits(out
, &bits
, 1, 1); /* is_object_layer_identifier */
534 write_bits(out
, &bits
, 2, 4); /* video_object_layer_verid: table V2-39 */
535 write_bits(out
, &bits
, 0, 3); /* video_object_layer_priority */
536 if (solo_dev
->video_type
== SOLO_VO_FMT_TYPE_NTSC
)
537 write_bits(out
, &bits
, 3, 4); /* aspect_ratio_info, assuming 4:3 */
539 write_bits(out
, &bits
, 2, 4);
540 write_bits(out
, &bits
, 1, 1); /* vol_control_parameters */
541 write_bits(out
, &bits
, 1, 2); /* chroma_format: 4:2:0 */
542 write_bits(out
, &bits
, 1, 1); /* low_delay */
543 write_bits(out
, &bits
, 0, 1); /* vbv_parameters */
544 write_bits(out
, &bits
, 0, 2); /* video_object_layer_shape: rectangular */
545 write_bits(out
, &bits
, 1, 1); /* marker_bit */
546 write_bits(out
, &bits
, fps
, 16); /* vop_time_increment_resolution */
547 write_bits(out
, &bits
, 1, 1); /* marker_bit */
548 write_bits(out
, &bits
, 1, 1); /* fixed_vop_rate */
549 write_bits(out
, &bits
, interval
, 15); /* fixed_vop_time_increment */
550 write_bits(out
, &bits
, 1, 1); /* marker_bit */
551 write_bits(out
, &bits
, width
, 13); /* video_object_layer_width */
552 write_bits(out
, &bits
, 1, 1); /* marker_bit */
553 write_bits(out
, &bits
, height
, 13); /* video_object_layer_height */
554 write_bits(out
, &bits
, 1, 1); /* marker_bit */
555 write_bits(out
, &bits
, interlaced
, 1); /* interlaced */
556 write_bits(out
, &bits
, 1, 1); /* obmc_disable */
557 write_bits(out
, &bits
, 0, 2); /* sprite_enable */
558 write_bits(out
, &bits
, 0, 1); /* not_8_bit */
559 write_bits(out
, &bits
, 1, 0); /* quant_type */
560 write_bits(out
, &bits
, 0, 1); /* load_intra_quant_mat */
561 write_bits(out
, &bits
, 0, 1); /* load_nonintra_quant_mat */
562 write_bits(out
, &bits
, 0, 1); /* quarter_sample */
563 write_bits(out
, &bits
, 1, 1); /* complexity_estimation_disable */
564 write_bits(out
, &bits
, 1, 1); /* resync_marker_disable */
565 write_bits(out
, &bits
, 0, 1); /* data_partitioned */
566 write_bits(out
, &bits
, 0, 1); /* newpred_enable */
567 write_bits(out
, &bits
, 0, 1); /* reduced_resolution_vop_enable */
568 write_bits(out
, &bits
, 0, 1); /* scalability */
569 write_mpeg4_end(out
, &bits
);
572 static void h264_write_vol(u8
**out
, struct solo_dev
*solo_dev
, __le32
*vh
)
574 static const u8 sps
[] = {
575 0, 0, 0, 1 /* start code */, 0x67, 66 /* profile_idc */,
576 0 /* constraints */, 30 /* level_idc */
578 static const u8 pps
[] = {
579 0, 0, 0, 1 /* start code */, 0x68
583 unsigned mbs_w
= vop_hsize(vh
);
584 unsigned mbs_h
= vop_vsize(vh
);
586 write_bytes(out
, &bits
, sps
, sizeof(sps
));
587 write_ue(out
, &bits
, 0); /* seq_parameter_set_id */
588 write_ue(out
, &bits
, 5); /* log2_max_frame_num_minus4 */
589 write_ue(out
, &bits
, 0); /* pic_order_cnt_type */
590 write_ue(out
, &bits
, 6); /* log2_max_pic_order_cnt_lsb_minus4 */
591 write_ue(out
, &bits
, 1); /* max_num_ref_frames */
592 write_bits(out
, &bits
, 0, 1); /* gaps_in_frame_num_value_allowed_flag */
593 write_ue(out
, &bits
, mbs_w
- 1); /* pic_width_in_mbs_minus1 */
594 write_ue(out
, &bits
, mbs_h
- 1); /* pic_height_in_map_units_minus1 */
595 write_bits(out
, &bits
, 1, 1); /* frame_mbs_only_flag */
596 write_bits(out
, &bits
, 1, 1); /* direct_8x8_frame_field_flag */
597 write_bits(out
, &bits
, 0, 1); /* frame_cropping_flag */
598 write_bits(out
, &bits
, 0, 1); /* vui_parameters_present_flag */
599 write_h264_end(out
, &bits
, 0);
601 write_bytes(out
, &bits
, pps
, sizeof(pps
));
602 write_ue(out
, &bits
, 0); /* pic_parameter_set_id */
603 write_ue(out
, &bits
, 0); /* seq_parameter_set_id */
604 write_bits(out
, &bits
, 0, 1); /* entropy_coding_mode_flag */
605 write_bits(out
, &bits
, 0, 1); /* bottom_field_pic_order_in_frame_present_flag */
606 write_ue(out
, &bits
, 0); /* num_slice_groups_minus1 */
607 write_ue(out
, &bits
, 0); /* num_ref_idx_l0_default_active_minus1 */
608 write_ue(out
, &bits
, 0); /* num_ref_idx_l1_default_active_minus1 */
609 write_bits(out
, &bits
, 0, 1); /* weighted_pred_flag */
610 write_bits(out
, &bits
, 0, 2); /* weighted_bipred_idc */
611 write_se(out
, &bits
, 0); /* pic_init_qp_minus26 */
612 write_se(out
, &bits
, 0); /* pic_init_qs_minus26 */
613 write_se(out
, &bits
, 2); /* chroma_qp_index_offset */
614 write_bits(out
, &bits
, 0, 1); /* deblocking_filter_control_present_flag */
615 write_bits(out
, &bits
, 1, 1); /* constrained_intra_pred_flag */
616 write_bits(out
, &bits
, 0, 1); /* redundant_pic_cnt_present_flag */
617 write_h264_end(out
, &bits
, 1);
620 static int solo_fill_mpeg(struct solo_enc_fh
*fh
, struct solo_enc_buf
*enc_buf
,
621 struct videobuf_buffer
*vb
,
622 struct videobuf_dmabuf
*vbuf
)
624 struct solo_enc_dev
*solo_enc
= fh
->enc
;
625 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
628 #define MAX_VOL_HEADER_LENGTH 64
632 int frame_size
, frame_off
;
635 if (WARN_ON_ONCE(enc_buf
->size
<= sizeof(vh
)))
638 /* First get the hardware vop header (not real mpeg) */
639 ret
= enc_get_mpeg_dma(solo_dev
, vh
, enc_buf
->off
, sizeof(vh
));
640 if (WARN_ON_ONCE(ret
))
643 if (WARN_ON_ONCE(vop_size(vh
) > enc_buf
->size
))
646 vb
->width
= vop_hsize(vh
) << 4;
647 vb
->height
= vop_vsize(vh
) << 4;
648 vb
->size
= vop_size(vh
);
650 /* If this is a key frame, add extra m4v header */
652 u8 header
[MAX_VOL_HEADER_LENGTH
], *out
= header
;
654 if (solo_dev
->flags
& FLAGS_6110
)
655 h264_write_vol(&out
, solo_dev
, vh
);
657 mpeg4_write_vol(&out
, solo_dev
, vh
,
658 solo_dev
->fps
* 1000,
659 solo_enc
->interval
* 1000);
661 enc_write_sg(vbuf
->sglist
, header
, skip
);
662 /* Adjust the dma buffer past this header */
666 /* Now get the actual mpeg payload */
667 frame_off
= (enc_buf
->off
+ sizeof(vh
)) % SOLO_MP4E_EXT_SIZE(solo_dev
);
668 frame_size
= enc_buf
->size
- sizeof(vh
);
670 ret
= enc_get_mpeg_dma_sg(solo_dev
, fh
->desc
, vbuf
->sglist
,
671 skip
, frame_off
, frame_size
);
677 static void solo_enc_fillbuf(struct solo_enc_fh
*fh
,
678 struct videobuf_buffer
*vb
)
680 struct solo_enc_dev
*solo_enc
= fh
->enc
;
681 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
682 struct solo_enc_buf
*enc_buf
= NULL
;
683 struct videobuf_dmabuf
*vbuf
;
686 u16 idx
= fh
->rd_idx
;
688 while (idx
!= solo_dev
->enc_wr_idx
) {
689 struct solo_enc_buf
*ebuf
= &solo_dev
->enc_buf
[idx
];
691 idx
= (idx
+ 1) % SOLO_NR_RING_BUFS
;
693 if (ebuf
->ch
!= solo_enc
->ch
)
696 if (fh
->fmt
== V4L2_PIX_FMT_MPEG
) {
697 if (fh
->type
== ebuf
->type
) {
702 /* For mjpeg, keep reading to the newest frame */
709 if (WARN_ON_ONCE(!enc_buf
))
712 if ((fh
->fmt
== V4L2_PIX_FMT_MPEG
&&
713 vb
->bsize
< enc_buf
->size
) ||
714 (fh
->fmt
== V4L2_PIX_FMT_MJPEG
&&
715 vb
->bsize
< (enc_buf
->jpeg_size
+ sizeof(jpeg_header
)))) {
720 vbuf
= videobuf_to_dma(vb
);
721 if (WARN_ON_ONCE(!vbuf
))
724 if (fh
->fmt
== V4L2_PIX_FMT_MPEG
)
725 ret
= solo_fill_mpeg(fh
, enc_buf
, vb
, vbuf
);
727 ret
= solo_fill_jpeg(fh
, enc_buf
, vb
, vbuf
);
734 vb
->state
= VIDEOBUF_ERROR
;
737 vb
->ts
= enc_buf
->ts
;
738 vb
->state
= VIDEOBUF_DONE
;
746 static void solo_enc_thread_try(struct solo_enc_fh
*fh
)
748 struct solo_enc_dev
*solo_enc
= fh
->enc
;
749 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
750 struct videobuf_buffer
*vb
;
753 spin_lock(&solo_enc
->lock
);
755 if (fh
->rd_idx
== solo_dev
->enc_wr_idx
)
758 if (list_empty(&fh
->vidq_active
))
761 vb
= list_first_entry(&fh
->vidq_active
,
762 struct videobuf_buffer
, queue
);
764 if (!waitqueue_active(&vb
->done
))
767 list_del(&vb
->queue
);
769 spin_unlock(&solo_enc
->lock
);
771 solo_enc_fillbuf(fh
, vb
);
774 assert_spin_locked(&solo_enc
->lock
);
775 spin_unlock(&solo_enc
->lock
);
778 static int solo_enc_thread(void *data
)
780 struct solo_enc_fh
*fh
= data
;
781 struct solo_enc_dev
*solo_enc
= fh
->enc
;
782 DECLARE_WAITQUEUE(wait
, current
);
785 add_wait_queue(&solo_enc
->thread_wait
, &wait
);
788 long timeout
= schedule_timeout_interruptible(HZ
);
789 if (timeout
== -ERESTARTSYS
|| kthread_should_stop())
791 solo_enc_thread_try(fh
);
795 remove_wait_queue(&solo_enc
->thread_wait
, &wait
);
800 void solo_motion_isr(struct solo_dev
*solo_dev
)
805 solo_reg_write(solo_dev
, SOLO_IRQ_STAT
, SOLO_IRQ_MOTION
);
807 status
= solo_reg_read(solo_dev
, SOLO_VI_MOT_STATUS
);
809 for (i
= 0; i
< solo_dev
->nr_chans
; i
++) {
810 struct solo_enc_dev
*solo_enc
= solo_dev
->v4l2_enc
[i
];
812 BUG_ON(solo_enc
== NULL
);
814 if (solo_enc
->motion_detected
)
816 if (!(status
& (1 << i
)))
819 solo_enc
->motion_detected
= 1;
823 void solo_enc_v4l2_isr(struct solo_dev
*solo_dev
)
825 struct solo_enc_buf
*enc_buf
;
826 u32 mpeg_current
, mpeg_next
, mpeg_size
;
827 u32 jpeg_current
, jpeg_next
, jpeg_size
;
831 enum solo_enc_types enc_type
;
833 solo_reg_write(solo_dev
, SOLO_IRQ_STAT
, SOLO_IRQ_ENCODER
);
835 cur_q
= ((solo_reg_read(solo_dev
, SOLO_VE_STATE(11)) & 0xF) + 1) % MP4_QS
;
837 reg_mpeg_size
= ((solo_reg_read(solo_dev
, SOLO_VE_STATE(0)) & 0xFFFFF) + 64 + 8) & ~7;
839 while (solo_dev
->enc_idx
!= cur_q
) {
840 mpeg_current
= solo_reg_read(solo_dev
,
841 SOLO_VE_MPEG4_QUE(solo_dev
->enc_idx
));
842 jpeg_current
= solo_reg_read(solo_dev
,
843 SOLO_VE_JPEG_QUE(solo_dev
->enc_idx
));
844 solo_dev
->enc_idx
= (solo_dev
->enc_idx
+ 1) % MP4_QS
;
845 mpeg_next
= solo_reg_read(solo_dev
,
846 SOLO_VE_MPEG4_QUE(solo_dev
->enc_idx
));
847 jpeg_next
= solo_reg_read(solo_dev
,
848 SOLO_VE_JPEG_QUE(solo_dev
->enc_idx
));
850 ch
= (mpeg_current
>> 24) & 0x1f;
851 if (ch
>= SOLO_MAX_CHANNELS
) {
852 ch
-= SOLO_MAX_CHANNELS
;
853 enc_type
= SOLO_ENC_TYPE_EXT
;
855 enc_type
= SOLO_ENC_TYPE_STD
;
857 vop_type
= (mpeg_current
>> 29) & 3;
859 mpeg_current
&= 0x00ffffff;
860 mpeg_next
&= 0x00ffffff;
861 jpeg_current
&= 0x00ffffff;
862 jpeg_next
&= 0x00ffffff;
864 mpeg_size
= (SOLO_MP4E_EXT_SIZE(solo_dev
) +
865 mpeg_next
- mpeg_current
) %
866 SOLO_MP4E_EXT_SIZE(solo_dev
);
868 jpeg_size
= (SOLO_JPEG_EXT_SIZE(solo_dev
) +
869 jpeg_next
- jpeg_current
) %
870 SOLO_JPEG_EXT_SIZE(solo_dev
);
872 /* XXX I think this means we had a ring overflow? */
873 if (mpeg_current
> mpeg_next
&& mpeg_size
!= reg_mpeg_size
) {
874 enc_reset_gop(solo_dev
, ch
);
878 /* When resetting the GOP, skip frames until I-frame */
879 if (enc_gop_reset(solo_dev
, ch
, vop_type
))
882 enc_buf
= &solo_dev
->enc_buf
[solo_dev
->enc_wr_idx
];
884 enc_buf
->vop
= vop_type
;
886 enc_buf
->off
= mpeg_current
;
887 enc_buf
->size
= mpeg_size
;
888 enc_buf
->jpeg_off
= jpeg_current
;
889 enc_buf
->jpeg_size
= jpeg_size
;
890 enc_buf
->type
= enc_type
;
892 do_gettimeofday(&enc_buf
->ts
);
894 solo_dev
->enc_wr_idx
= (solo_dev
->enc_wr_idx
+ 1) %
897 wake_up_interruptible(&solo_dev
->v4l2_enc
[ch
]->thread_wait
);
903 static int solo_enc_buf_setup(struct videobuf_queue
*vq
, unsigned int *count
,
906 *size
= FRAME_BUF_SIZE
;
908 if (*count
< MIN_VID_BUFFERS
)
909 *count
= MIN_VID_BUFFERS
;
914 static int solo_enc_buf_prepare(struct videobuf_queue
*vq
,
915 struct videobuf_buffer
*vb
,
916 enum v4l2_field field
)
918 struct solo_enc_fh
*fh
= vq
->priv_data
;
919 struct solo_enc_dev
*solo_enc
= fh
->enc
;
921 vb
->size
= FRAME_BUF_SIZE
;
922 if (vb
->baddr
!= 0 && vb
->bsize
< vb
->size
)
925 /* These properties only change when queue is idle */
926 vb
->width
= solo_enc
->width
;
927 vb
->height
= solo_enc
->height
;
930 if (vb
->state
== VIDEOBUF_NEEDS_INIT
) {
931 int rc
= videobuf_iolock(vq
, vb
, NULL
);
933 struct videobuf_dmabuf
*dma
= videobuf_to_dma(vb
);
934 videobuf_dma_unmap(vq
->dev
, dma
);
935 videobuf_dma_free(dma
);
936 vb
->state
= VIDEOBUF_NEEDS_INIT
;
940 vb
->state
= VIDEOBUF_PREPARED
;
945 static void solo_enc_buf_queue(struct videobuf_queue
*vq
,
946 struct videobuf_buffer
*vb
)
948 struct solo_enc_fh
*fh
= vq
->priv_data
;
950 vb
->state
= VIDEOBUF_QUEUED
;
951 list_add_tail(&vb
->queue
, &fh
->vidq_active
);
952 wake_up_interruptible(&fh
->enc
->thread_wait
);
955 static void solo_enc_buf_release(struct videobuf_queue
*vq
,
956 struct videobuf_buffer
*vb
)
958 struct videobuf_dmabuf
*dma
= videobuf_to_dma(vb
);
960 videobuf_dma_unmap(vq
->dev
, dma
);
961 videobuf_dma_free(dma
);
962 vb
->state
= VIDEOBUF_NEEDS_INIT
;
965 static struct videobuf_queue_ops solo_enc_video_qops
= {
966 .buf_setup
= solo_enc_buf_setup
,
967 .buf_prepare
= solo_enc_buf_prepare
,
968 .buf_queue
= solo_enc_buf_queue
,
969 .buf_release
= solo_enc_buf_release
,
972 static unsigned int solo_enc_poll(struct file
*file
,
973 struct poll_table_struct
*wait
)
975 struct solo_enc_fh
*fh
= file
->private_data
;
977 return videobuf_poll_stream(file
, &fh
->vidq
, wait
);
980 static int solo_enc_mmap(struct file
*file
, struct vm_area_struct
*vma
)
982 struct solo_enc_fh
*fh
= file
->private_data
;
984 return videobuf_mmap_mapper(&fh
->vidq
, vma
);
987 static int solo_enc_open(struct file
*file
)
989 struct solo_enc_dev
*solo_enc
= video_drvdata(file
);
990 struct solo_enc_fh
*fh
;
992 fh
= kzalloc(sizeof(*fh
), GFP_KERNEL
);
997 file
->private_data
= fh
;
998 INIT_LIST_HEAD(&fh
->vidq_active
);
999 fh
->fmt
= V4L2_PIX_FMT_MPEG
;
1000 fh
->type
= SOLO_ENC_TYPE_STD
;
1002 videobuf_queue_sg_init(&fh
->vidq
, &solo_enc_video_qops
,
1003 &solo_enc
->solo_dev
->pdev
->dev
,
1005 V4L2_BUF_TYPE_VIDEO_CAPTURE
,
1006 V4L2_FIELD_INTERLACED
,
1007 sizeof(struct videobuf_buffer
), fh
, NULL
);
1012 static ssize_t
solo_enc_read(struct file
*file
, char __user
*data
,
1013 size_t count
, loff_t
*ppos
)
1015 struct solo_enc_fh
*fh
= file
->private_data
;
1016 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1018 /* Make sure the encoder is on */
1022 spin_lock(&solo_enc
->lock
);
1023 ret
= solo_enc_on(fh
);
1024 spin_unlock(&solo_enc
->lock
);
1028 ret
= solo_start_fh_thread(fh
);
1033 return videobuf_read_stream(&fh
->vidq
, data
, count
, ppos
, 0,
1034 file
->f_flags
& O_NONBLOCK
);
1037 static int solo_enc_release(struct file
*file
)
1039 struct solo_enc_fh
*fh
= file
->private_data
;
1040 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1042 videobuf_stop(&fh
->vidq
);
1043 videobuf_mmap_free(&fh
->vidq
);
1045 spin_lock(&solo_enc
->lock
);
1047 spin_unlock(&solo_enc
->lock
);
1054 static int solo_enc_querycap(struct file
*file
, void *priv
,
1055 struct v4l2_capability
*cap
)
1057 struct solo_enc_fh
*fh
= priv
;
1058 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1059 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1061 strcpy(cap
->driver
, SOLO6X10_NAME
);
1062 snprintf(cap
->card
, sizeof(cap
->card
), "Softlogic 6x10 Enc %d",
1064 snprintf(cap
->bus_info
, sizeof(cap
->bus_info
), "PCI %s",
1065 pci_name(solo_dev
->pdev
));
1066 cap
->version
= SOLO6X10_VER_NUM
;
1067 cap
->capabilities
= V4L2_CAP_VIDEO_CAPTURE
|
1068 V4L2_CAP_READWRITE
|
1073 static int solo_enc_enum_input(struct file
*file
, void *priv
,
1074 struct v4l2_input
*input
)
1076 struct solo_enc_fh
*fh
= priv
;
1077 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1078 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1083 snprintf(input
->name
, sizeof(input
->name
), "Encoder %d",
1085 input
->type
= V4L2_INPUT_TYPE_CAMERA
;
1087 if (solo_dev
->video_type
== SOLO_VO_FMT_TYPE_NTSC
)
1088 input
->std
= V4L2_STD_NTSC_M
;
1090 input
->std
= V4L2_STD_PAL_B
;
1092 if (!tw28_get_video_status(solo_dev
, solo_enc
->ch
))
1093 input
->status
= V4L2_IN_ST_NO_SIGNAL
;
1098 static int solo_enc_set_input(struct file
*file
, void *priv
, unsigned int index
)
1106 static int solo_enc_get_input(struct file
*file
, void *priv
,
1107 unsigned int *index
)
1114 static int solo_enc_enum_fmt_cap(struct file
*file
, void *priv
,
1115 struct v4l2_fmtdesc
*f
)
1119 f
->pixelformat
= V4L2_PIX_FMT_MPEG
;
1120 strcpy(f
->description
, "MPEG-4 AVC");
1123 f
->pixelformat
= V4L2_PIX_FMT_MJPEG
;
1124 strcpy(f
->description
, "MJPEG");
1130 f
->flags
= V4L2_FMT_FLAG_COMPRESSED
;
1135 static int solo_enc_try_fmt_cap(struct file
*file
, void *priv
,
1136 struct v4l2_format
*f
)
1138 struct solo_enc_fh
*fh
= priv
;
1139 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1140 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1141 struct v4l2_pix_format
*pix
= &f
->fmt
.pix
;
1143 if (pix
->pixelformat
!= V4L2_PIX_FMT_MPEG
&&
1144 pix
->pixelformat
!= V4L2_PIX_FMT_MJPEG
)
1147 /* We cannot change width/height in mid read */
1148 if (atomic_read(&solo_enc
->readers
) > 0) {
1149 if (pix
->width
!= solo_enc
->width
||
1150 pix
->height
!= solo_enc
->height
)
1154 if (pix
->width
< solo_dev
->video_hsize
||
1155 pix
->height
< solo_dev
->video_vsize
<< 1) {
1156 /* Default to CIF 1/2 size */
1157 pix
->width
= solo_dev
->video_hsize
>> 1;
1158 pix
->height
= solo_dev
->video_vsize
;
1161 pix
->width
= solo_dev
->video_hsize
;
1162 pix
->height
= solo_dev
->video_vsize
<< 1;
1165 if (pix
->field
== V4L2_FIELD_ANY
)
1166 pix
->field
= V4L2_FIELD_INTERLACED
;
1167 else if (pix
->field
!= V4L2_FIELD_INTERLACED
)
1168 pix
->field
= V4L2_FIELD_INTERLACED
;
1170 /* Just set these */
1171 pix
->colorspace
= V4L2_COLORSPACE_SMPTE170M
;
1172 pix
->sizeimage
= FRAME_BUF_SIZE
;
1177 static int solo_enc_set_fmt_cap(struct file
*file
, void *priv
,
1178 struct v4l2_format
*f
)
1180 struct solo_enc_fh
*fh
= priv
;
1181 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1182 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1183 struct v4l2_pix_format
*pix
= &f
->fmt
.pix
;
1186 spin_lock(&solo_enc
->lock
);
1188 ret
= solo_enc_try_fmt_cap(file
, priv
, f
);
1190 spin_unlock(&solo_enc
->lock
);
1194 if (pix
->width
== solo_dev
->video_hsize
)
1195 solo_enc
->mode
= SOLO_ENC_MODE_D1
;
1197 solo_enc
->mode
= SOLO_ENC_MODE_CIF
;
1199 /* This does not change the encoder at all */
1200 fh
->fmt
= pix
->pixelformat
;
1203 fh
->type
= SOLO_ENC_TYPE_EXT
;
1204 ret
= solo_enc_on(fh
);
1206 spin_unlock(&solo_enc
->lock
);
1211 return solo_start_fh_thread(fh
);
1214 static int solo_enc_get_fmt_cap(struct file
*file
, void *priv
,
1215 struct v4l2_format
*f
)
1217 struct solo_enc_fh
*fh
= priv
;
1218 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1219 struct v4l2_pix_format
*pix
= &f
->fmt
.pix
;
1221 pix
->width
= solo_enc
->width
;
1222 pix
->height
= solo_enc
->height
;
1223 pix
->pixelformat
= fh
->fmt
;
1224 pix
->field
= solo_enc
->interlaced
? V4L2_FIELD_INTERLACED
:
1226 pix
->sizeimage
= FRAME_BUF_SIZE
;
1227 pix
->colorspace
= V4L2_COLORSPACE_SMPTE170M
;
1232 static int solo_enc_reqbufs(struct file
*file
, void *priv
,
1233 struct v4l2_requestbuffers
*req
)
1235 struct solo_enc_fh
*fh
= priv
;
1237 return videobuf_reqbufs(&fh
->vidq
, req
);
1240 static int solo_enc_querybuf(struct file
*file
, void *priv
,
1241 struct v4l2_buffer
*buf
)
1243 struct solo_enc_fh
*fh
= priv
;
1245 return videobuf_querybuf(&fh
->vidq
, buf
);
1248 static int solo_enc_qbuf(struct file
*file
, void *priv
, struct v4l2_buffer
*buf
)
1250 struct solo_enc_fh
*fh
= priv
;
1252 return videobuf_qbuf(&fh
->vidq
, buf
);
1255 static int solo_enc_dqbuf(struct file
*file
, void *priv
,
1256 struct v4l2_buffer
*buf
)
1258 struct solo_enc_fh
*fh
= priv
;
1259 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1262 /* Make sure the encoder is on */
1264 spin_lock(&solo_enc
->lock
);
1265 ret
= solo_enc_on(fh
);
1266 spin_unlock(&solo_enc
->lock
);
1270 ret
= solo_start_fh_thread(fh
);
1275 ret
= videobuf_dqbuf(&fh
->vidq
, buf
, file
->f_flags
& O_NONBLOCK
);
1279 /* Signal motion detection */
1280 if (solo_is_motion_on(solo_enc
)) {
1281 buf
->flags
|= V4L2_BUF_FLAG_MOTION_ON
;
1282 if (solo_enc
->motion_detected
) {
1283 buf
->flags
|= V4L2_BUF_FLAG_MOTION_DETECTED
;
1284 solo_reg_write(solo_enc
->solo_dev
, SOLO_VI_MOT_CLEAR
,
1286 solo_enc
->motion_detected
= 0;
1290 /* Check for key frame on mpeg data */
1291 if (fh
->fmt
== V4L2_PIX_FMT_MPEG
) {
1292 struct videobuf_dmabuf
*vbuf
=
1293 videobuf_to_dma(fh
->vidq
.bufs
[buf
->index
]);
1296 u8
*p
= sg_virt(vbuf
->sglist
);
1298 buf
->flags
|= V4L2_BUF_FLAG_KEYFRAME
;
1300 buf
->flags
|= V4L2_BUF_FLAG_PFRAME
;
1307 static int solo_enc_streamon(struct file
*file
, void *priv
,
1308 enum v4l2_buf_type i
)
1310 struct solo_enc_fh
*fh
= priv
;
1312 if (i
!= V4L2_BUF_TYPE_VIDEO_CAPTURE
)
1315 return videobuf_streamon(&fh
->vidq
);
1318 static int solo_enc_streamoff(struct file
*file
, void *priv
,
1319 enum v4l2_buf_type i
)
1321 struct solo_enc_fh
*fh
= priv
;
1323 if (i
!= V4L2_BUF_TYPE_VIDEO_CAPTURE
)
1326 return videobuf_streamoff(&fh
->vidq
);
1329 static int solo_enc_s_std(struct file
*file
, void *priv
, v4l2_std_id
*i
)
1334 static int solo_enum_framesizes(struct file
*file
, void *priv
,
1335 struct v4l2_frmsizeenum
*fsize
)
1337 struct solo_enc_fh
*fh
= priv
;
1338 struct solo_dev
*solo_dev
= fh
->enc
->solo_dev
;
1340 if (fsize
->pixel_format
!= V4L2_PIX_FMT_MPEG
)
1343 switch (fsize
->index
) {
1345 fsize
->discrete
.width
= solo_dev
->video_hsize
>> 1;
1346 fsize
->discrete
.height
= solo_dev
->video_vsize
;
1349 fsize
->discrete
.width
= solo_dev
->video_hsize
;
1350 fsize
->discrete
.height
= solo_dev
->video_vsize
<< 1;
1356 fsize
->type
= V4L2_FRMSIZE_TYPE_DISCRETE
;
1361 static int solo_enum_frameintervals(struct file
*file
, void *priv
,
1362 struct v4l2_frmivalenum
*fintv
)
1364 struct solo_enc_fh
*fh
= priv
;
1365 struct solo_dev
*solo_dev
= fh
->enc
->solo_dev
;
1367 if (fintv
->pixel_format
!= V4L2_PIX_FMT_MPEG
|| fintv
->index
)
1370 fintv
->type
= V4L2_FRMIVAL_TYPE_STEPWISE
;
1372 fintv
->stepwise
.min
.numerator
= solo_dev
->fps
;
1373 fintv
->stepwise
.min
.denominator
= 1;
1375 fintv
->stepwise
.max
.numerator
= solo_dev
->fps
;
1376 fintv
->stepwise
.max
.denominator
= 15;
1378 fintv
->stepwise
.step
.numerator
= 1;
1379 fintv
->stepwise
.step
.denominator
= 1;
1384 static int solo_g_parm(struct file
*file
, void *priv
,
1385 struct v4l2_streamparm
*sp
)
1387 struct solo_enc_fh
*fh
= priv
;
1388 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1389 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1390 struct v4l2_captureparm
*cp
= &sp
->parm
.capture
;
1392 cp
->capability
= V4L2_CAP_TIMEPERFRAME
;
1393 cp
->timeperframe
.numerator
= solo_enc
->interval
;
1394 cp
->timeperframe
.denominator
= solo_dev
->fps
;
1395 cp
->capturemode
= 0;
1396 /* XXX: Shouldn't we be able to get/set this from videobuf? */
1397 cp
->readbuffers
= 2;
1402 static int solo_s_parm(struct file
*file
, void *priv
,
1403 struct v4l2_streamparm
*sp
)
1405 struct solo_enc_fh
*fh
= priv
;
1406 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1407 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1408 struct v4l2_captureparm
*cp
= &sp
->parm
.capture
;
1410 spin_lock(&solo_enc
->lock
);
1412 if (atomic_read(&solo_enc
->readers
) > 0) {
1413 spin_unlock(&solo_enc
->lock
);
1417 if ((cp
->timeperframe
.numerator
== 0) ||
1418 (cp
->timeperframe
.denominator
== 0)) {
1419 /* reset framerate */
1420 cp
->timeperframe
.numerator
= 1;
1421 cp
->timeperframe
.denominator
= solo_dev
->fps
;
1424 if (cp
->timeperframe
.denominator
!= solo_dev
->fps
)
1425 cp
->timeperframe
.denominator
= solo_dev
->fps
;
1427 if (cp
->timeperframe
.numerator
> 15)
1428 cp
->timeperframe
.numerator
= 15;
1430 solo_enc
->interval
= cp
->timeperframe
.numerator
;
1432 cp
->capability
= V4L2_CAP_TIMEPERFRAME
;
1434 solo_enc
->gop
= max(solo_dev
->fps
/ solo_enc
->interval
, 1);
1435 solo_update_mode(solo_enc
);
1437 spin_unlock(&solo_enc
->lock
);
1442 static int solo_queryctrl(struct file
*file
, void *priv
,
1443 struct v4l2_queryctrl
*qc
)
1445 struct solo_enc_fh
*fh
= priv
;
1446 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1447 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1449 qc
->id
= v4l2_ctrl_next(solo_ctrl_classes
, qc
->id
);
1454 case V4L2_CID_BRIGHTNESS
:
1455 case V4L2_CID_CONTRAST
:
1456 case V4L2_CID_SATURATION
:
1458 return v4l2_ctrl_query_fill(qc
, 0x00, 0xff, 1, 0x80);
1459 case V4L2_CID_SHARPNESS
:
1460 return v4l2_ctrl_query_fill(qc
, 0x00, 0x0f, 1, 0x00);
1461 case V4L2_CID_MPEG_VIDEO_ENCODING
:
1462 return v4l2_ctrl_query_fill(
1463 qc
, V4L2_MPEG_VIDEO_ENCODING_MPEG_1
,
1464 V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC
, 1,
1465 V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC
);
1466 case V4L2_CID_MPEG_VIDEO_GOP_SIZE
:
1467 return v4l2_ctrl_query_fill(qc
, 1, 255, 1, solo_dev
->fps
);
1469 case V4L2_CID_MOTION_THRESHOLD
:
1470 qc
->flags
|= V4L2_CTRL_FLAG_SLIDER
;
1471 qc
->type
= V4L2_CTRL_TYPE_INTEGER
;
1473 qc
->maximum
= 0xffff;
1475 qc
->default_value
= SOLO_DEF_MOT_THRESH
;
1476 strlcpy(qc
->name
, "Motion Detection Threshold",
1479 case V4L2_CID_MOTION_ENABLE
:
1480 qc
->type
= V4L2_CTRL_TYPE_BOOLEAN
;
1482 qc
->maximum
= qc
->step
= 1;
1483 qc
->default_value
= 0;
1484 strlcpy(qc
->name
, "Motion Detection Enable", sizeof(qc
->name
));
1487 case V4L2_CID_MOTION_THRESHOLD
:
1488 return v4l2_ctrl_query_fill(qc
, 0, 0xffff, 1,
1489 SOLO_DEF_MOT_THRESH
);
1490 case V4L2_CID_MOTION_ENABLE
:
1491 return v4l2_ctrl_query_fill(qc
, 0, 1, 1, 0);
1493 case V4L2_CID_RDS_TX_RADIO_TEXT
:
1494 qc
->type
= V4L2_CTRL_TYPE_STRING
;
1496 qc
->maximum
= OSD_TEXT_MAX
;
1498 qc
->default_value
= 0;
1499 strlcpy(qc
->name
, "OSD Text", sizeof(qc
->name
));
1506 static int solo_querymenu(struct file
*file
, void *priv
,
1507 struct v4l2_querymenu
*qmenu
)
1509 struct v4l2_queryctrl qctrl
;
1512 qctrl
.id
= qmenu
->id
;
1513 err
= solo_queryctrl(file
, priv
, &qctrl
);
1517 return v4l2_ctrl_query_menu(qmenu
, &qctrl
, NULL
);
1520 static int solo_g_ctrl(struct file
*file
, void *priv
,
1521 struct v4l2_control
*ctrl
)
1523 struct solo_enc_fh
*fh
= priv
;
1524 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1525 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1528 case V4L2_CID_BRIGHTNESS
:
1529 case V4L2_CID_CONTRAST
:
1530 case V4L2_CID_SATURATION
:
1532 case V4L2_CID_SHARPNESS
:
1533 return tw28_get_ctrl_val(solo_dev
, ctrl
->id
, solo_enc
->ch
,
1535 case V4L2_CID_MPEG_VIDEO_ENCODING
:
1536 ctrl
->value
= V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC
;
1538 case V4L2_CID_MPEG_VIDEO_GOP_SIZE
:
1539 ctrl
->value
= solo_enc
->gop
;
1541 case V4L2_CID_MOTION_THRESHOLD
:
1542 ctrl
->value
= solo_enc
->motion_thresh
;
1544 case V4L2_CID_MOTION_ENABLE
:
1545 ctrl
->value
= solo_is_motion_on(solo_enc
);
1554 static int solo_s_ctrl(struct file
*file
, void *priv
,
1555 struct v4l2_control
*ctrl
)
1557 struct solo_enc_fh
*fh
= priv
;
1558 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1559 struct solo_dev
*solo_dev
= solo_enc
->solo_dev
;
1562 case V4L2_CID_BRIGHTNESS
:
1563 case V4L2_CID_CONTRAST
:
1564 case V4L2_CID_SATURATION
:
1566 case V4L2_CID_SHARPNESS
:
1567 return tw28_set_ctrl_val(solo_dev
, ctrl
->id
, solo_enc
->ch
,
1569 case V4L2_CID_MPEG_VIDEO_ENCODING
:
1570 if (ctrl
->value
!= V4L2_MPEG_VIDEO_ENCODING_MPEG_4_AVC
)
1573 case V4L2_CID_MPEG_VIDEO_GOP_SIZE
:
1574 if (ctrl
->value
< 1 || ctrl
->value
> 255)
1576 solo_enc
->gop
= ctrl
->value
;
1577 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP(solo_enc
->ch
),
1579 solo_reg_write(solo_dev
, SOLO_VE_CH_GOP_E(solo_enc
->ch
),
1582 case V4L2_CID_MOTION_THRESHOLD
:
1583 /* TODO accept value on lower 16-bits and use high
1584 * 16-bits to assign the value to a specific block */
1585 if (ctrl
->value
< 0 || ctrl
->value
> 0xffff)
1587 solo_enc
->motion_thresh
= ctrl
->value
;
1588 solo_set_motion_threshold(solo_dev
, solo_enc
->ch
, ctrl
->value
);
1590 case V4L2_CID_MOTION_ENABLE
:
1591 solo_motion_toggle(solo_enc
, ctrl
->value
);
1600 static int solo_s_ext_ctrls(struct file
*file
, void *priv
,
1601 struct v4l2_ext_controls
*ctrls
)
1603 struct solo_enc_fh
*fh
= priv
;
1604 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1607 for (i
= 0; i
< ctrls
->count
; i
++) {
1608 struct v4l2_ext_control
*ctrl
= (ctrls
->controls
+ i
);
1612 case V4L2_CID_RDS_TX_RADIO_TEXT
:
1613 if (ctrl
->size
- 1 > OSD_TEXT_MAX
)
1616 err
= copy_from_user(solo_enc
->osd_text
,
1619 solo_enc
->osd_text
[OSD_TEXT_MAX
] = '\0';
1621 err
= solo_osd_print(solo_enc
);
1629 ctrls
->error_idx
= i
;
1637 static int solo_g_ext_ctrls(struct file
*file
, void *priv
,
1638 struct v4l2_ext_controls
*ctrls
)
1640 struct solo_enc_fh
*fh
= priv
;
1641 struct solo_enc_dev
*solo_enc
= fh
->enc
;
1644 for (i
= 0; i
< ctrls
->count
; i
++) {
1645 struct v4l2_ext_control
*ctrl
= (ctrls
->controls
+ i
);
1649 case V4L2_CID_RDS_TX_RADIO_TEXT
:
1650 if (ctrl
->size
< OSD_TEXT_MAX
) {
1651 ctrl
->size
= OSD_TEXT_MAX
;
1654 err
= copy_to_user(ctrl
->string
,
1664 ctrls
->error_idx
= i
;
1672 static const struct v4l2_file_operations solo_enc_fops
= {
1673 .owner
= THIS_MODULE
,
1674 .open
= solo_enc_open
,
1675 .release
= solo_enc_release
,
1676 .read
= solo_enc_read
,
1677 .poll
= solo_enc_poll
,
1678 .mmap
= solo_enc_mmap
,
1679 .ioctl
= video_ioctl2
,
1682 static const struct v4l2_ioctl_ops solo_enc_ioctl_ops
= {
1683 .vidioc_querycap
= solo_enc_querycap
,
1684 .vidioc_s_std
= solo_enc_s_std
,
1685 /* Input callbacks */
1686 .vidioc_enum_input
= solo_enc_enum_input
,
1687 .vidioc_s_input
= solo_enc_set_input
,
1688 .vidioc_g_input
= solo_enc_get_input
,
1689 /* Video capture format callbacks */
1690 .vidioc_enum_fmt_vid_cap
= solo_enc_enum_fmt_cap
,
1691 .vidioc_try_fmt_vid_cap
= solo_enc_try_fmt_cap
,
1692 .vidioc_s_fmt_vid_cap
= solo_enc_set_fmt_cap
,
1693 .vidioc_g_fmt_vid_cap
= solo_enc_get_fmt_cap
,
1695 .vidioc_reqbufs
= solo_enc_reqbufs
,
1696 .vidioc_querybuf
= solo_enc_querybuf
,
1697 .vidioc_qbuf
= solo_enc_qbuf
,
1698 .vidioc_dqbuf
= solo_enc_dqbuf
,
1699 .vidioc_streamon
= solo_enc_streamon
,
1700 .vidioc_streamoff
= solo_enc_streamoff
,
1701 /* Frame size and interval */
1702 .vidioc_enum_framesizes
= solo_enum_framesizes
,
1703 .vidioc_enum_frameintervals
= solo_enum_frameintervals
,
1704 /* Video capture parameters */
1705 .vidioc_s_parm
= solo_s_parm
,
1706 .vidioc_g_parm
= solo_g_parm
,
1708 .vidioc_queryctrl
= solo_queryctrl
,
1709 .vidioc_querymenu
= solo_querymenu
,
1710 .vidioc_g_ctrl
= solo_g_ctrl
,
1711 .vidioc_s_ctrl
= solo_s_ctrl
,
1712 .vidioc_g_ext_ctrls
= solo_g_ext_ctrls
,
1713 .vidioc_s_ext_ctrls
= solo_s_ext_ctrls
,
1716 static struct video_device solo_enc_template
= {
1717 .name
= SOLO6X10_NAME
,
1718 .fops
= &solo_enc_fops
,
1719 .ioctl_ops
= &solo_enc_ioctl_ops
,
1721 .release
= video_device_release
,
1723 .tvnorms
= V4L2_STD_NTSC_M
| V4L2_STD_PAL_B
,
1724 .current_norm
= V4L2_STD_NTSC_M
,
1727 static struct solo_enc_dev
*solo_enc_alloc(struct solo_dev
*solo_dev
, u8 ch
)
1729 struct solo_enc_dev
*solo_enc
;
1732 solo_enc
= kzalloc(sizeof(*solo_enc
), GFP_KERNEL
);
1734 return ERR_PTR(-ENOMEM
);
1736 solo_enc
->vfd
= video_device_alloc();
1737 if (!solo_enc
->vfd
) {
1739 return ERR_PTR(-ENOMEM
);
1742 solo_enc
->solo_dev
= solo_dev
;
1745 *solo_enc
->vfd
= solo_enc_template
;
1746 solo_enc
->vfd
->parent
= &solo_dev
->pdev
->dev
;
1747 ret
= video_register_device(solo_enc
->vfd
, VFL_TYPE_GRABBER
,
1750 video_device_release(solo_enc
->vfd
);
1752 return ERR_PTR(ret
);
1755 video_set_drvdata(solo_enc
->vfd
, solo_enc
);
1757 snprintf(solo_enc
->vfd
->name
, sizeof(solo_enc
->vfd
->name
),
1758 "%s-enc (%i/%i)", SOLO6X10_NAME
, solo_dev
->vfd
->num
,
1759 solo_enc
->vfd
->num
);
1764 spin_lock_init(&solo_enc
->lock
);
1765 init_waitqueue_head(&solo_enc
->thread_wait
);
1766 atomic_set(&solo_enc
->readers
, 0);
1768 solo_enc
->qp
= SOLO_DEFAULT_QP
;
1769 solo_enc
->gop
= solo_dev
->fps
;
1770 solo_enc
->interval
= 1;
1771 solo_enc
->mode
= SOLO_ENC_MODE_CIF
;
1772 solo_enc
->motion_thresh
= SOLO_DEF_MOT_THRESH
;
1774 spin_lock(&solo_enc
->lock
);
1775 solo_update_mode(solo_enc
);
1776 spin_unlock(&solo_enc
->lock
);
1781 static void solo_enc_free(struct solo_enc_dev
*solo_enc
)
1783 if (solo_enc
== NULL
)
1786 video_unregister_device(solo_enc
->vfd
);
1790 int solo_enc_v4l2_init(struct solo_dev
*solo_dev
)
1794 for (i
= 0; i
< solo_dev
->nr_chans
; i
++) {
1795 solo_dev
->v4l2_enc
[i
] = solo_enc_alloc(solo_dev
, i
);
1796 if (IS_ERR(solo_dev
->v4l2_enc
[i
]))
1800 if (i
!= solo_dev
->nr_chans
) {
1801 int ret
= PTR_ERR(solo_dev
->v4l2_enc
[i
]);
1803 solo_enc_free(solo_dev
->v4l2_enc
[i
]);
1807 /* D1@MAX-FPS * 4 */
1808 solo_dev
->enc_bw_remain
= solo_dev
->fps
* 4 * 4;
1810 dev_info(&solo_dev
->pdev
->dev
, "Encoders as /dev/video%d-%d\n",
1811 solo_dev
->v4l2_enc
[0]->vfd
->num
,
1812 solo_dev
->v4l2_enc
[solo_dev
->nr_chans
- 1]->vfd
->num
);
1817 void solo_enc_v4l2_exit(struct solo_dev
*solo_dev
)
1821 solo_irq_off(solo_dev
, SOLO_IRQ_MOTION
);
1823 for (i
= 0; i
< solo_dev
->nr_chans
; i
++)
1824 solo_enc_free(solo_dev
->v4l2_enc
[i
]);