Files
mpp/osal/allocator/allocator_std.c
Herman Chen 6ce3007994 refactor[allocator]: Refactor allocator flow
1. Allocator api is determined by buffer type.
2. Allocator ctx is determined by both buffer type and buffer flags.
3. All allocator dma_heap / drm / ion / ext_dma should support different
buffer flags.
4. The buffer flag supports cacheable / 32-bit / contig options.
5. Add flags update flow on allocator create process.
6. Add mpp_dmabuf_has_partial_ops to disable dmabuf partial ops when the
kernel driver has bug.

Signed-off-by: Herman Chen <herman.chen@rock-chips.com>
Change-Id: If36a05c6704112cad3ab46861023597ff02bf14c
2023-11-29 09:54:36 +08:00

128 lines
3.0 KiB
C

/*
* Copyright 2015 Rockchip Electronics Co. LTD
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include <stdio.h>
#include "os_mem.h"
#include "mpp_mem.h"
#include "mpp_debug.h"
#include "allocator_std.h"
typedef struct {
size_t alignment;
MppAllocFlagType flags;
RK_S32 fd_count;
} allocator_ctx;
static MPP_RET allocator_std_open(void **ctx, size_t alignment, MppAllocFlagType flags)
{
allocator_ctx *p = NULL;
if (NULL == ctx) {
mpp_err_f("do not accept NULL input\n");
return MPP_ERR_NULL_PTR;
}
mpp_err_f("Warning: std allocator should be used on simulation mode only\n");
p = mpp_malloc(allocator_ctx, 1);
if (p) {
p->alignment = alignment;
p->flags = flags;
p->fd_count = 0;
}
*ctx = p;
return p ? MPP_OK : MPP_NOK;
}
static MPP_RET allocator_std_alloc(void *ctx, MppBufferInfo *info)
{
if (NULL == ctx) {
mpp_err_f("found NULL context input\n");
return MPP_ERR_NULL_PTR;
}
mpp_err_f("Warning: std allocator should be used on simulation mode only\n");
(void)info;
return MPP_NOK;
}
static MPP_RET allocator_std_free(void *ctx, MppBufferInfo *info)
{
(void) ctx;
if (info->ptr)
os_free(info->ptr);
return MPP_OK;
}
static MPP_RET allocator_std_import(void *ctx, MppBufferInfo *info)
{
allocator_ctx *p = (allocator_ctx *)ctx;
mpp_assert(ctx);
mpp_assert(info->ptr);
mpp_assert(info->size);
info->hnd = NULL;
info->fd = p->fd_count++;
return MPP_OK;
}
static MPP_RET allocator_std_release(void *ctx, MppBufferInfo *info)
{
(void) ctx;
mpp_assert(info->ptr);
mpp_assert(info->size);
info->ptr = NULL;
info->size = 0;
info->hnd = NULL;
info->fd = -1;
return MPP_OK;
}
static MPP_RET allocator_std_mmap(void *ctx, MppBufferInfo *info)
{
mpp_assert(ctx);
mpp_assert(info->ptr);
mpp_assert(info->size);
return MPP_OK;
}
static MPP_RET allocator_std_close(void *ctx)
{
MPP_FREE(ctx);
return MPP_OK;
}
static MppAllocFlagType os_allocator_std_flags(void *ctx)
{
(void) ctx;
return MPP_ALLOC_FLAG_NONE;
}
os_allocator allocator_std = {
.type = MPP_BUFFER_TYPE_NORMAL,
.open = allocator_std_open,
.close = allocator_std_close,
.alloc = allocator_std_alloc,
.free = allocator_std_free,
.import = allocator_std_import,
.release = allocator_std_release,
.mmap = allocator_std_mmap,
.flags = os_allocator_std_flags,
};