root/drivers/media/platform/sti/delta/delta.h

/* [<][>][^][v][top][bottom][index][help] */

INCLUDED FROM


DEFINITIONS

This source file includes following definitions.
  1. frame_type_str
  2. frame_field_str
  3. frame_state_str

   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 bitstream 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 */

/* [<][>][^][v][top][bottom][index][help] */