#include "tbm_bufmgr_tgl.h"
//#define USE_CONTIG_ONLY
+//#define USE_CACHE
#define USE_DMAIMPORT
#define TBM_COLOR_FORMAT_COUNT 4
uint32_t tbm_sprd_color_format_list[TBM_COLOR_FORMAT_COUNT] = {
- TBM_FORMAT_ARGB8888,
- TBM_FORMAT_XRGB8888,
- TBM_FORMAT_NV12,
- TBM_FORMAT_YUV420
- };
+ TBM_FORMAT_ARGB8888,
+ TBM_FORMAT_XRGB8888,
+ TBM_FORMAT_NV12,
+ TBM_FORMAT_YUV420
+ };
+
+static inline int
+_tgl_get_version(int fd)
+{
+ struct tgl_ver_data data;
+ int err;
+
+ err = ioctl(fd, TGL_IOCTL_GET_VERSION, &data);
+ if (err) {
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__);
+ return 0;
+ }
+
+ TBM_SPRD_LOG("[libtbm-sprd:%d] %s:%d tgl version is (%u, %u).\n",
+ getpid(), __func__, __LINE__, data.major, data.minor);
+
+ return 1;
+}
+
static inline int
_tgl_init(int fd, unsigned int key)
{
- struct tgl_attribute attr;
+ struct tgl_reg_data data;
int err;
- attr.key = key;
- attr.timeout_ms = 1000;
+ data.key = key;
+ data.timeout_ms = 1000;
- err = ioctl(fd, TGL_IOC_INIT_LOCK, &attr);
+ err = ioctl(fd, TGL_IOCTL_REGISTER, &data);
if (err) {
TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ getpid(), strerror(errno), __func__, __LINE__, key);
return 0;
}
static inline int
_tgl_destroy(int fd, unsigned int key)
{
+ struct tgl_reg_data data;
int err;
- err = ioctl(fd, TGL_IOC_DESTROY_LOCK, key);
+ data.key = key;
+ err = ioctl(fd, TGL_IOCTL_UNREGISTER, &data);
if (err) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__, key);
return 0;
}
}
static inline int
-_tgl_lock(int fd, unsigned int key)
+_tgl_lock(int fd, unsigned int key, int opt)
{
+ struct tgl_lock_data data;
+ enum tgl_type_data tgl_type;
int err;
- err = ioctl(fd, TGL_IOC_LOCK_LOCK, key);
+ switch (opt) {
+ case TBM_OPTION_READ:
+ tgl_type = TGL_TYPE_READ;
+ break;
+ case TBM_OPTION_WRITE:
+ tgl_type = TGL_TYPE_WRITE;
+ break;
+ default:
+ tgl_type = TGL_TYPE_NONE;
+ break;
+ }
+
+ data.key = key;
+ data.type = tgl_type;
+
+ err = ioctl(fd, TGL_IOCTL_LOCK, data);
if (err) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d opt:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__, key, opt);
return 0;
}
static inline int
_tgl_unlock(int fd, unsigned int key)
{
+ struct tgl_lock_data data;
int err;
- err = ioctl(fd, TGL_IOC_UNLOCK_LOCK, key);
+ data.key = key;
+ data.type = TGL_TYPE_NONE;
+
+ err = ioctl(fd, TGL_IOCTL_UNLOCK, data);
if (err) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__, key);
return 0;
}
static inline int
_tgl_set_data(int fd, unsigned int key, unsigned int val)
{
+ struct tgl_usr_data data;
int err;
- struct tgl_user_data arg;
- arg.key = key;
- arg.data1 = val;
- err = ioctl(fd, TGL_IOC_SET_DATA, &arg);
+ data.key = key;
+ data.data1 = val;
+
+ err = ioctl(fd, TGL_IOCTL_SET_DATA, &data);
if (err) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__, key);
return 0;
}
static inline unsigned int
_tgl_get_data(int fd, unsigned int key, unsigned int *locked)
{
+ struct tgl_usr_data data = { 0, };
int err;
- struct tgl_user_data arg = { 0, };
- arg.key = key;
- err = ioctl(fd, TGL_IOC_GET_DATA, &arg);
+ data.key = key;
+
+ err = ioctl(fd, TGL_IOCTL_GET_DATA, &data);
if (err) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error(%s) %s:%d key:%d\n",
- getpid(), strerror(errno), __func__, __LINE__, key);
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error(%s) %s:%d key:%d\n",
+ getpid(), strerror(errno), __func__, __LINE__, key);
return 0;
}
if (locked)
- *locked = arg.locked;
+ *locked = (unsigned int)data.status;
- return arg.data1;
+ return data.data1;
}
#endif
/* cache flush is managed by kernel side when using dma-fence. */
if (bufmgr_sprd->use_dma_fence)
return 1;
-
+// TODO: The tm1 kernel does not support ioctl for cache flush right now.
+// The drm in tm1 kernel has to support cache_flush to turn on this feature(TBM_SRPD_CACHE_FLUSH).
+#if TBM_SRPD_CACHE_FLUSH
struct drm_sprd_gem_cache_op cache_op = {0, };
int ret;
getpid(), __FUNCTION__, __LINE__);
return 0;
}
-
+#endif
return 1;
}
#endif
/* open tgl fd for saving cache flush data */
bufmgr_sprd->tgl_fd = open(tgl_devfile, O_RDWR);
-
if (bufmgr_sprd->tgl_fd < 0) {
- bufmgr_sprd->tgl_fd = open(tgl_devfile1, O_RDWR);
- if (bufmgr_sprd->tgl_fd < 0) {
- TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error: Fail to open global_lock:%s\n",
- getpid(), tgl_devfile);
- return 0;
- }
+ TBM_SPRD_LOG("[libtbm-sprd:%d] error: Fail to open global_lock:%s\n",
+ getpid(), tgl_devfile);
+ return 0;
+ }
+
+ if (!_tgl_get_version(bufmgr_sprd->tgl_fd)) {
+ TBM_SPRD_LOG("[libtbm-sprd:%d] "
+ "error: fail to get tgl_version. tgl init failed.\n",
+ getpid());
+
+ close(bufmgr_sprd->tgl_fd);
+ return 0;
}
#ifdef USE_CACHE
if (!_tgl_init(bufmgr_sprd->tgl_fd, GLOBAL_KEY)) {
TBM_SPRD_LOG("[libtbm-sprd:%d] "
- "error: Fail to initialize the tgl\n",
- getpid());
+ "error: Fail to initialize the tgl\n",
+ getpid());
close(bufmgr_sprd->tgl_fd);
return 0;
getpid(),
__FUNCTION__, bo_sprd->name, bo_sprd->dmabuf);
} else {
- ret = _tgl_lock(bufmgr_sprd->tgl_fd, bo_sprd->name);
+ ret = _tgl_lock(bufmgr_sprd->tgl_fd, bo_sprd->name, opt);
DBG("[libtbm-sprd:%d] lock tgl flink_id:%d\n",
getpid(), __FUNCTION__, bo_sprd->name);