mirror of
https://github.com/nyanmisaka/mpp.git
synced 2025-10-05 17:16:50 +08:00
[osal]: add NORMAL path on android
git-svn-id: https://10.10.10.66:8443/svn/MediaProcessPlatform/trunk/mpp@140 6e48237b-75ef-9749-8fc9-41990f28c85a
This commit is contained in:
@@ -143,7 +143,7 @@ typedef enum {
|
||||
typedef union MppBufferData_t MppBufferData;
|
||||
union MppBufferData_t {
|
||||
void *ptr;
|
||||
RK_S32 fd;
|
||||
int fd;
|
||||
};
|
||||
|
||||
typedef struct {
|
||||
|
@@ -25,9 +25,10 @@
|
||||
#include "mpp_log.h"
|
||||
|
||||
typedef struct {
|
||||
MppBufferType type;
|
||||
RK_S32 ion_device;
|
||||
RK_U32 alignment;
|
||||
} allocator_ion;
|
||||
} allocator_impl;
|
||||
|
||||
static int ion_open()
|
||||
{
|
||||
@@ -87,7 +88,6 @@ static int ion_free(int fd, ion_user_handle_t handle)
|
||||
|
||||
static int ion_share(int fd, ion_user_handle_t handle, int *share_fd)
|
||||
{
|
||||
int map_fd;
|
||||
int ret;
|
||||
struct ion_fd_data data = {
|
||||
.handle = handle,
|
||||
@@ -121,64 +121,125 @@ static int ion_alloc_fd(int fd, size_t len, size_t align, unsigned int heap_mask
|
||||
return ret;
|
||||
}
|
||||
|
||||
int os_allocator_open(void **ctx, size_t alignment)
|
||||
MPP_RET os_allocator_open(void **ctx, size_t alignment, MppBufferType type)
|
||||
{
|
||||
allocator_ion *p = NULL;
|
||||
allocator_impl *p = NULL;
|
||||
|
||||
if (NULL == ctx) {
|
||||
mpp_err("os_allocator_open Android do not accept NULL input\n");
|
||||
return MPP_ERR_NULL_PTR;
|
||||
}
|
||||
|
||||
p = mpp_malloc(allocator_ion, 1);
|
||||
p = mpp_malloc(allocator_impl, 1);
|
||||
if (NULL == p) {
|
||||
*ctx = NULL;
|
||||
mpp_err("os_allocator_open Android failed to allocate context\n");
|
||||
return MPP_ERR_MALLOC;
|
||||
}
|
||||
|
||||
switch (type) {
|
||||
case MPP_BUFFER_TYPE_NORMAL :
|
||||
case MPP_BUFFER_TYPE_ION : {
|
||||
p = mpp_malloc(allocator_impl, 1);
|
||||
if (NULL == p) {
|
||||
*ctx = NULL;
|
||||
mpp_err("os_allocator_open Android failed to allocate context\n");
|
||||
return MPP_ERR_MALLOC;
|
||||
}
|
||||
|
||||
p->ion_device = ion_open();
|
||||
p->alignment = alignment;
|
||||
p->type = type;
|
||||
if (MPP_BUFFER_TYPE_ION == type)
|
||||
p->ion_device = ion_open();
|
||||
} break;
|
||||
default : {
|
||||
mpp_err("os_allocator_open Window do not accept type %d\n");
|
||||
} break;
|
||||
}
|
||||
|
||||
*ctx = p;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int os_allocator_alloc(void *ctx, MppBufferData *data, size_t size)
|
||||
MPP_RET os_allocator_alloc(void *ctx, MppBufferData *data, size_t size)
|
||||
{
|
||||
allocator_ion *p = NULL;
|
||||
MPP_RET ret = MPP_OK;
|
||||
allocator_impl *p = NULL;
|
||||
|
||||
if (NULL == ctx) {
|
||||
mpp_err("os_allocator_close Android do not accept NULL input\n");
|
||||
return MPP_ERR_NULL_PTR;
|
||||
}
|
||||
|
||||
p = (allocator_ion *)ctx;
|
||||
p = (allocator_impl *)ctx;
|
||||
|
||||
return (MPP_RET)os_malloc(&data->ptr, p->alignment, size);
|
||||
switch (p->type) {
|
||||
case MPP_BUFFER_TYPE_NORMAL : {
|
||||
ret = os_malloc(&data->ptr, p->alignment, size);
|
||||
} break;
|
||||
case MPP_BUFFER_TYPE_ION : {
|
||||
ret = ion_alloc_fd(p->ion_device, size, p->alignment, ION_HEAP_TYPE_CARVEOUT, 0, &data->fd);
|
||||
} break;
|
||||
default : {
|
||||
mpp_err("os_allocator_alloc Linux do not accept type %d\n", p->type);
|
||||
ret = MPP_ERR_UNKNOW;
|
||||
} break;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
void os_allocator_free(void *ctx, MppBufferData *data)
|
||||
MPP_RET os_allocator_free(void *ctx, MppBufferData *data)
|
||||
{
|
||||
allocator_ion *p = NULL;
|
||||
MPP_RET ret = MPP_OK;
|
||||
allocator_impl *p = NULL;
|
||||
|
||||
if (NULL == ctx) {
|
||||
mpp_err("os_allocator_close Android do not accept NULL input\n");
|
||||
return ;
|
||||
return MPP_ERR_NULL_PTR;
|
||||
}
|
||||
|
||||
p = (allocator_impl *)ctx;
|
||||
|
||||
switch (p->type) {
|
||||
case MPP_BUFFER_TYPE_NORMAL : {
|
||||
os_free(data->ptr);
|
||||
} break;
|
||||
case MPP_BUFFER_TYPE_ION : {
|
||||
close(data->fd);
|
||||
} break;
|
||||
default : {
|
||||
mpp_err("os_allocator_alloc Linux do not accept type %d\n", p->type);
|
||||
ret = MPP_ERR_UNKNOW;
|
||||
} break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
void os_allocator_close(void *ctx)
|
||||
MPP_RET os_allocator_close(void *ctx)
|
||||
{
|
||||
allocator_ion *p = NULL;
|
||||
MPP_RET ret = MPP_OK;
|
||||
allocator_impl *p = NULL;
|
||||
|
||||
if (NULL == ctx) {
|
||||
mpp_err("os_allocator_close Android do not accept NULL input\n");
|
||||
return ;
|
||||
return MPP_ERR_NULL_PTR;
|
||||
}
|
||||
|
||||
p = (allocator_ion *)ctx;
|
||||
p = (allocator_impl *)ctx;
|
||||
|
||||
switch (p->type) {
|
||||
case MPP_BUFFER_TYPE_NORMAL : {
|
||||
} break;
|
||||
case MPP_BUFFER_TYPE_ION : {
|
||||
ion_close(p->ion_device);
|
||||
} break;
|
||||
default : {
|
||||
mpp_err("os_allocator_alloc Linux do not accept type %d\n", p->type);
|
||||
ret = MPP_ERR_UNKNOW;
|
||||
} break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@@ -50,6 +50,7 @@ MPP_RET os_allocator_open(void **ctx, size_t alignment, MppBufferType type)
|
||||
}
|
||||
|
||||
p->alignment = alignment;
|
||||
p->type = type;
|
||||
} break;
|
||||
default : {
|
||||
mpp_err("os_allocator_open Window do not accept type %d\n");
|
||||
|
Reference in New Issue
Block a user