/*
* Copyright (c) 2011 Intel Corporation. All Rights Reserved.
* Copyright (c) Imagination Technologies Limited, UK
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sub license, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice (including the
* next paragraph) shall be included in all copies or substantial portions
* of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
* IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
* ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
* Authors:
* Waldo Bastian <waldo.bastian@intel.com>
*
*/
#ifndef _PSB_BUFFER_H_
#define _PSB_BUFFER_H_
#include "psb_drv_video.h"
//#include "xf86mm.h"
/* For TopazSC, it indicates the next frame should be skipped */
#define SKIP_NEXT_FRAME 0x800
typedef struct psb_buffer_s *psb_buffer_p;
/* VPU = MSVDX */
typedef enum psb_buffer_type_e {
psb_bt_cpu_vpu = 0, /* Shared between CPU & Video PU */
psb_bt_cpu_vpu_shared, /* CPU/VPU can access, and can shared by other process */
psb_bt_surface, /* linear surface */
psb_bt_surface_tt, /* surface allocated in TT*/
#ifdef PSBVIDEO_MSVDX_DEC_TILING
psb_bt_mmu_tiling, /* Tiled surface */
psb_bt_surface_tiling, /* Tiled surface */
#endif
psb_bt_vpu_only, /* Only used by Video PU */
psb_bt_cpu_only, /* Only used by CPU */
psb_bt_camera, /* memory is camera device memory */
psb_bt_imr, /* global RAR buffer */
psb_bt_imr_surface, /* memory is RAR device memory for protected surface*/
psb_bt_imr_slice, /* memory is RAR device memory for slice data */
psb_bt_user_buffer, /* memory is from user buffers */
psb_bt_cpu_vpu_cached /* Cached & CPU/VPU can access */
} psb_buffer_type_t;
typedef enum psb_buffer_status_e {
psb_bs_unfinished = 0,
psb_bs_ready,
psb_bs_queued,
psb_bs_abandoned
} psb_buffer_status_t;
struct psb_buffer_s {
struct _WsbmBufferObject *drm_buf;
int wsbm_synccpu_flag;
uint64_t pl_flags;
psb_buffer_type_t type;
psb_buffer_status_t status;
uint32_t rar_handle;
unsigned int buffer_ofs; /* several buffers may share one BO (camera/RAR), and use offset to distinguish it */
struct psb_buffer_s *next;
unsigned char *user_ptr; /* user pointer for user buffers */
psb_driver_data_p driver_data; /* for RAR buffer release */
uint32_t size;
void *handle;
unsigned char *virtual_addr;
int unfence_flag;
};
/*
* Create buffer
*/
VAStatus psb_buffer_create(psb_driver_data_p driver_data,
unsigned int size,
psb_buffer_type_t type,
psb_buffer_p buf
);
/* flags: 0 indicates cache */
#define PSB_USER_BUFFER_UNCACHED (0x1)
#define PSB_USER_BUFFER_WC (0x1<<1)
/*
* Create buffer from user ptr
*/
VAStatus psb_buffer_create_from_ub(psb_driver_data_p driver_data,
unsigned int size,
psb_buffer_type_t type,
psb_buffer_p buf,
void * vaddr,
unsigned int flags
);
/*
* Setstatus Buffer
*/
int psb_buffer_setstatus(psb_buffer_p buf, uint32_t set_placement, uint32_t clr_placement);
/*
* Reference buffer
*/
VAStatus psb_buffer_reference(psb_driver_data_p driver_data,
psb_buffer_p buf,
psb_buffer_p reference_buf
);
/*
*
*/
VAStatus psb_kbuffer_reference(psb_driver_data_p driver_data,
psb_buffer_p buf,
int kbuf_handle
);
/*
* Suspend buffer
*/
void psb__suspend_buffer(psb_driver_data_p driver_data, object_buffer_p obj_buffer);
/*
* Destroy buffer
*/
void psb_buffer_destroy(psb_buffer_p buf);
/*
* Map buffer
*
* Returns 0 on success
*/
int psb_buffer_map(psb_buffer_p buf, unsigned char **address /* out */);
int psb_codedbuf_map_mangle(
VADriverContextP ctx,
object_buffer_p obj_buffer,
void **pbuf /* out */
);
/*
* Unmap buffer
*
* Returns 0 on success
*/
int psb_buffer_unmap(psb_buffer_p buf);
#if PSB_MFLD_DUMMY_CODE
/*
* Create buffer from camera device memory
*/
VAStatus psb_buffer_create_camera(psb_driver_data_p driver_data,
psb_buffer_p buf,
int is_v4l2,
int id_or_ofs
);
/*
* Create one buffer from user buffer
* id_or_ofs is CI frame ID (actually now is frame offset), or V4L2 buffer offset
* user_ptr :virtual address of user buffer start.
*/
VAStatus psb_buffer_create_camera_from_ub(psb_driver_data_p driver_data,
psb_buffer_p buf,
int id_or_ofs,
int size,
const unsigned long * user_ptr);
#endif
VAStatus psb_buffer_reference_imr(psb_driver_data_p driver_data,
uint32_t imr_offset,
psb_buffer_p buf
);
#endif /* _PSB_BUFFER_H_ */