1 /*
2  * Copyright (c) 2011 Intel Corporation. All Rights Reserved.
3  * Copyright (c) Imagination Technologies Limited, UK
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the
7  * "Software"), to deal in the Software without restriction, including
8  * without limitation the rights to use, copy, modify, merge, publish,
9  * distribute, sub license, and/or sell copies of the Software, and to
10  * permit persons to whom the Software is furnished to do so, subject to
11  * the following conditions:
12  *
13  * The above copyright notice and this permission notice (including the
14  * next paragraph) shall be included in all copies or substantial portions
15  * of the Software.
16  *
17  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
18  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
19  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
20  * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
21  * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
22  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
23  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
24  *
25  * Authors:
26  *    Waldo Bastian <waldo.bastian@intel.com>
27  *
28  */
29 
30 #ifndef _PSB_BUFFER_H_
31 #define _PSB_BUFFER_H_
32 
33 #include "psb_drv_video.h"
34 
35 //#include "xf86mm.h"
36 
37 /* For TopazSC, it indicates the next frame should be skipped */
38 #define SKIP_NEXT_FRAME   0x800
39 
40 typedef struct psb_buffer_s *psb_buffer_p;
41 
42 /* VPU = MSVDX */
43 typedef enum psb_buffer_type_e {
44     psb_bt_cpu_vpu = 0,                 /* Shared between CPU & Video PU */
45     psb_bt_cpu_vpu_shared,              /* CPU/VPU can access, and can shared by other process */
46     psb_bt_surface,                     /* linear surface */
47     psb_bt_surface_tt,                  /* surface allocated in TT*/
48 #ifdef PSBVIDEO_MSVDX_DEC_TILING
49     psb_bt_mmu_tiling,              /* Tiled surface */
50     psb_bt_surface_tiling,              /* Tiled surface */
51 #endif
52     psb_bt_vpu_only,                    /* Only used by Video PU */
53     psb_bt_cpu_only,                    /* Only used by CPU */
54     psb_bt_camera,                      /* memory is camera device memory */
55     psb_bt_imr,                         /* global RAR buffer */
56     psb_bt_imr_surface,                 /* memory is RAR device memory for protected surface*/
57     psb_bt_imr_slice,                   /* memory is RAR device memory for slice data */
58     psb_bt_user_buffer,                 /* memory is from user buffers */
59     psb_bt_cpu_vpu_cached               /* Cached & CPU/VPU can access */
60 } psb_buffer_type_t;
61 
62 typedef enum psb_buffer_status_e {
63     psb_bs_unfinished = 0,
64     psb_bs_ready,
65     psb_bs_queued,
66     psb_bs_abandoned
67 } psb_buffer_status_t;
68 
69 struct psb_buffer_s {
70     struct _WsbmBufferObject *drm_buf;
71     int wsbm_synccpu_flag;
72     uint64_t pl_flags;
73 
74     psb_buffer_type_t type;
75     psb_buffer_status_t status;
76     uint32_t rar_handle;
77     unsigned int buffer_ofs; /* several buffers may share one BO (camera/RAR), and use offset to distinguish it */
78     struct psb_buffer_s *next;
79     unsigned char *user_ptr; /* user pointer for user buffers */
80     psb_driver_data_p driver_data; /* for RAR buffer release */
81     uint32_t size;
82     void *handle;
83 	unsigned char *virtual_addr;
84     int unfence_flag;
85 };
86 
87 /*
88  * Create buffer
89  */
90 VAStatus psb_buffer_create(psb_driver_data_p driver_data,
91                            unsigned int size,
92                            psb_buffer_type_t type,
93                            psb_buffer_p buf
94                           );
95 /* flags: 0 indicates cache */
96 #define PSB_USER_BUFFER_UNCACHED	(0x1)
97 #define PSB_USER_BUFFER_WC		(0x1<<1)
98 /*
99  * Create buffer from user ptr
100  */
101 VAStatus psb_buffer_create_from_ub(psb_driver_data_p driver_data,
102                            unsigned int size,
103                            psb_buffer_type_t type,
104                            psb_buffer_p buf,
105                            void * vaddr,
106                            unsigned int flags
107                           );
108 
109 /*
110  * Setstatus Buffer
111  */
112 int psb_buffer_setstatus(psb_buffer_p buf, uint32_t set_placement, uint32_t clr_placement);
113 
114 
115 /*
116  * Reference buffer
117  */
118 VAStatus psb_buffer_reference(psb_driver_data_p driver_data,
119                               psb_buffer_p buf,
120                               psb_buffer_p reference_buf
121                              );
122 /*
123  *
124  */
125 VAStatus psb_kbuffer_reference(psb_driver_data_p driver_data,
126                                psb_buffer_p buf,
127                                int kbuf_handle
128                               );
129 
130 /*
131  * Suspend buffer
132  */
133 void psb__suspend_buffer(psb_driver_data_p driver_data, object_buffer_p obj_buffer);
134 
135 /*
136  * Destroy buffer
137  */
138 void psb_buffer_destroy(psb_buffer_p buf);
139 
140 /*
141  * Map buffer
142  *
143  * Returns 0 on success
144  */
145 int psb_buffer_map(psb_buffer_p buf, unsigned char **address /* out */);
146 
147 int psb_codedbuf_map_mangle(
148     VADriverContextP ctx,
149     object_buffer_p obj_buffer,
150     void **pbuf /* out */
151 );
152 
153 
154 /*
155  * Unmap buffer
156  *
157  * Returns 0 on success
158  */
159 int psb_buffer_unmap(psb_buffer_p buf);
160 
161 #if PSB_MFLD_DUMMY_CODE
162 /*
163  * Create buffer from camera device memory
164  */
165 VAStatus psb_buffer_create_camera(psb_driver_data_p driver_data,
166                                   psb_buffer_p buf,
167                                   int is_v4l2,
168                                   int id_or_ofs
169                                  );
170 
171 /*
172  * Create one buffer from user buffer
173  * id_or_ofs is CI frame ID (actually now is frame offset), or V4L2 buffer offset
174  * user_ptr :virtual address of user buffer start.
175  */
176 VAStatus psb_buffer_create_camera_from_ub(psb_driver_data_p driver_data,
177         psb_buffer_p buf,
178         int id_or_ofs,
179         int size,
180         const unsigned long * user_ptr);
181 #endif
182 VAStatus psb_buffer_reference_imr(psb_driver_data_p driver_data,
183                                   uint32_t imr_offset,
184                                   psb_buffer_p buf
185                                  );
186 
187 #endif /* _PSB_BUFFER_H_ */
188