19ed785a9SBenjamin Gaignard /* SPDX-License-Identifier: GPL-2.0 */
2f386509eSHugues Fruchet /*
3f386509eSHugues Fruchet * Copyright (C) STMicroelectronics SA 2015
4f386509eSHugues Fruchet * Author: Hugues Fruchet <hugues.fruchet@st.com> for STMicroelectronics.
5f386509eSHugues Fruchet */
6f386509eSHugues Fruchet
7f386509eSHugues Fruchet #ifndef DELTA_H
8f386509eSHugues Fruchet #define DELTA_H
9f386509eSHugues Fruchet
1091c83f39SHugues Fruchet #include <linux/rpmsg.h>
11f386509eSHugues Fruchet #include <media/v4l2-device.h>
12f386509eSHugues Fruchet #include <media/v4l2-mem2mem.h>
13f386509eSHugues Fruchet
14f386509eSHugues Fruchet #include "delta-cfg.h"
15f386509eSHugues Fruchet
16f386509eSHugues Fruchet /*
17f386509eSHugues Fruchet * enum delta_state - state of decoding instance
18f386509eSHugues Fruchet *
19f386509eSHugues Fruchet *@DELTA_STATE_WF_FORMAT:
20f386509eSHugues Fruchet * Wait for compressed format to be set by V4L2 client in order
21f386509eSHugues Fruchet * to know what is the relevant decoder to open.
22f386509eSHugues Fruchet *
23f386509eSHugues Fruchet *@DELTA_STATE_WF_STREAMINFO:
24f386509eSHugues Fruchet * Wait for stream information to be available (bitstream
25f386509eSHugues Fruchet * header parsing is done).
26f386509eSHugues Fruchet *
27f386509eSHugues Fruchet *@DELTA_STATE_READY:
28f386509eSHugues Fruchet * Decoding instance is ready to decode compressed access unit.
29f386509eSHugues Fruchet *
30017c3242SHugues Fruchet *@DELTA_STATE_WF_EOS:
31017c3242SHugues Fruchet * Decoding instance is waiting for EOS (End Of Stream) completion.
32017c3242SHugues Fruchet *
33017c3242SHugues Fruchet *@DELTA_STATE_EOS:
34017c3242SHugues Fruchet * EOS (End Of Stream) is completed (signaled to user). Decoding instance
35017c3242SHugues Fruchet * should then be closed.
36f386509eSHugues Fruchet */
37f386509eSHugues Fruchet enum delta_state {
38f386509eSHugues Fruchet DELTA_STATE_WF_FORMAT,
39f386509eSHugues Fruchet DELTA_STATE_WF_STREAMINFO,
40f386509eSHugues Fruchet DELTA_STATE_READY,
41017c3242SHugues Fruchet DELTA_STATE_WF_EOS,
42017c3242SHugues Fruchet DELTA_STATE_EOS
43f386509eSHugues Fruchet };
44f386509eSHugues Fruchet
45f386509eSHugues Fruchet /*
46f386509eSHugues Fruchet * struct delta_streaminfo - information about stream to decode
47f386509eSHugues Fruchet *
48f386509eSHugues Fruchet * @flags: validity of fields (crop, pixelaspect, other)
49f386509eSHugues Fruchet * @width: width of video stream
50f386509eSHugues Fruchet * @height: height ""
51f386509eSHugues Fruchet * @streamformat: fourcc compressed format of video (MJPEG, MPEG2, ...)
52f386509eSHugues Fruchet * @dpb: number of frames needed to decode a single frame
53f386509eSHugues Fruchet * (h264 dpb, up to 16)
54f386509eSHugues Fruchet * @crop: cropping window inside decoded frame (1920x1080@0,0
55f386509eSHugues Fruchet * inside 1920x1088 frame for ex.)
56f386509eSHugues Fruchet * @pixelaspect: pixel aspect ratio of video (4/3, 5/4)
57f386509eSHugues Fruchet * @field: interlaced or not
58f386509eSHugues Fruchet * @profile: profile string
59f386509eSHugues Fruchet * @level: level string
60f386509eSHugues Fruchet * @other: other string information from codec
61f386509eSHugues Fruchet * @colorspace: colorspace identifier
62f386509eSHugues Fruchet * @xfer_func: transfer function identifier
63f386509eSHugues Fruchet * @ycbcr_enc: Y'CbCr encoding identifier
64f386509eSHugues Fruchet * @quantization: quantization identifier
65f386509eSHugues Fruchet */
66f386509eSHugues Fruchet struct delta_streaminfo {
67f386509eSHugues Fruchet u32 flags;
68f386509eSHugues Fruchet u32 streamformat;
69f386509eSHugues Fruchet u32 width;
70f386509eSHugues Fruchet u32 height;
71f386509eSHugues Fruchet u32 dpb;
72f386509eSHugues Fruchet struct v4l2_rect crop;
73f386509eSHugues Fruchet struct v4l2_fract pixelaspect;
74f386509eSHugues Fruchet enum v4l2_field field;
75f386509eSHugues Fruchet u8 profile[32];
76f386509eSHugues Fruchet u8 level[32];
77f386509eSHugues Fruchet u8 other[32];
78f386509eSHugues Fruchet enum v4l2_colorspace colorspace;
79f386509eSHugues Fruchet enum v4l2_xfer_func xfer_func;
80f386509eSHugues Fruchet enum v4l2_ycbcr_encoding ycbcr_enc;
81f386509eSHugues Fruchet enum v4l2_quantization quantization;
82f386509eSHugues Fruchet };
83f386509eSHugues Fruchet
84f386509eSHugues Fruchet #define DELTA_STREAMINFO_FLAG_CROP 0x0001
85f386509eSHugues Fruchet #define DELTA_STREAMINFO_FLAG_PIXELASPECT 0x0002
86f386509eSHugues Fruchet #define DELTA_STREAMINFO_FLAG_OTHER 0x0004
87f386509eSHugues Fruchet
88f386509eSHugues Fruchet /*
89f386509eSHugues Fruchet * struct delta_au - access unit structure.
90f386509eSHugues Fruchet *
91f386509eSHugues Fruchet * @vbuf: video buffer information for V4L2
92f386509eSHugues Fruchet * @list: V4L2 m2m list that the frame belongs to
93f386509eSHugues Fruchet * @prepared: if set vaddr/paddr are resolved
94f386509eSHugues Fruchet * @vaddr: virtual address (kernel can read/write)
95f386509eSHugues Fruchet * @paddr: physical address (for hardware)
96f386509eSHugues Fruchet * @flags: access unit type (V4L2_BUF_FLAG_KEYFRAME/PFRAME/BFRAME)
97f386509eSHugues Fruchet * @dts: decoding timestamp of this access unit
98f386509eSHugues Fruchet */
99f386509eSHugues Fruchet struct delta_au {
100f386509eSHugues Fruchet struct vb2_v4l2_buffer vbuf; /* keep first */
101f386509eSHugues Fruchet struct list_head list; /* keep second */
102f386509eSHugues Fruchet
103f386509eSHugues Fruchet bool prepared;
104f386509eSHugues Fruchet u32 size;
105f386509eSHugues Fruchet void *vaddr;
106f386509eSHugues Fruchet dma_addr_t paddr;
107f386509eSHugues Fruchet u32 flags;
108f386509eSHugues Fruchet u64 dts;
109f386509eSHugues Fruchet };
110f386509eSHugues Fruchet
111f386509eSHugues Fruchet /*
112f386509eSHugues Fruchet * struct delta_frameinfo - information about decoded frame
113f386509eSHugues Fruchet *
114f386509eSHugues Fruchet * @flags: validity of fields (crop, pixelaspect)
115f386509eSHugues Fruchet * @pixelformat: fourcc code for uncompressed video format
116f386509eSHugues Fruchet * @width: width of frame
117f386509eSHugues Fruchet * @height: height of frame
118f386509eSHugues Fruchet * @aligned_width: width of frame (with encoder or decoder alignment
119f386509eSHugues Fruchet * constraint)
120f386509eSHugues Fruchet * @aligned_height: height of frame (with encoder or decoder alignment
121f386509eSHugues Fruchet * constraint)
122f386509eSHugues Fruchet * @size: maximum size in bytes required for data
123f386509eSHugues Fruchet * @crop: cropping window inside frame (1920x1080@0,0
124f386509eSHugues Fruchet * inside 1920x1088 frame for ex.)
125f386509eSHugues Fruchet * @pixelaspect: pixel aspect ratio of video (4/3, 5/4)
126f386509eSHugues Fruchet * @field: interlaced mode
127f386509eSHugues Fruchet * @colorspace: colorspace identifier
128f386509eSHugues Fruchet * @xfer_func: transfer function identifier
129f386509eSHugues Fruchet * @ycbcr_enc: Y'CbCr encoding identifier
130f386509eSHugues Fruchet * @quantization: quantization identifier
131f386509eSHugues Fruchet */
132f386509eSHugues Fruchet struct delta_frameinfo {
133f386509eSHugues Fruchet u32 flags;
134f386509eSHugues Fruchet u32 pixelformat;
135f386509eSHugues Fruchet u32 width;
136f386509eSHugues Fruchet u32 height;
137f386509eSHugues Fruchet u32 aligned_width;
138f386509eSHugues Fruchet u32 aligned_height;
139f386509eSHugues Fruchet u32 size;
140f386509eSHugues Fruchet struct v4l2_rect crop;
141f386509eSHugues Fruchet struct v4l2_fract pixelaspect;
142f386509eSHugues Fruchet enum v4l2_field field;
143f386509eSHugues Fruchet enum v4l2_colorspace colorspace;
144f386509eSHugues Fruchet enum v4l2_xfer_func xfer_func;
145f386509eSHugues Fruchet enum v4l2_ycbcr_encoding ycbcr_enc;
146f386509eSHugues Fruchet enum v4l2_quantization quantization;
147f386509eSHugues Fruchet };
148f386509eSHugues Fruchet
149f386509eSHugues Fruchet #define DELTA_FRAMEINFO_FLAG_CROP 0x0001
150f386509eSHugues Fruchet #define DELTA_FRAMEINFO_FLAG_PIXELASPECT 0x0002
151f386509eSHugues Fruchet
152f386509eSHugues Fruchet /*
153f386509eSHugues Fruchet * struct delta_frame - frame structure.
154f386509eSHugues Fruchet *
155f386509eSHugues Fruchet * @vbuf: video buffer information for V4L2
156f386509eSHugues Fruchet * @list: V4L2 m2m list that the frame belongs to
157f386509eSHugues Fruchet * @info: frame information (width, height, format, alignment...)
158f386509eSHugues Fruchet * @prepared: if set pix/vaddr/paddr are resolved
159f386509eSHugues Fruchet * @index: frame index, aligned on V4L2 wow
160f386509eSHugues Fruchet * @vaddr: virtual address (kernel can read/write)
161f386509eSHugues Fruchet * @paddr: physical address (for hardware)
162f386509eSHugues Fruchet * @state: frame state for frame lifecycle tracking
163f386509eSHugues Fruchet * (DELTA_FRAME_FREE/DEC/OUT/REC/...)
164f386509eSHugues Fruchet * @flags: frame type (V4L2_BUF_FLAG_KEYFRAME/PFRAME/BFRAME)
165f386509eSHugues Fruchet * @dts: decoding timestamp of this frame
166f386509eSHugues Fruchet * @field: field order for interlaced frame
167f386509eSHugues Fruchet */
168f386509eSHugues Fruchet struct delta_frame {
169f386509eSHugues Fruchet struct vb2_v4l2_buffer vbuf; /* keep first */
170f386509eSHugues Fruchet struct list_head list; /* keep second */
171f386509eSHugues Fruchet
172f386509eSHugues Fruchet struct delta_frameinfo info;
173f386509eSHugues Fruchet bool prepared;
174f386509eSHugues Fruchet u32 index;
175f386509eSHugues Fruchet void *vaddr;
176f386509eSHugues Fruchet dma_addr_t paddr;
177f386509eSHugues Fruchet u32 state;
178f386509eSHugues Fruchet u32 flags;
179f386509eSHugues Fruchet u64 dts;
180f386509eSHugues Fruchet enum v4l2_field field;
181f386509eSHugues Fruchet };
182f386509eSHugues Fruchet
183f386509eSHugues Fruchet /* frame state for frame lifecycle tracking */
184f386509eSHugues Fruchet #define DELTA_FRAME_FREE 0x00 /* is free and can be used for decoding */
185f386509eSHugues Fruchet #define DELTA_FRAME_REF 0x01 /* is a reference frame */
186f386509eSHugues Fruchet #define DELTA_FRAME_BSY 0x02 /* is owned by decoder and busy */
187f386509eSHugues Fruchet #define DELTA_FRAME_DEC 0x04 /* contains decoded content */
188f386509eSHugues Fruchet #define DELTA_FRAME_OUT 0x08 /* has been given to user */
189f386509eSHugues Fruchet #define DELTA_FRAME_RDY 0x10 /* is ready but still held by decoder */
190f386509eSHugues Fruchet #define DELTA_FRAME_M2M 0x20 /* is owned by mem2mem framework */
191f386509eSHugues Fruchet
192f386509eSHugues Fruchet /*
193f386509eSHugues Fruchet * struct delta_dts - decoding timestamp.
194f386509eSHugues Fruchet *
195f386509eSHugues Fruchet * @list: list to chain timestamps
196f386509eSHugues Fruchet * @val: timestamp in microseconds
197f386509eSHugues Fruchet */
198f386509eSHugues Fruchet struct delta_dts {
199f386509eSHugues Fruchet struct list_head list;
200f386509eSHugues Fruchet u64 val;
201f386509eSHugues Fruchet };
202f386509eSHugues Fruchet
203c502e583SHugues Fruchet struct delta_buf {
204c502e583SHugues Fruchet u32 size;
205c502e583SHugues Fruchet void *vaddr;
206c502e583SHugues Fruchet dma_addr_t paddr;
207c502e583SHugues Fruchet const char *name;
208c502e583SHugues Fruchet unsigned long attrs;
209c502e583SHugues Fruchet };
210c502e583SHugues Fruchet
21191c83f39SHugues Fruchet struct delta_ipc_ctx {
21291c83f39SHugues Fruchet int cb_err;
21391c83f39SHugues Fruchet u32 copro_hdl;
21491c83f39SHugues Fruchet struct completion done;
21591c83f39SHugues Fruchet struct delta_buf ipc_buf_struct;
21691c83f39SHugues Fruchet struct delta_buf *ipc_buf;
21791c83f39SHugues Fruchet };
21891c83f39SHugues Fruchet
21991c83f39SHugues Fruchet struct delta_ipc_param {
22091c83f39SHugues Fruchet u32 size;
22191c83f39SHugues Fruchet void *data;
22291c83f39SHugues Fruchet };
22391c83f39SHugues Fruchet
224f386509eSHugues Fruchet struct delta_ctx;
225f386509eSHugues Fruchet
226f386509eSHugues Fruchet /*
227f386509eSHugues Fruchet * struct delta_dec - decoder structure.
228f386509eSHugues Fruchet *
229f386509eSHugues Fruchet * @name: name of this decoder
230f386509eSHugues Fruchet * @streamformat: input stream format that this decoder support
231f386509eSHugues Fruchet * @pixelformat: pixel format of decoded frame that this decoder support
232f386509eSHugues Fruchet * @max_width: (optional) maximum width that can decode this decoder
233f386509eSHugues Fruchet * if not set, maximum width is DELTA_MAX_WIDTH
234f386509eSHugues Fruchet * @max_height: (optional) maximum height that can decode this decoder
235f386509eSHugues Fruchet * if not set, maximum height is DELTA_MAX_HEIGHT
236f386509eSHugues Fruchet * @pm: (optional) if set, decoder will manage power on its own
237f386509eSHugues Fruchet * @open: open this decoder
238f386509eSHugues Fruchet * @close: close this decoder
239f386509eSHugues Fruchet * @setup_frame: setup frame to be used by decoder, see below
240f386509eSHugues Fruchet * @get_streaminfo: get stream related infos, see below
241f386509eSHugues Fruchet * @get_frameinfo: get decoded frame related infos, see below
242f386509eSHugues Fruchet * @set_frameinfo: (optional) set decoded frame related infos, see below
243f386509eSHugues Fruchet * @setup_frame: setup frame to be used by decoder, see below
244f386509eSHugues Fruchet * @decode: decode a single access unit, see below
245f386509eSHugues Fruchet * @get_frame: get the next decoded frame available, see below
246f386509eSHugues Fruchet * @recycle: recycle the given frame, see below
247f386509eSHugues Fruchet * @flush: (optional) flush decoder, see below
248017c3242SHugues Fruchet * @drain: (optional) drain decoder, see below
249f386509eSHugues Fruchet */
250f386509eSHugues Fruchet struct delta_dec {
251f386509eSHugues Fruchet const char *name;
252f386509eSHugues Fruchet u32 streamformat;
253f386509eSHugues Fruchet u32 pixelformat;
254f386509eSHugues Fruchet u32 max_width;
255f386509eSHugues Fruchet u32 max_height;
256f386509eSHugues Fruchet bool pm;
257f386509eSHugues Fruchet
258f386509eSHugues Fruchet /*
259f386509eSHugues Fruchet * decoder ops
260f386509eSHugues Fruchet */
261f386509eSHugues Fruchet int (*open)(struct delta_ctx *ctx);
262f386509eSHugues Fruchet int (*close)(struct delta_ctx *ctx);
263f386509eSHugues Fruchet
264f386509eSHugues Fruchet /*
265f386509eSHugues Fruchet * setup_frame() - setup frame to be used by decoder
266f386509eSHugues Fruchet * @ctx: (in) instance
267f386509eSHugues Fruchet * @frame: (in) frame to use
268f386509eSHugues Fruchet * @frame.index (in) identifier of frame
269f386509eSHugues Fruchet * @frame.vaddr (in) virtual address (kernel can read/write)
270f386509eSHugues Fruchet * @frame.paddr (in) physical address (for hardware)
271f386509eSHugues Fruchet *
272f386509eSHugues Fruchet * Frame is to be allocated by caller, then given
273f386509eSHugues Fruchet * to decoder through this call.
274f386509eSHugues Fruchet * Several frames must be given to decoder (dpb),
275f386509eSHugues Fruchet * each frame is identified using its index.
276f386509eSHugues Fruchet */
277f386509eSHugues Fruchet int (*setup_frame)(struct delta_ctx *ctx, struct delta_frame *frame);
278f386509eSHugues Fruchet
279f386509eSHugues Fruchet /*
280f386509eSHugues Fruchet * get_streaminfo() - get stream related infos
281f386509eSHugues Fruchet * @ctx: (in) instance
282f386509eSHugues Fruchet * @streaminfo: (out) width, height, dpb,...
283f386509eSHugues Fruchet *
284f386509eSHugues Fruchet * Precondition: stream header must have been successfully
285f386509eSHugues Fruchet * parsed to have this call successful & @streaminfo valid.
286f386509eSHugues Fruchet * Header parsing must be done using decode(), giving
287f386509eSHugues Fruchet * explicitly header access unit or first access unit of bitstream.
288f386509eSHugues Fruchet * If no valid header is found, get_streaminfo will return -ENODATA,
289*8b72c18dSMauro Carvalho Chehab * in this case the next bitstream access unit must be decoded till
290f386509eSHugues Fruchet * get_streaminfo becomes successful.
291f386509eSHugues Fruchet */
292f386509eSHugues Fruchet int (*get_streaminfo)(struct delta_ctx *ctx,
293f386509eSHugues Fruchet struct delta_streaminfo *streaminfo);
294f386509eSHugues Fruchet
295f386509eSHugues Fruchet /*
296f386509eSHugues Fruchet * get_frameinfo() - get decoded frame related infos
297f386509eSHugues Fruchet * @ctx: (in) instance
298f386509eSHugues Fruchet * @frameinfo: (out) width, height, alignment, crop, ...
299f386509eSHugues Fruchet *
300f386509eSHugues Fruchet * Precondition: get_streaminfo() must be successful
301f386509eSHugues Fruchet */
302f386509eSHugues Fruchet int (*get_frameinfo)(struct delta_ctx *ctx,
303f386509eSHugues Fruchet struct delta_frameinfo *frameinfo);
304f386509eSHugues Fruchet
305f386509eSHugues Fruchet /*
306f386509eSHugues Fruchet * set_frameinfo() - set decoded frame related infos
307f386509eSHugues Fruchet * @ctx: (in) instance
308f386509eSHugues Fruchet * @frameinfo: (out) width, height, alignment, crop, ...
309f386509eSHugues Fruchet *
310f386509eSHugues Fruchet * Optional.
311f386509eSHugues Fruchet * Typically used to negotiate with decoder the output
312f386509eSHugues Fruchet * frame if decoder can do post-processing.
313f386509eSHugues Fruchet */
314f386509eSHugues Fruchet int (*set_frameinfo)(struct delta_ctx *ctx,
315f386509eSHugues Fruchet struct delta_frameinfo *frameinfo);
316f386509eSHugues Fruchet
317f386509eSHugues Fruchet /*
318f386509eSHugues Fruchet * decode() - decode a single access unit
319f386509eSHugues Fruchet * @ctx: (in) instance
320f386509eSHugues Fruchet * @au: (in/out) access unit
321f386509eSHugues Fruchet * @au.size (in) size of au to decode
322f386509eSHugues Fruchet * @au.vaddr (in) virtual address (kernel can read/write)
323f386509eSHugues Fruchet * @au.paddr (in) physical address (for hardware)
324f386509eSHugues Fruchet * @au.flags (out) au type (V4L2_BUF_FLAG_KEYFRAME/
325f386509eSHugues Fruchet * PFRAME/BFRAME)
326f386509eSHugues Fruchet *
327f386509eSHugues Fruchet * Decode the access unit given. Decode is synchronous;
328f386509eSHugues Fruchet * access unit memory is no more needed after this call.
329f386509eSHugues Fruchet * After this call, none, one or several frames could
330f386509eSHugues Fruchet * have been decoded, which can be retrieved using
331f386509eSHugues Fruchet * get_frame().
332f386509eSHugues Fruchet */
333f386509eSHugues Fruchet int (*decode)(struct delta_ctx *ctx, struct delta_au *au);
334f386509eSHugues Fruchet
335f386509eSHugues Fruchet /*
336f386509eSHugues Fruchet * get_frame() - get the next decoded frame available
337f386509eSHugues Fruchet * @ctx: (in) instance
338f386509eSHugues Fruchet * @frame: (out) frame with decoded data:
339f386509eSHugues Fruchet * @frame.index (out) identifier of frame
340f386509eSHugues Fruchet * @frame.field (out) field order for interlaced frame
341f386509eSHugues Fruchet * @frame.state (out) frame state for frame lifecycle tracking
342f386509eSHugues Fruchet * @frame.flags (out) frame type (V4L2_BUF_FLAG_KEYFRAME/
343f386509eSHugues Fruchet * PFRAME/BFRAME)
344f386509eSHugues Fruchet *
345f386509eSHugues Fruchet * Get the next available decoded frame.
346f386509eSHugues Fruchet * If no frame is available, -ENODATA is returned.
347f386509eSHugues Fruchet * If a frame is available, frame structure is filled with
348f386509eSHugues Fruchet * relevant data, frame.index identifying this exact frame.
349f386509eSHugues Fruchet * When this frame is no more needed by upper layers,
350f386509eSHugues Fruchet * recycle() must be called giving this frame identifier.
351f386509eSHugues Fruchet */
352f386509eSHugues Fruchet int (*get_frame)(struct delta_ctx *ctx, struct delta_frame **frame);
353f386509eSHugues Fruchet
354f386509eSHugues Fruchet /*
355f386509eSHugues Fruchet * recycle() - recycle the given frame
356f386509eSHugues Fruchet * @ctx: (in) instance
357f386509eSHugues Fruchet * @frame: (in) frame to recycle:
358f386509eSHugues Fruchet * @frame.index (in) identifier of frame
359f386509eSHugues Fruchet *
360f386509eSHugues Fruchet * recycle() is to be called by user when the decoded frame
361f386509eSHugues Fruchet * is no more needed (composition/display done).
362f386509eSHugues Fruchet * This frame will then be reused by decoder to proceed
363f386509eSHugues Fruchet * with next frame decoding.
364f386509eSHugues Fruchet * If not enough frames have been provided through setup_frame(),
365f386509eSHugues Fruchet * or recycle() is not called fast enough, the decoder can run out
366f386509eSHugues Fruchet * of available frames to proceed with decoding (starvation).
367f386509eSHugues Fruchet * This case is guarded by wq_recycle wait queue which ensures that
368f386509eSHugues Fruchet * decoder is called only if at least one frame is available.
369f386509eSHugues Fruchet */
370f386509eSHugues Fruchet int (*recycle)(struct delta_ctx *ctx, struct delta_frame *frame);
371f386509eSHugues Fruchet
372f386509eSHugues Fruchet /*
373f386509eSHugues Fruchet * flush() - flush decoder
374f386509eSHugues Fruchet * @ctx: (in) instance
375f386509eSHugues Fruchet *
376f386509eSHugues Fruchet * Optional.
377f386509eSHugues Fruchet * Reset decoder context and discard all internal buffers.
378f386509eSHugues Fruchet * This allows implementation of seek, which leads to discontinuity
379f386509eSHugues Fruchet * of input bitstream that decoder must know to restart its internal
380f386509eSHugues Fruchet * decoding logic.
381f386509eSHugues Fruchet */
382f386509eSHugues Fruchet int (*flush)(struct delta_ctx *ctx);
383017c3242SHugues Fruchet
384017c3242SHugues Fruchet /*
385017c3242SHugues Fruchet * drain() - drain decoder
386017c3242SHugues Fruchet * @ctx: (in) instance
387017c3242SHugues Fruchet *
388017c3242SHugues Fruchet * Optional.
389017c3242SHugues Fruchet * Mark decoder pending frames (decoded but not yet output) as ready
390017c3242SHugues Fruchet * so that they can be output to client at EOS (End Of Stream).
391017c3242SHugues Fruchet * get_frame() is to be called in a loop right after drain() to
392017c3242SHugues Fruchet * get all those pending frames.
393017c3242SHugues Fruchet */
394017c3242SHugues Fruchet int (*drain)(struct delta_ctx *ctx);
395f386509eSHugues Fruchet };
396f386509eSHugues Fruchet
397f386509eSHugues Fruchet struct delta_dev;
398f386509eSHugues Fruchet
399f386509eSHugues Fruchet /*
400f386509eSHugues Fruchet * struct delta_ctx - instance structure.
401f386509eSHugues Fruchet *
402f386509eSHugues Fruchet * @flags: validity of fields (streaminfo)
403f386509eSHugues Fruchet * @fh: V4L2 file handle
404f386509eSHugues Fruchet * @dev: device context
405f386509eSHugues Fruchet * @dec: selected decoder context for this instance
40691c83f39SHugues Fruchet * @ipc_ctx: context of IPC communication with firmware
407f386509eSHugues Fruchet * @state: instance state
408f386509eSHugues Fruchet * @frame_num: frame number
409f386509eSHugues Fruchet * @au_num: access unit number
410f386509eSHugues Fruchet * @max_au_size: max size of an access unit
411f386509eSHugues Fruchet * @streaminfo: stream information (width, height, dpb, interlacing...)
412f386509eSHugues Fruchet * @frameinfo: frame information (width, height, format, alignment...)
413f386509eSHugues Fruchet * @nb_of_frames: number of frames available for decoding
414f386509eSHugues Fruchet * @frames: array of decoding frames to keep track of frame
415f386509eSHugues Fruchet * state and manage frame recycling
416f386509eSHugues Fruchet * @decoded_frames: nb of decoded frames from opening
417f386509eSHugues Fruchet * @output_frames: nb of output frames from opening
418f386509eSHugues Fruchet * @dropped_frames: nb of frames dropped (ie access unit not parsed
419f386509eSHugues Fruchet * or frame decoded but not output)
420f386509eSHugues Fruchet * @stream_errors: nb of stream errors (corrupted, not supported, ...)
421f386509eSHugues Fruchet * @decode_errors: nb of decode errors (firmware error)
422f386509eSHugues Fruchet * @sys_errors: nb of system errors (memory, ipc, ...)
423f386509eSHugues Fruchet * @dts: FIFO of decoding timestamp.
424f386509eSHugues Fruchet * output frames are timestamped with incoming access
425f386509eSHugues Fruchet * unit timestamps using this fifo.
426f386509eSHugues Fruchet * @name: string naming this instance (debug purpose)
427f386509eSHugues Fruchet * @run_work: decoding work
428f386509eSHugues Fruchet * @lock: lock for decoding work serialization
429f386509eSHugues Fruchet * @aborting: true if current job aborted
430f386509eSHugues Fruchet * @priv: private decoder context for this instance, allocated
431f386509eSHugues Fruchet * by decoder @open time.
432f386509eSHugues Fruchet */
433f386509eSHugues Fruchet struct delta_ctx {
434f386509eSHugues Fruchet u32 flags;
435f386509eSHugues Fruchet struct v4l2_fh fh;
436f386509eSHugues Fruchet struct delta_dev *dev;
437f386509eSHugues Fruchet const struct delta_dec *dec;
43891c83f39SHugues Fruchet struct delta_ipc_ctx ipc_ctx;
43991c83f39SHugues Fruchet
440f386509eSHugues Fruchet enum delta_state state;
441f386509eSHugues Fruchet u32 frame_num;
442f386509eSHugues Fruchet u32 au_num;
443f386509eSHugues Fruchet size_t max_au_size;
444f386509eSHugues Fruchet struct delta_streaminfo streaminfo;
445f386509eSHugues Fruchet struct delta_frameinfo frameinfo;
446f386509eSHugues Fruchet u32 nb_of_frames;
447f386509eSHugues Fruchet struct delta_frame *frames[DELTA_MAX_FRAMES];
448f386509eSHugues Fruchet u32 decoded_frames;
449f386509eSHugues Fruchet u32 output_frames;
450f386509eSHugues Fruchet u32 dropped_frames;
451f386509eSHugues Fruchet u32 stream_errors;
452f386509eSHugues Fruchet u32 decode_errors;
453f386509eSHugues Fruchet u32 sys_errors;
454f386509eSHugues Fruchet struct list_head dts;
455f386509eSHugues Fruchet char name[100];
456f386509eSHugues Fruchet struct work_struct run_work;
457f386509eSHugues Fruchet struct mutex lock;
458f386509eSHugues Fruchet bool aborting;
459f386509eSHugues Fruchet void *priv;
460f386509eSHugues Fruchet };
461f386509eSHugues Fruchet
462f386509eSHugues Fruchet #define DELTA_FLAG_STREAMINFO 0x0001
463f386509eSHugues Fruchet #define DELTA_FLAG_FRAMEINFO 0x0002
464f386509eSHugues Fruchet
465f386509eSHugues Fruchet #define DELTA_MAX_FORMATS DELTA_MAX_DECODERS
466f386509eSHugues Fruchet
467f386509eSHugues Fruchet /*
468f386509eSHugues Fruchet * struct delta_dev - device struct, 1 per probe (so single one for
469f386509eSHugues Fruchet * all platform life)
470f386509eSHugues Fruchet *
471f386509eSHugues Fruchet * @v4l2_dev: v4l2 device
472f386509eSHugues Fruchet * @vdev: v4l2 video device
473f386509eSHugues Fruchet * @pdev: platform device
474f386509eSHugues Fruchet * @dev: device
475f386509eSHugues Fruchet * @m2m_dev: memory-to-memory V4L2 device
476f386509eSHugues Fruchet * @lock: device lock, for crit section & V4L2 ops serialization.
477f386509eSHugues Fruchet * @clk_delta: delta main clock
478f386509eSHugues Fruchet * @clk_st231: st231 coprocessor main clock
479f386509eSHugues Fruchet * @clk_flash_promip: flash promip clock
480f386509eSHugues Fruchet * @decoders: list of registered decoders
481f386509eSHugues Fruchet * @nb_of_decoders: nb of registered decoders
482f386509eSHugues Fruchet * @pixelformats: supported uncompressed video formats
483f386509eSHugues Fruchet * @nb_of_pixelformats: number of supported umcompressed video formats
484f386509eSHugues Fruchet * @streamformats: supported compressed video formats
485f386509eSHugues Fruchet * @nb_of_streamformats:number of supported compressed video formats
486f386509eSHugues Fruchet * @instance_id: rolling counter identifying an instance (debug purpose)
487f386509eSHugues Fruchet * @work_queue: decoding job work queue
48891c83f39SHugues Fruchet * @rpmsg_driver: rpmsg IPC driver
48991c83f39SHugues Fruchet * @rpmsg_device: rpmsg IPC device
490f386509eSHugues Fruchet */
491f386509eSHugues Fruchet struct delta_dev {
492f386509eSHugues Fruchet struct v4l2_device v4l2_dev;
493f386509eSHugues Fruchet struct video_device *vdev;
494f386509eSHugues Fruchet struct platform_device *pdev;
495f386509eSHugues Fruchet struct device *dev;
496f386509eSHugues Fruchet struct v4l2_m2m_dev *m2m_dev;
497f386509eSHugues Fruchet struct mutex lock;
498f386509eSHugues Fruchet struct clk *clk_delta;
499f386509eSHugues Fruchet struct clk *clk_st231;
500f386509eSHugues Fruchet struct clk *clk_flash_promip;
501f386509eSHugues Fruchet const struct delta_dec *decoders[DELTA_MAX_DECODERS];
502f386509eSHugues Fruchet u32 nb_of_decoders;
503f386509eSHugues Fruchet u32 pixelformats[DELTA_MAX_FORMATS];
504f386509eSHugues Fruchet u32 nb_of_pixelformats;
505f386509eSHugues Fruchet u32 streamformats[DELTA_MAX_FORMATS];
506f386509eSHugues Fruchet u32 nb_of_streamformats;
507f386509eSHugues Fruchet u8 instance_id;
508f386509eSHugues Fruchet struct workqueue_struct *work_queue;
50991c83f39SHugues Fruchet struct rpmsg_driver rpmsg_driver;
51091c83f39SHugues Fruchet struct rpmsg_device *rpmsg_device;
511f386509eSHugues Fruchet };
512f386509eSHugues Fruchet
frame_type_str(u32 flags)513f386509eSHugues Fruchet static inline char *frame_type_str(u32 flags)
514f386509eSHugues Fruchet {
515f386509eSHugues Fruchet if (flags & V4L2_BUF_FLAG_KEYFRAME)
516f386509eSHugues Fruchet return "I";
517f386509eSHugues Fruchet if (flags & V4L2_BUF_FLAG_PFRAME)
518f386509eSHugues Fruchet return "P";
519f386509eSHugues Fruchet if (flags & V4L2_BUF_FLAG_BFRAME)
520f386509eSHugues Fruchet return "B";
521017c3242SHugues Fruchet if (flags & V4L2_BUF_FLAG_LAST)
522017c3242SHugues Fruchet return "EOS";
523f386509eSHugues Fruchet return "?";
524f386509eSHugues Fruchet }
525f386509eSHugues Fruchet
frame_field_str(enum v4l2_field field)526f386509eSHugues Fruchet static inline char *frame_field_str(enum v4l2_field field)
527f386509eSHugues Fruchet {
528f386509eSHugues Fruchet if (field == V4L2_FIELD_NONE)
529f386509eSHugues Fruchet return "-";
530f386509eSHugues Fruchet if (field == V4L2_FIELD_TOP)
531f386509eSHugues Fruchet return "T";
532f386509eSHugues Fruchet if (field == V4L2_FIELD_BOTTOM)
533f386509eSHugues Fruchet return "B";
534f386509eSHugues Fruchet if (field == V4L2_FIELD_INTERLACED)
535f386509eSHugues Fruchet return "I";
536f386509eSHugues Fruchet if (field == V4L2_FIELD_INTERLACED_TB)
537f386509eSHugues Fruchet return "TB";
538f386509eSHugues Fruchet if (field == V4L2_FIELD_INTERLACED_BT)
539f386509eSHugues Fruchet return "BT";
540f386509eSHugues Fruchet return "?";
541f386509eSHugues Fruchet }
542f386509eSHugues Fruchet
frame_state_str(u32 state,char * str,unsigned int len)543f386509eSHugues Fruchet static inline char *frame_state_str(u32 state, char *str, unsigned int len)
544f386509eSHugues Fruchet {
545f386509eSHugues Fruchet snprintf(str, len, "%s %s %s %s %s %s",
546f386509eSHugues Fruchet (state & DELTA_FRAME_REF) ? "ref" : " ",
547f386509eSHugues Fruchet (state & DELTA_FRAME_BSY) ? "bsy" : " ",
548f386509eSHugues Fruchet (state & DELTA_FRAME_DEC) ? "dec" : " ",
549f386509eSHugues Fruchet (state & DELTA_FRAME_OUT) ? "out" : " ",
550f386509eSHugues Fruchet (state & DELTA_FRAME_M2M) ? "m2m" : " ",
551f386509eSHugues Fruchet (state & DELTA_FRAME_RDY) ? "rdy" : " ");
552f386509eSHugues Fruchet return str;
553f386509eSHugues Fruchet }
554f386509eSHugues Fruchet
555f386509eSHugues Fruchet int delta_get_frameinfo_default(struct delta_ctx *ctx,
556f386509eSHugues Fruchet struct delta_frameinfo *frameinfo);
557f386509eSHugues Fruchet int delta_recycle_default(struct delta_ctx *pctx,
558f386509eSHugues Fruchet struct delta_frame *frame);
559f386509eSHugues Fruchet
560f386509eSHugues Fruchet int delta_get_free_frame(struct delta_ctx *ctx,
561f386509eSHugues Fruchet struct delta_frame **pframe);
562f386509eSHugues Fruchet
563f386509eSHugues Fruchet int delta_get_sync(struct delta_ctx *ctx);
564f386509eSHugues Fruchet void delta_put_autosuspend(struct delta_ctx *ctx);
565f386509eSHugues Fruchet
566f386509eSHugues Fruchet #endif /* DELTA_H */
567