mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
914 lines
30 KiB
C
914 lines
30 KiB
C
|
/*
|
||
|
* Copyright (C) 2010-2022 Arm Limited or its affiliates. All rights reserved.
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
*
|
||
|
* 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
|
||
|
*
|
||
|
* 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.
|
||
|
*/
|
||
|
|
||
|
/* ----------------------------------------------------------------------
|
||
|
* Project: Arm-2D Library
|
||
|
* Title: arm-2d_draw.c
|
||
|
* Description: APIs for basic drawing
|
||
|
*
|
||
|
* $Date: 21. April 2022
|
||
|
* $Revision: V.1.0.0
|
||
|
*
|
||
|
* Target Processor: Cortex-M cores
|
||
|
*
|
||
|
* -------------------------------------------------------------------- */
|
||
|
|
||
|
|
||
|
/*============================ INCLUDES ======================================*/
|
||
|
#define __ARM_2D_IMPL__
|
||
|
|
||
|
#include "arm_2d.h"
|
||
|
#include "__arm_2d_impl.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#if defined(__clang__)
|
||
|
# pragma clang diagnostic ignored "-Wunknown-warning-option"
|
||
|
# pragma clang diagnostic ignored "-Wreserved-identifier"
|
||
|
# pragma clang diagnostic ignored "-Wincompatible-pointer-types-discards-qualifiers"
|
||
|
# pragma clang diagnostic ignored "-Wmissing-variable-declarations"
|
||
|
# pragma clang diagnostic ignored "-Wcast-qual"
|
||
|
# pragma clang diagnostic ignored "-Wcast-align"
|
||
|
# pragma clang diagnostic ignored "-Wextra-semi-stmt"
|
||
|
# pragma clang diagnostic ignored "-Wsign-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wunused-function"
|
||
|
# pragma clang diagnostic ignored "-Wimplicit-int-float-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wdouble-promotion"
|
||
|
# pragma clang diagnostic ignored "-Wunused-parameter"
|
||
|
# pragma clang diagnostic ignored "-Wimplicit-float-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wimplicit-int-conversion"
|
||
|
# pragma clang diagnostic ignored "-Wtautological-pointer-compare"
|
||
|
# pragma clang diagnostic ignored "-Wsign-compare"
|
||
|
# pragma clang diagnostic ignored "-Wmissing-prototypes"
|
||
|
# pragma clang diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
|
||
|
# pragma clang diagnostic ignored "-Wswitch-enum"
|
||
|
# pragma clang diagnostic ignored "-Wswitch"
|
||
|
# pragma clang diagnostic ignored "-Wdeclaration-after-statement"
|
||
|
#elif defined(__IS_COMPILER_ARM_COMPILER_5__)
|
||
|
# pragma diag_suppress 174,177,188,68,513,144
|
||
|
#endif
|
||
|
|
||
|
/*============================ MACROS ========================================*/
|
||
|
/*============================ MACROFIED FUNCTIONS ===========================*/
|
||
|
/*============================ TYPES =========================================*/
|
||
|
/*============================ GLOBAL VARIABLES ==============================*/
|
||
|
/*============================ PROTOTYPES ====================================*/
|
||
|
/*============================ LOCAL VARIABLES ===============================*/
|
||
|
/*============================ IMPLEMENTATION ================================*/
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Accelerable Low Level APIs *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
|
||
|
/*! adding support with c code template */
|
||
|
|
||
|
#define __API_COLOUR c8bit
|
||
|
#define __API_INT_TYPE uint8_t
|
||
|
|
||
|
#include "__arm_2d_fill_colour.inc"
|
||
|
|
||
|
#define __API_COLOUR rgb16
|
||
|
#define __API_INT_TYPE uint16_t
|
||
|
|
||
|
#include "__arm_2d_fill_colour.inc"
|
||
|
|
||
|
|
||
|
#define __API_COLOUR rgb32
|
||
|
#define __API_INT_TYPE uint32_t
|
||
|
|
||
|
#include "__arm_2d_fill_colour.inc"
|
||
|
|
||
|
|
||
|
/*! adding support with c code template */
|
||
|
#define __API_COLOUR c8bit
|
||
|
#define __API_INT_TYPE uint8_t
|
||
|
#include "__arm_2d_draw_pattern.inc"
|
||
|
|
||
|
#define __API_COLOUR rgb16
|
||
|
#define __API_INT_TYPE uint16_t
|
||
|
#include "__arm_2d_draw_pattern.inc"
|
||
|
|
||
|
|
||
|
#define __API_COLOUR rgb32
|
||
|
#define __API_INT_TYPE uint32_t
|
||
|
#include "__arm_2d_draw_pattern.inc"
|
||
|
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Draw a point with specified colour *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
|
||
|
/*!
|
||
|
* \brief draw a point with a given 8bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target root tile
|
||
|
* \param[in] tLocation the target location
|
||
|
* \param[in] chColour an 8bit colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*
|
||
|
* \note As those draw point APIs involve the region calculation
|
||
|
* which is only useful when partial framebuffer is used, it is slow.
|
||
|
* For gettting better performance, if the target tile is root and the
|
||
|
* target location is inside the target region, please use the
|
||
|
* functions with "_fast" posfix.
|
||
|
*
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_c8bit_draw_point( arm_2d_op_drw_pt_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_location_t tLocation,
|
||
|
uint_fast8_t chColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_pt_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
arm_2d_region_t tPointRegion = {
|
||
|
.tLocation = tLocation,
|
||
|
.tSize = {1,1},
|
||
|
};
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_POINT_C8BIT;
|
||
|
OP_CORE.Preference.u2ACCMethods = ARM_2D_PREF_ACC_SW_ONLY;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = &tPointRegion;
|
||
|
this.chColour = chColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief draw a point with a given 16bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target root tile
|
||
|
* \param[in] tLocation the target location
|
||
|
* \param[in] hwColour an 16bit colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*
|
||
|
* \note As those draw point APIs involve the region calculation
|
||
|
* which is only useful when partial framebuffer is used, it is slow.
|
||
|
* For gettting better performance, if the target tile is root and the
|
||
|
* target location is inside the target region, please use the
|
||
|
* functions with "_fast" posfix.
|
||
|
*
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_rgb16_draw_point( arm_2d_op_drw_pt_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_location_t tLocation,
|
||
|
uint_fast16_t hwColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_pt_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
arm_2d_region_t tPointRegion = {
|
||
|
.tLocation = tLocation,
|
||
|
.tSize = {1,1},
|
||
|
};
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_POINT_RGB16;
|
||
|
OP_CORE.Preference.u2ACCMethods = ARM_2D_PREF_ACC_SW_ONLY;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = &tPointRegion;
|
||
|
this.hwColour = hwColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief draw a point with a given 32bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target root tile
|
||
|
* \param[in] tLocation the target location
|
||
|
* \param[in] wColour an 32bit colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*
|
||
|
* \note As those draw point APIs involve the region calculation
|
||
|
* which is only useful when partial framebuffer is used, it is slow.
|
||
|
* For gettting better performance, if the target tile is root and the
|
||
|
* target location is inside the target region, please use the
|
||
|
* functions with "_fast" posfix.
|
||
|
*
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_rgb32_draw_point( arm_2d_op_drw_pt_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_location_t tLocation,
|
||
|
uint32_t wColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_pt_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
arm_2d_region_t tPointRegion = {
|
||
|
.tLocation = tLocation,
|
||
|
.tSize = {1,1},
|
||
|
};
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_POINT_RGB32;
|
||
|
OP_CORE.Preference.u2ACCMethods = ARM_2D_PREF_ACC_SW_ONLY;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = &tPointRegion;
|
||
|
this.wColour = wColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_sw_draw_point(__arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_pt_t, ptTask->ptOP)
|
||
|
|
||
|
switch (OP_CORE.ptOp->Info.Colour.u3ColourSZ) {
|
||
|
case ARM_2D_COLOUR_SZ_8BIT:
|
||
|
(*(uint8_t *)ptTask->Param.tTileProcess.pBuffer) = this.chColour;
|
||
|
break;
|
||
|
case ARM_2D_COLOUR_SZ_16BIT:
|
||
|
(*(uint16_t *)ptTask->Param.tTileProcess.pBuffer) = this.hwColour;
|
||
|
break;
|
||
|
case ARM_2D_COLOUR_SZ_32BIT:
|
||
|
(*(uint32_t *)ptTask->Param.tTileProcess.pBuffer) = this.wColour;
|
||
|
break;
|
||
|
default:
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Fill tile with a specified colour *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
|
||
|
/*!
|
||
|
* \brief fill the target region with a given 8bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] chColour a 8bit colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_c8bit_fill_colour( arm_2d_op_fill_cl_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint_fast8_t chColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_FILL_COLOUR_C8BIT;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.chColour = chColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief fill the target region with a given 16bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] hwColour a 16bit colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_rgb16_fill_colour( arm_2d_op_fill_cl_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint_fast16_t hwColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_FILL_COLOUR_RGB16;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.hwColour = hwColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief fill the target region with a given 32bit colour
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] wColour a 32bit colour
|
||
|
* \return arm_fsm_rt_t the operations result
|
||
|
*/
|
||
|
ARM_NONNULL(2)
|
||
|
arm_fsm_rt_t arm_2dp_rgb32_fill_colour( arm_2d_op_fill_cl_t *ptOP,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint32_t wColour)
|
||
|
{
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptOP);
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_FILL_COLOUR_RGB32;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.wColour = wColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_c8bit_sw_colour_filling(__arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptTask->ptOP)
|
||
|
assert(ARM_2D_COLOUR_SZ_8BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
|
||
|
__arm_2d_impl_c8bit_colour_filling(
|
||
|
ptTask->Param.tTileProcess.pBuffer,
|
||
|
ptTask->Param.tTileProcess.iStride,
|
||
|
&(ptTask->Param.tTileProcess.tValidRegion.tSize),
|
||
|
this.chColour);
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_rgb16_sw_colour_filling(__arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptTask->ptOP)
|
||
|
assert(ARM_2D_COLOUR_SZ_16BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
|
||
|
__arm_2d_impl_rgb16_colour_filling(
|
||
|
ptTask->Param.tTileProcess.pBuffer,
|
||
|
ptTask->Param.tTileProcess.iStride,
|
||
|
&(ptTask->Param.tTileProcess.tValidRegion.tSize),
|
||
|
this.hwColour);
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_rgb32_sw_colour_filling(__arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_fill_cl_t, ptTask->ptOP)
|
||
|
assert(ARM_2D_COLOUR_SZ_32BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
|
||
|
__arm_2d_impl_rgb32_colour_filling(
|
||
|
ptTask->Param.tTileProcess.pBuffer,
|
||
|
ptTask->Param.tTileProcess.iStride,
|
||
|
&(ptTask->Param.tTileProcess.tValidRegion.tSize),
|
||
|
this.wColour);
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Draw a bit patterns *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
|
||
|
/*!
|
||
|
* \brief copy a bit-pattern with given 8bit colours
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptPattern the source bit pattern
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] wMode the copy mode
|
||
|
* \param[in] chForeColour the foreground colour
|
||
|
* \param[in] chBackColour the background colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*/
|
||
|
ARM_NONNULL(2,3)
|
||
|
arm_fsm_rt_t arm_2dp_c8bit_draw_pattern( arm_2d_op_drw_patn_t *ptOP,
|
||
|
const arm_2d_tile_t *ptPattern,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint32_t wMode,
|
||
|
uint8_t chForeColour,
|
||
|
uint8_t chBackColour)
|
||
|
{
|
||
|
assert(NULL != ptPattern);
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptOP);
|
||
|
|
||
|
|
||
|
if ( (wMode & (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR |
|
||
|
ARM_2D_DRW_PATH_MODE_COMP_FG_COLOUR |
|
||
|
ARM_2D_DRW_PATN_MODE_WITH_BG_COLOR ))
|
||
|
== (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR)) {
|
||
|
|
||
|
//! nothing todo
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_PATTERN_C8BIT;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.Source.ptTile = ptPattern;
|
||
|
this.wMode = wMode;
|
||
|
this.Foreground.chColour = chForeColour;
|
||
|
this.Background.chColour = chBackColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief copy a bit-pattern with given 16bit colours
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptPattern the source bit pattern
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] wMode the copy mode
|
||
|
* \param[in] hwForeColour the foreground colour
|
||
|
* \param[in] hwBackColour the background colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*/
|
||
|
ARM_NONNULL(2,3)
|
||
|
arm_fsm_rt_t arm_2dp_rgb16_draw_pattern( arm_2d_op_drw_patn_t *ptOP,
|
||
|
const arm_2d_tile_t *ptPattern,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint32_t wMode,
|
||
|
uint16_t hwForeColour,
|
||
|
uint16_t hwBackColour)
|
||
|
{
|
||
|
assert(NULL != ptPattern);
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptOP);
|
||
|
|
||
|
if ( (wMode & (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR |
|
||
|
ARM_2D_DRW_PATH_MODE_COMP_FG_COLOUR |
|
||
|
ARM_2D_DRW_PATN_MODE_WITH_BG_COLOR ))
|
||
|
== (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR)) {
|
||
|
|
||
|
//! nothing todo
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_PATTERN_RGB16;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.Source.ptTile = ptPattern;
|
||
|
this.wMode = wMode;
|
||
|
this.Foreground.hwColour = hwForeColour;
|
||
|
this.Background.hwColour = hwBackColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
/*!
|
||
|
* \brief copy a bit-pattern with given 32bit colours
|
||
|
* \param[in] ptOP the control block, NULL means using the default control block
|
||
|
* \param[in] ptPattern the source bit pattern
|
||
|
* \param[in] ptTarget the target tile
|
||
|
* \param[in] ptRegion the target region
|
||
|
* \param[in] wMode the copy mode
|
||
|
* \param[in] wForeColour the foreground colour
|
||
|
* \param[in] wBackColour the background colour
|
||
|
* \return arm_fsm_rt_t the operation result
|
||
|
*/
|
||
|
ARM_NONNULL(2,3)
|
||
|
arm_fsm_rt_t arm_2dp_rgb32_draw_pattern(arm_2d_op_drw_patn_t *ptOP,
|
||
|
const arm_2d_tile_t *ptPattern,
|
||
|
const arm_2d_tile_t *ptTarget,
|
||
|
const arm_2d_region_t *ptRegion,
|
||
|
uint32_t wMode,
|
||
|
uint32_t wForeColour,
|
||
|
uint32_t wBackColour)
|
||
|
{
|
||
|
|
||
|
assert(NULL != ptPattern);
|
||
|
assert(NULL != ptTarget);
|
||
|
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptOP);
|
||
|
|
||
|
|
||
|
if ( (wMode & (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR |
|
||
|
ARM_2D_DRW_PATH_MODE_COMP_FG_COLOUR |
|
||
|
ARM_2D_DRW_PATN_MODE_WITH_BG_COLOR ))
|
||
|
== (ARM_2D_DRW_PATN_MODE_NO_FG_COLOR)) {
|
||
|
|
||
|
//! nothing todo
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
if (!__arm_2d_op_acquire((arm_2d_op_core_t *)ptThis)) {
|
||
|
return arm_fsm_rt_on_going;
|
||
|
}
|
||
|
|
||
|
//memset(ptThis, 0, sizeof(*ptThis));
|
||
|
|
||
|
|
||
|
OP_CORE.ptOp = &ARM_2D_OP_DRAW_PATTERN_RGB32;
|
||
|
|
||
|
this.Target.ptTile = ptTarget;
|
||
|
this.Target.ptRegion = ptRegion;
|
||
|
this.Source.ptTile = ptPattern;
|
||
|
this.wMode = wMode;
|
||
|
this.Foreground.wColour = wForeColour;
|
||
|
this.Background.wColour = wBackColour;
|
||
|
|
||
|
return __arm_2d_op_invoke((arm_2d_op_core_t *)ptThis);
|
||
|
}
|
||
|
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_c8bit_sw_draw_pattern( __arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptTask->ptOP);
|
||
|
assert(ARM_2D_COLOUR_SZ_8BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
uint32_t wMode = this.wMode;
|
||
|
|
||
|
#if 0
|
||
|
if (!this.Source.ptTile->bHasEnforcedColour) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
|
||
|
if (ARM_2D_COLOUR_SZ_1BIT != this.Source.ptTile->tColourInfo.u3ColourSZ) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
if (wMode & (ARM_2D_CP_MODE_Y_MIRROR | ARM_2D_CP_MODE_X_MIRROR)) {
|
||
|
#if 0
|
||
|
//! todo: add support for mirror
|
||
|
__arm_2d_impl_c8bit_draw_pattern_with_mirror(
|
||
|
ptTask->Param.tCopy.pSource ,
|
||
|
ptTask->Param.tCopy.iSourceStride,
|
||
|
ptTask->Param.tCopy.pTarget,
|
||
|
ptTask->Param.tCopy.iTargetStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode);
|
||
|
break;
|
||
|
#else
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
#endif
|
||
|
} else {
|
||
|
//! draw bit-pattern
|
||
|
__arm_2d_impl_c8bit_draw_pattern(
|
||
|
ptTask->Param.tCopy.tSource.pBuffer,
|
||
|
ptTask->Param.tCopy.tSource.nOffset,
|
||
|
ptTask->Param.tCopy.tSource.iStride,
|
||
|
ptTask->Param.tCopy.tTarget.pBuffer,
|
||
|
ptTask->Param.tCopy.tTarget.iStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode,
|
||
|
this.Foreground.hwColour,
|
||
|
this.Background.hwColour);
|
||
|
}
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_rgb16_sw_draw_pattern( __arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptTask->ptOP);
|
||
|
assert(ARM_2D_COLOUR_SZ_16BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
uint32_t wMode = this.wMode;
|
||
|
|
||
|
#if 0
|
||
|
if (!this.Source.ptTile->bHasEnforcedColour) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
|
||
|
if (ARM_2D_COLOUR_SZ_1BIT != this.Source.ptTile->tColourInfo.u3ColourSZ) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
if (wMode & (ARM_2D_CP_MODE_Y_MIRROR | ARM_2D_CP_MODE_X_MIRROR)) {
|
||
|
#if 0
|
||
|
//! todo: add support for mirror
|
||
|
__arm_2d_impl_rgb16_draw_pattern_with_mirror(
|
||
|
ptTask->Param.tCopy.pSource ,
|
||
|
ptTask->Param.tCopy.iSourceStride,
|
||
|
ptTask->Param.tCopy.pTarget,
|
||
|
ptTask->Param.tCopy.iTargetStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode);
|
||
|
break;
|
||
|
#else
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
#endif
|
||
|
} else {
|
||
|
//! draw bit-pattern
|
||
|
__arm_2d_impl_rgb16_draw_pattern(
|
||
|
ptTask->Param.tCopy.tSource.pBuffer,
|
||
|
ptTask->Param.tCopy.tSource.nOffset,
|
||
|
ptTask->Param.tCopy.tSource.iStride,
|
||
|
ptTask->Param.tCopy.tTarget.pBuffer,
|
||
|
ptTask->Param.tCopy.tTarget.iStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode,
|
||
|
this.Foreground.hwColour,
|
||
|
this.Background.hwColour);
|
||
|
}
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
arm_fsm_rt_t __arm_2d_rgb32_sw_draw_pattern( __arm_2d_sub_task_t *ptTask)
|
||
|
{
|
||
|
ARM_2D_IMPL(arm_2d_op_drw_patn_t, ptTask->ptOP);
|
||
|
assert(ARM_2D_COLOUR_SZ_32BIT == OP_CORE.ptOp->Info.Colour.u3ColourSZ);
|
||
|
uint32_t wMode = this.wMode;
|
||
|
|
||
|
#if 0
|
||
|
if (!this.Source.ptTile->bHasEnforcedColour) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
|
||
|
if (ARM_2D_COLOUR_SZ_1BIT != this.Source.ptTile->tColourInfo.u3ColourSZ) {
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
if (wMode & (ARM_2D_CP_MODE_Y_MIRROR | ARM_2D_CP_MODE_X_MIRROR)) {
|
||
|
#if 0
|
||
|
//! todo: add support for mirror
|
||
|
__arm_2d_impl_rgb32_draw_pattern_with_mirror(
|
||
|
ptTask->Param.tCopy.pSource ,
|
||
|
ptTask->Param.tCopy.iSourceStride,
|
||
|
ptTask->Param.tCopy.pTarget,
|
||
|
ptTask->Param.tCopy.iTargetStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode);
|
||
|
#else
|
||
|
return (arm_fsm_rt_t)ARM_2D_ERR_NOT_SUPPORT;
|
||
|
#endif
|
||
|
} else {
|
||
|
__arm_2d_impl_rgb32_draw_pattern(
|
||
|
ptTask->Param.tCopy.tSource.pBuffer,
|
||
|
ptTask->Param.tCopy.tSource.nOffset,
|
||
|
ptTask->Param.tCopy.tSource.iStride,
|
||
|
ptTask->Param.tCopy.tTarget.pBuffer,
|
||
|
ptTask->Param.tCopy.tTarget.iStride,
|
||
|
&ptTask->Param.tCopy.tCopySize,
|
||
|
wMode,
|
||
|
this.Foreground.wColour,
|
||
|
this.Background.wColour);
|
||
|
}
|
||
|
|
||
|
return arm_fsm_rt_cpl;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
/*----------------------------------------------------------------------------*
|
||
|
* Low Level IO Interfaces *
|
||
|
*----------------------------------------------------------------------------*/
|
||
|
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_DRAW_POINT, __arm_2d_sw_draw_point);
|
||
|
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_C8BIT, __arm_2d_c8bit_sw_draw_pattern);
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_RGB16, __arm_2d_rgb16_sw_draw_pattern);
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_RGB32, __arm_2d_rgb32_sw_draw_pattern);
|
||
|
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_FILL_COLOUR_C8BIT, __arm_2d_c8bit_sw_colour_filling);
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_FILL_COLOUR_RGB16, __arm_2d_rgb16_sw_colour_filling);
|
||
|
__WEAK
|
||
|
def_low_lv_io(__ARM_2D_IO_FILL_COLOUR_RGB32, __arm_2d_rgb32_sw_colour_filling);
|
||
|
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_POINT_C8BIT = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_8BIT,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_POINT,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_DRAW_POINT),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_POINT_RGB16 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB16,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_POINT,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_DRAW_POINT),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_POINT_RGB32 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB32,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_POINT,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_DRAW_POINT),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_PATTERN_C8BIT = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_8BIT,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = true,
|
||
|
.bHasTarget = true,
|
||
|
.bAllowEnforcedColour = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_PATTERN,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptCopyLike = ref_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_C8BIT),
|
||
|
.ptFillLike = NULL,
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_PATTERN_RGB16 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB16,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = true,
|
||
|
.bHasTarget = true,
|
||
|
.bAllowEnforcedColour = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_PATTERN,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptCopyLike = ref_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_RGB16),
|
||
|
.ptFillLike = NULL,
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_DRAW_PATTERN_RGB32 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB32,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = true,
|
||
|
.bHasTarget = true,
|
||
|
.bAllowEnforcedColour = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_DRAW_PATTERN,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptCopyLike = ref_low_lv_io(__ARM_2D_IO_DRAW_PATTERN_RGB32),
|
||
|
.ptFillLike = NULL,
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_FILL_COLOUR_C8BIT = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_8BIT,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_FILL_COLOUR,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_FILL_COLOUR_C8BIT),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_FILL_COLOUR_RGB16 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB16,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_FILL_COLOUR,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_FILL_COLOUR_RGB16),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
const __arm_2d_op_info_t ARM_2D_OP_FILL_COLOUR_RGB32 = {
|
||
|
.Info = {
|
||
|
.Colour = {
|
||
|
.chScheme = ARM_2D_COLOUR_RGB32,
|
||
|
},
|
||
|
.Param = {
|
||
|
.bHasSource = false,
|
||
|
.bHasTarget = true,
|
||
|
},
|
||
|
.chOpIndex = __ARM_2D_OP_IDX_FILL_COLOUR,
|
||
|
|
||
|
.LowLevelIO = {
|
||
|
.ptTileProcessLike = ref_low_lv_io(__ARM_2D_IO_FILL_COLOUR_RGB32),
|
||
|
},
|
||
|
},
|
||
|
};
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|