1 /*
2  * Copyright 2013 Ilia Mirkin
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  */
22 
23 #ifndef NV84_VIDEO_H_
24 #define NV84_VIDEO_H_
25 
26 #include "vl/vl_decoder.h"
27 #include "vl/vl_video_buffer.h"
28 #include "vl/vl_types.h"
29 
30 #include "vl/vl_mpeg12_bitstream.h"
31 
32 #include "util/u_video.h"
33 
34 #include "nv50/nv50_context.h"
35 
36 /* These are expected to be on their own pushbufs */
37 #define SUBC_BSP(m) 2, (m)
38 #define SUBC_VP(m) 2, (m)
39 
40 union pipe_desc {
41    struct pipe_picture_desc *base;
42    struct pipe_mpeg12_picture_desc *mpeg12;
43    struct pipe_mpeg4_picture_desc *mpeg4;
44    struct pipe_vc1_picture_desc *vc1;
45    struct pipe_h264_picture_desc *h264;
46 };
47 
48 struct nv84_video_buffer {
49    struct pipe_video_buffer base;
50    struct pipe_resource *resources[VL_NUM_COMPONENTS];
51    struct pipe_sampler_view *sampler_view_planes[VL_NUM_COMPONENTS];
52    struct pipe_sampler_view *sampler_view_components[VL_NUM_COMPONENTS];
53    struct pipe_surface *surfaces[VL_NUM_COMPONENTS * 2];
54 
55    struct nouveau_bo *interlaced, *full;
56    int mvidx;
57    unsigned frame_num, frame_num_max;
58 };
59 
60 struct nv84_decoder {
61    struct pipe_video_codec base;
62    struct nouveau_client *client;
63    struct nouveau_object *bsp_channel, *vp_channel, *bsp, *vp;
64    struct nouveau_pushbuf *bsp_pushbuf, *vp_pushbuf;
65    struct nouveau_bufctx *bsp_bufctx, *vp_bufctx;
66 
67    struct nouveau_bo *bsp_fw, *bsp_data;
68    struct nouveau_bo *vp_fw, *vp_data;
69    struct nouveau_bo *mbring, *vpring;
70 
71    /*
72     * states:
73     *  0: init
74     *  1: vpring/mbring cleared, bsp is ready
75     *  2: bsp is done, vp is ready
76     * and then vp it back to 1
77     */
78    struct nouveau_bo *fence;
79 
80    struct nouveau_bo *bitstream;
81    struct nouveau_bo *vp_params;
82 
83    size_t vp_fw2_offset;
84 
85    unsigned frame_mbs, frame_size;
86    /* VPRING layout:
87         RESIDUAL
88         CTRL
89         DEBLOCK
90         0x1000
91    */
92    unsigned vpring_deblock, vpring_residual, vpring_ctrl;
93 
94 
95    struct vl_mpg12_bs *mpeg12_bs;
96 
97    struct nouveau_bo *mpeg12_bo;
98    void *mpeg12_mb_info;
99    uint16_t *mpeg12_data;
100    const int *zscan;
101    uint8_t mpeg12_intra_matrix[64];
102    uint8_t mpeg12_non_intra_matrix[64];
103 };
104 
mb(uint32_t coord)105 static inline uint32_t mb(uint32_t coord)
106 {
107    return (coord + 0xf)>>4;
108 }
109 
mb_half(uint32_t coord)110 static inline uint32_t mb_half(uint32_t coord)
111 {
112    return (coord + 0x1f)>>5;
113 }
114 
115 int
116 nv84_decoder_bsp(struct nv84_decoder *dec,
117                  struct pipe_h264_picture_desc *desc,
118                  unsigned num_buffers,
119                  const void *const *data,
120                  const unsigned *num_bytes,
121                  struct nv84_video_buffer *dest);
122 
123 void
124 nv84_decoder_vp_h264(struct nv84_decoder *dec,
125                      struct pipe_h264_picture_desc *desc,
126                      struct nv84_video_buffer *dest);
127 
128 void
129 nv84_decoder_vp_mpeg12_mb(struct nv84_decoder *dec,
130                           struct pipe_mpeg12_picture_desc *desc,
131                           const struct pipe_mpeg12_macroblock *mb);
132 
133 void
134 nv84_decoder_vp_mpeg12(struct nv84_decoder *dec,
135                        struct pipe_mpeg12_picture_desc *desc,
136                        struct nv84_video_buffer *dest);
137 
138 #endif
139