162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-or-later */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci *  cx18 init/start/stop/exit stream functions
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci *  Derived from ivtv-streams.h
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci *  Copyright (C) 2007  Hans Verkuil <hverkuil@xs4all.nl>
862306a36Sopenharmony_ci *  Copyright (C) 2008  Andy Walls <awalls@md.metrocast.net>
962306a36Sopenharmony_ci */
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ciu32 cx18_find_handle(struct cx18 *cx);
1262306a36Sopenharmony_cistruct cx18_stream *cx18_handle_to_stream(struct cx18 *cx, u32 handle);
1362306a36Sopenharmony_ciint cx18_streams_setup(struct cx18 *cx);
1462306a36Sopenharmony_ciint cx18_streams_register(struct cx18 *cx);
1562306a36Sopenharmony_civoid cx18_streams_cleanup(struct cx18 *cx, int unregister);
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci#define CX18_ENC_STREAM_TYPE_IDX_FW_MDL_MIN (3)
1862306a36Sopenharmony_civoid cx18_stream_rotate_idx_mdls(struct cx18 *cx);
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_cistatic inline bool cx18_stream_enabled(struct cx18_stream *s)
2162306a36Sopenharmony_ci{
2262306a36Sopenharmony_ci	return s->video_dev.v4l2_dev ||
2362306a36Sopenharmony_ci	       (s->dvb && s->dvb->enabled) ||
2462306a36Sopenharmony_ci	       (s->type == CX18_ENC_STREAM_TYPE_IDX &&
2562306a36Sopenharmony_ci		s->cx->stream_buffers[CX18_ENC_STREAM_TYPE_IDX] != 0);
2662306a36Sopenharmony_ci}
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci/* Related to submission of mdls to firmware */
2962306a36Sopenharmony_cistatic inline void cx18_stream_load_fw_queue(struct cx18_stream *s)
3062306a36Sopenharmony_ci{
3162306a36Sopenharmony_ci	schedule_work(&s->out_work_order);
3262306a36Sopenharmony_ci}
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_cistatic inline void cx18_stream_put_mdl_fw(struct cx18_stream *s,
3562306a36Sopenharmony_ci					  struct cx18_mdl *mdl)
3662306a36Sopenharmony_ci{
3762306a36Sopenharmony_ci	/* Put mdl on q_free; the out work handler will move mdl(s) to q_busy */
3862306a36Sopenharmony_ci	cx18_enqueue(s, mdl, &s->q_free);
3962306a36Sopenharmony_ci	cx18_stream_load_fw_queue(s);
4062306a36Sopenharmony_ci}
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_civoid cx18_out_work_handler(struct work_struct *work);
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci/* Capture related */
4562306a36Sopenharmony_ciint cx18_start_v4l2_encode_stream(struct cx18_stream *s);
4662306a36Sopenharmony_ciint cx18_stop_v4l2_encode_stream(struct cx18_stream *s, int gop_end);
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_civoid cx18_stop_all_captures(struct cx18 *cx);
49