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