mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-22 17:12:55 +08:00
819 lines
53 KiB
C
819 lines
53 KiB
C
|
/*
|
||
|
* Copyright (C) 2010-2021 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_paving.h
|
||
|
* Description: Provides definitions and code templates for generic paving
|
||
|
*
|
||
|
* $Date: 20. Jan 2021
|
||
|
* $Revision: V 0.5.0
|
||
|
*
|
||
|
* Target Processor: Cortex-M cores
|
||
|
*
|
||
|
* -------------------------------------------------------------------- */
|
||
|
|
||
|
|
||
|
#ifndef __ARM_2D_PAVING_H__
|
||
|
#define __ARM_2D_PAVING_H__
|
||
|
|
||
|
/*============================ INCLUDES ======================================*/
|
||
|
|
||
|
#include "arm_2d.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
#if defined(__clang__)
|
||
|
# pragma clang diagnostic push
|
||
|
# pragma clang diagnostic ignored "-Wunknown-warning-option"
|
||
|
# pragma clang diagnostic ignored "-Wreserved-identifier"
|
||
|
# pragma clang diagnostic ignored "-Wgnu-zero-variadic-macro-arguments"
|
||
|
#elif __IS_COMPILER_GCC__
|
||
|
# pragma GCC diagnostic push
|
||
|
# pragma GCC diagnostic ignored "-Wdiscarded-qualifiers"
|
||
|
#endif
|
||
|
|
||
|
/*============================ MACROS ========================================*/
|
||
|
/*============================ MACROFIED FUNCTIONS ===========================*/
|
||
|
|
||
|
#define SETUP_DIRECT_COPY_8(srcWidth) (void)srcWidth;
|
||
|
#define SETUP_DIRECT_COPY_16(srcWidth) (void)srcWidth;
|
||
|
#define SETUP_DIRECT_COPY_32(srcWidth) (void)srcWidth;
|
||
|
|
||
|
|
||
|
/* scalar copy w/o mirroring */
|
||
|
#define LOAD_SRC_DIRECT_8(pSource, offset) *pSource++;
|
||
|
#define LOAD_SRC_DIRECT_16(pSource, offset) *pSource++;
|
||
|
#define LOAD_SRC_DIRECT_32(pSource, offset) *pSource++;
|
||
|
|
||
|
#define LOAD_SRC_X_MIRROR_8(pSource, offset) pSource[offset]; offset -= 1;
|
||
|
#define LOAD_SRC_X_MIRROR_16(pSource, offset) pSource[offset]; offset -= 1;
|
||
|
#define LOAD_SRC_X_MIRROR_32(pSource, offset) pSource[offset]; offset -= 1;
|
||
|
|
||
|
#define SETUP_MIRROR_COPY_8(srcWidth) uint32_t offset = srcWidth - 1;
|
||
|
#define SETUP_MIRROR_COPY_16(srcWidth) uint32_t offset = srcWidth - 1;
|
||
|
#define SETUP_MIRROR_COPY_32(srcWidth) uint32_t offset = srcWidth - 1;
|
||
|
|
||
|
|
||
|
#define INCR_Y_DIR 1
|
||
|
#define DECR_Y_DIR -1
|
||
|
#define BOTTOM_TO_TOP INCR_Y_DIR
|
||
|
#define TOP_TO_BOTTOM DECR_Y_DIR
|
||
|
|
||
|
#ifndef PAVING_OP
|
||
|
#define PAVING_OP(__DES_ADDR, __SRC) \
|
||
|
do { \
|
||
|
*(__DES_ADDR) = (__SRC); \
|
||
|
}while(0)
|
||
|
#endif
|
||
|
|
||
|
#define PAVING_DIRECT_START_OFFS(strd, heig) 0
|
||
|
#define PAVING_DIRECT_READ_DIR BOTTOM_TO_TOP
|
||
|
#define PAVING_DIRECT_SETUP_COPY(sz) ARM_CONNECT2(SETUP_DIRECT_COPY_,sz)
|
||
|
#define PAVING_DIRECT_LOAD_PATTERN(sz) ARM_CONNECT2(LOAD_SRC_DIRECT_,sz)
|
||
|
|
||
|
#define PAVING_X_MIRROR_START_OFFS(strd, heig) PAVING_DIRECT_START_OFFS(strd, heig)
|
||
|
#define PAVING_X_MIRROR_READ_DIR PAVING_DIRECT_READ_DIR
|
||
|
#define PAVING_X_MIRROR_SETUP_COPY(sz) ARM_CONNECT2(SETUP_MIRROR_COPY_,sz)
|
||
|
#define PAVING_X_MIRROR_LOAD_PATTERN(sz) ARM_CONNECT2(LOAD_SRC_X_MIRROR_,sz)
|
||
|
|
||
|
#define PAVING_Y_MIRROR_START_OFFS(strd, heig) (strd * (heig - 1))
|
||
|
#define PAVING_Y_MIRROR_READ_DIR TOP_TO_BOTTOM
|
||
|
#define PAVING_Y_MIRROR_SETUP_COPY(sz) PAVING_DIRECT_SETUP_COPY(sz)
|
||
|
#define PAVING_Y_MIRROR_LOAD_PATTERN(sz) PAVING_DIRECT_LOAD_PATTERN(sz)
|
||
|
|
||
|
#define PAVING_XY_MIRROR_START_OFFS(strd, heig) PAVING_Y_MIRROR_START_OFFS(strd, heig)
|
||
|
#define PAVING_XY_MIRROR_READ_DIR PAVING_Y_MIRROR_READ_DIR
|
||
|
#define PAVING_XY_MIRROR_SETUP_COPY(sz) PAVING_X_MIRROR_SETUP_COPY(sz)
|
||
|
#define PAVING_XY_MIRROR_LOAD_PATTERN(sz) PAVING_X_MIRROR_LOAD_PATTERN(sz)
|
||
|
|
||
|
|
||
|
|
||
|
#define __ARM_2D_MEM_FILL_GENERIC( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
ptSourceSize, \
|
||
|
pTargetBase, \
|
||
|
iTargetStride, \
|
||
|
ptTargetSize, \
|
||
|
pPavFct, \
|
||
|
...) \
|
||
|
{ \
|
||
|
uint16_t targetIWidth = ptTargetSize->iWidth; \
|
||
|
uint16_t sourceIWidth = ptSourceSize->iWidth; \
|
||
|
uint16_t targetIHeight = ptTargetSize->iHeight; \
|
||
|
uint16_t sourceIHeight = ptSourceSize->iHeight; \
|
||
|
uint32_t tilePairRows = (targetIHeight / (2 * sourceIHeight)); \
|
||
|
uint32_t tilePairCols = (targetIWidth / (2 * sourceIWidth)); \
|
||
|
int32_t residueW = 0; \
|
||
|
int32_t residueH = 0; \
|
||
|
uint32_t targetOffsetRows = 0; \
|
||
|
uint32_t targetOffsetCols = 0; \
|
||
|
\
|
||
|
\
|
||
|
/* can we handle vertical pairs of image ? */ \
|
||
|
if (tilePairRows >= 1) { \
|
||
|
/* target row coordinate after paving */ \
|
||
|
targetOffsetRows = tilePairRows * (2 * sourceIHeight); \
|
||
|
residueW = targetIWidth; \
|
||
|
\
|
||
|
/* can we handle horizontal pairs of image ? */ \
|
||
|
if (tilePairCols >= 1) { \
|
||
|
/* target column coordinate after paving */ \
|
||
|
targetOffsetCols = tilePairCols * (2 * sourceIWidth); \
|
||
|
\
|
||
|
/* run 2 x 2 image paving */ \
|
||
|
/* \
|
||
|
* +=======+=======+=======+=======+=======+=======++..... \
|
||
|
* ||xxxxxx|xxxxxxx|| | || | || \
|
||
|
* +-------+-------+-------+-------+-------+-------+-..... \
|
||
|
* ||xxxxxx|xxxxxxx|| | || | || \
|
||
|
* +=======+=======+=======+=======+=======+=======++..... \
|
||
|
* || | || | || | || \
|
||
|
* +-------+-------+-------+-------+-------+-------+-..... \
|
||
|
* || | || | || | || \
|
||
|
* +=======+=======+=======+=======+=======+=======++..... \
|
||
|
*/ \
|
||
|
pPavFct->pav_2x2(pSourceBase, iSourceStride, ptSourceSize, \
|
||
|
pTargetBase, iTargetStride, \
|
||
|
tilePairRows, tilePairCols \
|
||
|
,##__VA_ARGS__); \
|
||
|
\
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
} \
|
||
|
\
|
||
|
\
|
||
|
if (residueW > ptSourceSize->iWidth) { \
|
||
|
/* run 1 x 2 image paving */ \
|
||
|
/* \
|
||
|
* ...+=======+=..... \
|
||
|
* ...||xxxxxx|| \
|
||
|
* ...+-------+-..... \
|
||
|
* ...||xxxxxx|| \
|
||
|
* ...+=======+=..... \
|
||
|
*/ \
|
||
|
pPavFct->pav_1x2( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
ptSourceSize, \
|
||
|
pTargetBase + targetOffsetCols, \
|
||
|
iTargetStride, \
|
||
|
ptSourceSize->iWidth, \
|
||
|
tilePairRows, ##__VA_ARGS__); \
|
||
|
\
|
||
|
targetOffsetCols += ptSourceSize->iWidth; \
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
} \
|
||
|
if (residueW > 0) { \
|
||
|
/* run residual 1 x 2 image paving */ \
|
||
|
/* \
|
||
|
* ...+===== \
|
||
|
* ...||xxxx \
|
||
|
* ...+----- \
|
||
|
* ...||xxxx \
|
||
|
* ...+===== \
|
||
|
*/ \
|
||
|
pPavFct->pav_1x2( pSourceBase, iSourceStride, ptSourceSize, \
|
||
|
pTargetBase + targetOffsetCols, \
|
||
|
iTargetStride, residueW, tilePairRows \
|
||
|
, ##__VA_ARGS__); \
|
||
|
} \
|
||
|
} \
|
||
|
\
|
||
|
\
|
||
|
/* less than 2 complete vertical images */ \
|
||
|
targetOffsetCols = 0; \
|
||
|
residueH = targetIHeight - targetOffsetRows; \
|
||
|
if (residueH >= ptSourceSize->iHeight) { \
|
||
|
residueW = targetIWidth; \
|
||
|
\
|
||
|
/* can we handle horizontal pair of image ? */ \
|
||
|
if (tilePairCols >= 1) { \
|
||
|
/* run 2 x 1 image paving */ \
|
||
|
/* \
|
||
|
* +=======+=======+=======+=======+=======+=======++..... \
|
||
|
* ||xxxxxx|xxxxxxx|| | || | || \
|
||
|
* +-------+-------+-------+-------+-------+-------+-..... \
|
||
|
* .................................................. \
|
||
|
*/ \
|
||
|
pPavFct->pav_2x1( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
ptSourceSize, \
|
||
|
pTargetBase + \
|
||
|
targetOffsetRows * iTargetStride, \
|
||
|
iTargetStride, \
|
||
|
tilePairCols, \
|
||
|
ptSourceSize->iHeight \
|
||
|
, ##__VA_ARGS__); \
|
||
|
\
|
||
|
targetOffsetCols = tilePairCols * (2 * sourceIWidth); \
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
} \
|
||
|
\
|
||
|
if (residueW > ptSourceSize->iWidth) { \
|
||
|
/* run single image paving */ \
|
||
|
/* \
|
||
|
* +=======+... \
|
||
|
* ||xxxxx||... \
|
||
|
* +-------+... \
|
||
|
* ............ \
|
||
|
*/ \
|
||
|
pPavFct->pav_1x1(pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
pTargetBase + targetOffsetRows * iTargetStride + \
|
||
|
targetOffsetCols, \
|
||
|
iTargetStride, \
|
||
|
ptSourceSize, \
|
||
|
ptSourceSize \
|
||
|
, ##__VA_ARGS__); \
|
||
|
\
|
||
|
targetOffsetCols += ptSourceSize->iWidth; \
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
} \
|
||
|
\
|
||
|
if (residueW > 0) { \
|
||
|
/* run residual single image paving (complete height, */ \
|
||
|
/* but truncated width) */ \
|
||
|
/* */ \
|
||
|
/* +=====... */ \
|
||
|
/* ||xxxx... */ \
|
||
|
/* +-----... */ \
|
||
|
/* ......... */ \
|
||
|
/* */ \
|
||
|
arm_2d_size_t tail; \
|
||
|
tail.iWidth = residueW; \
|
||
|
tail.iHeight = ptSourceSize->iHeight; \
|
||
|
\
|
||
|
pPavFct->pav_1x1( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
pTargetBase + targetOffsetRows * iTargetStride +\
|
||
|
targetOffsetCols, \
|
||
|
iTargetStride, \
|
||
|
ptSourceSize, \
|
||
|
&tail \
|
||
|
, ##__VA_ARGS__); \
|
||
|
\
|
||
|
} \
|
||
|
targetOffsetRows += ptSourceSize->iHeight; \
|
||
|
} \
|
||
|
\
|
||
|
/* less than 1 complete vertical images */ \
|
||
|
targetOffsetCols = 0; \
|
||
|
residueH = ptTargetSize->iHeight - targetOffsetRows; \
|
||
|
if (residueH) { \
|
||
|
arm_2d_size_t tail; \
|
||
|
tail.iWidth = ptSourceSize->iWidth; \
|
||
|
tail.iHeight = residueH; \
|
||
|
\
|
||
|
if (tilePairCols >= 1) { \
|
||
|
/* run vertical truncated 2 x 1 image paving */ \
|
||
|
/* \
|
||
|
* +=======+=======+=======+=======+=======+=======++..... \
|
||
|
* ||xxxxxx|xxxxxxx|| | || | || \
|
||
|
* .................................................. \
|
||
|
*/ \
|
||
|
pPavFct->pav_2x1( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
ptSourceSize, \
|
||
|
pTargetBase + targetOffsetRows * iTargetStride, \
|
||
|
iTargetStride, \
|
||
|
tilePairCols, \
|
||
|
residueH \
|
||
|
, ##__VA_ARGS__); \
|
||
|
\
|
||
|
targetOffsetCols = tilePairCols * (2 * sourceIWidth); \
|
||
|
} \
|
||
|
\
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
if (residueW > ptSourceSize->iWidth) { \
|
||
|
/* run vertical truncated single image copy */ \
|
||
|
/* \
|
||
|
* +=======+... \
|
||
|
* ||xxxxx||... \
|
||
|
* ............ \
|
||
|
*/ \
|
||
|
\
|
||
|
pPavFct->pav_1x1( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
pTargetBase + targetOffsetRows * iTargetStride +\
|
||
|
targetOffsetCols, \
|
||
|
iTargetStride, \
|
||
|
ptSourceSize, \
|
||
|
&tail \
|
||
|
, ##__VA_ARGS__); \
|
||
|
\
|
||
|
targetOffsetCols += ptSourceSize->iWidth; \
|
||
|
residueW = targetIWidth - targetOffsetCols; \
|
||
|
} \
|
||
|
\
|
||
|
if (residueW > 0) { \
|
||
|
/* run horizontal & vertical truncated single image copy */ \
|
||
|
/* \
|
||
|
* +======.. \
|
||
|
* ||xxxxx... \
|
||
|
* .......... \
|
||
|
*/ \
|
||
|
tail.iWidth = residueW; \
|
||
|
\
|
||
|
pPavFct->pav_1x1( pSourceBase, \
|
||
|
iSourceStride, \
|
||
|
pTargetBase + targetOffsetRows * iTargetStride +\
|
||
|
targetOffsetCols, \
|
||
|
iTargetStride, \
|
||
|
ptSourceSize, \
|
||
|
&tail \
|
||
|
, ##__VA_ARGS__); \
|
||
|
} \
|
||
|
} \
|
||
|
\
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
#define __ARM_2D_PAVING_2x2(sz, SRC_OFFSET, DIR, SETUP_MIRROR, LOAD, ...) \
|
||
|
{ \
|
||
|
uint32_t srcWidth = ptSourceSize->iWidth; \
|
||
|
uint32_t srcHeight = ptSourceSize->iHeight; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSourceBaseCur; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pTargetBaseCur = pTargetBase; \
|
||
|
\
|
||
|
\
|
||
|
/* row iteration */ \
|
||
|
/* handle pair of source image row and fill in the column direction */ \
|
||
|
do { \
|
||
|
uint32_t rowCnt = 0; \
|
||
|
\
|
||
|
pSourceBaseCur = (ARM_PIX_SCLTYP(sz) *)pSourceBase; \
|
||
|
\
|
||
|
/* single source row loop */ \
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst = pTargetBaseCur; \
|
||
|
uint32_t tilePairColsCnt = tilePairCols; \
|
||
|
\
|
||
|
/* column loop */ \
|
||
|
/* duplicate current source row into 2 x 2 destination across */ \
|
||
|
/*destination columns */ \
|
||
|
/* \
|
||
|
* +-------+ \
|
||
|
* |xxxxxxx| \
|
||
|
* | src | \
|
||
|
* +-------+ \
|
||
|
* \
|
||
|
* <---------------> \
|
||
|
* \
|
||
|
* || | || | || \
|
||
|
* * +========+=======+========+=======+ \
|
||
|
* | ||xxxxxxx|xxxxxxx||xxxxxxx|xxxxxxx||... \
|
||
|
* | || | || | ||... \
|
||
|
* | +--------+-------+--------+-------+-... \
|
||
|
* | ||xxxxxxx|xxxxxxx||xxxxxxx|xxxxxxx||... \
|
||
|
* | || | || | ||... \
|
||
|
* * +========+=======+========+=======+ \
|
||
|
* || | || | || \
|
||
|
*/ \
|
||
|
do { \
|
||
|
int32_t dstColCnt = srcWidth; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSource = pSourceBaseCur + SRC_OFFSET; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst00 = pDst; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst01 = pDst00 + srcWidth; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst10 = pDst + srcHeight * iTargetStride; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst11 = pDst10 + srcWidth; \
|
||
|
\
|
||
|
SETUP_MIRROR(srcWidth); \
|
||
|
\
|
||
|
/* duplicate current source line into 2x2 destinations tiles*/ \
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) in; \
|
||
|
\
|
||
|
in = LOAD(pSource, offset); \
|
||
|
if (true,##__VA_ARGS__) { \
|
||
|
PAVING_OP(pDst00++, in); \
|
||
|
PAVING_OP(pDst01++, in); \
|
||
|
PAVING_OP(pDst10++, in); \
|
||
|
PAVING_OP(pDst11++, in); \
|
||
|
} else { \
|
||
|
pDst00++;pDst01++;pDst10++;pDst11++; \
|
||
|
} \
|
||
|
\
|
||
|
} while (--dstColCnt); \
|
||
|
\
|
||
|
pDst += 2 * srcWidth; \
|
||
|
tilePairColsCnt--; \
|
||
|
} \
|
||
|
while (tilePairColsCnt != 0); \
|
||
|
\
|
||
|
rowCnt ++; \
|
||
|
pTargetBaseCur += iTargetStride; \
|
||
|
pSourceBaseCur += (iSourceStride * DIR); \
|
||
|
} \
|
||
|
while (rowCnt < ptSourceSize->iHeight); \
|
||
|
\
|
||
|
pTargetBaseCur += srcHeight * iTargetStride; \
|
||
|
tilePairRows--; \
|
||
|
} \
|
||
|
while (tilePairRows != 0); \
|
||
|
}
|
||
|
|
||
|
#define __ARM_2D_PAVING_1x2(sz, SRC_OFFSET, DIR, SETUP_MIRROR, LOAD, ...) \
|
||
|
{ \
|
||
|
uint32_t srcWidth = ptSourceSize->iWidth; \
|
||
|
uint32_t srcHeight = ptSourceSize->iHeight; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSourceBaseCur; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pTargetBaseCur = pTargetBase; \
|
||
|
\
|
||
|
\
|
||
|
/* row iteration */ \
|
||
|
/* handle pair of source image row and fill in the column direction */ \
|
||
|
do { \
|
||
|
uint32_t rowCnt = 0; \
|
||
|
\
|
||
|
pSourceBaseCur = (ARM_PIX_SCLTYP(sz) *)pSourceBase; \
|
||
|
\
|
||
|
/* single source row loop */ \
|
||
|
do { \
|
||
|
int32_t dstColCnt = destWidth; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSource = pSourceBaseCur + SRC_OFFSET; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst = pTargetBaseCur; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst00 = pDst; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst10 = pDst + srcHeight * iTargetStride; \
|
||
|
\
|
||
|
/* column loop */ \
|
||
|
/* duplicate current source row into 1 x 2 destination across */ \
|
||
|
/* destination columns */ \
|
||
|
/* \
|
||
|
* +-------+ \
|
||
|
* |xxxxxxx| \
|
||
|
* | src | \
|
||
|
* +-------+ \
|
||
|
* \
|
||
|
* ..|| || \
|
||
|
* * ==+========+=... \
|
||
|
* | ..||xxxxxxx||... \
|
||
|
* | ..|| ||... \
|
||
|
* | ..+--------+-... \
|
||
|
* | ..||xxxxxxx||... \
|
||
|
* | ..|| ||... \
|
||
|
* * ==+========+=... \
|
||
|
* ..|| ||... \
|
||
|
*/ \
|
||
|
SETUP_MIRROR(srcWidth); \
|
||
|
\
|
||
|
/* duplicate current source line into 2x2 destinations */ \
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) in; \
|
||
|
\
|
||
|
in = LOAD(pSource, offset); \
|
||
|
if (true,##__VA_ARGS__) { \
|
||
|
PAVING_OP(pDst00++, in); \
|
||
|
PAVING_OP(pDst10++, in); \
|
||
|
} else { \
|
||
|
pDst00 ++; \
|
||
|
pDst10 ++; \
|
||
|
} \
|
||
|
} \
|
||
|
while (--dstColCnt); \
|
||
|
\
|
||
|
rowCnt ++; \
|
||
|
pTargetBaseCur += iTargetStride; \
|
||
|
pSourceBaseCur += (iSourceStride * DIR); \
|
||
|
} \
|
||
|
while (rowCnt < ptSourceSize->iHeight); \
|
||
|
\
|
||
|
pTargetBaseCur += srcHeight * iTargetStride; \
|
||
|
tilePairRows--; \
|
||
|
} \
|
||
|
while (tilePairRows != 0); \
|
||
|
}
|
||
|
|
||
|
|
||
|
#define __ARM_2D_PAVING_2x1(sz, SRC_OFFSET, DIR, SETUP_MIRROR, LOAD, ...) \
|
||
|
{ \
|
||
|
uint32_t srcWidth = ptSourceSize->iWidth; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSourceBaseCur; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pTargetBaseCur = pTargetBase; \
|
||
|
uint32_t rowCnt = 0; \
|
||
|
\
|
||
|
\
|
||
|
/* row iteration */ \
|
||
|
/* handle pair of source image row and fill in the column direction */ \
|
||
|
/* \
|
||
|
* +-------+ \
|
||
|
* | src | \
|
||
|
* +-------+ \
|
||
|
* \
|
||
|
* tilePairCols \
|
||
|
* <---------------+--------........> \
|
||
|
* \
|
||
|
* +=======+=======++=======+=======++...... \
|
||
|
* || | || | || \
|
||
|
* +=======+=======++=======+=======++ \
|
||
|
* ........ \
|
||
|
*/ \
|
||
|
\
|
||
|
pSourceBaseCur = (ARM_PIX_SCLTYP(sz) *)pSourceBase; \
|
||
|
\
|
||
|
/* copy 2 x 2 source image block */ \
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst = pTargetBaseCur; \
|
||
|
ARM_PIX_SCLTYP(sz) tilePairColsCnt = tilePairCols; \
|
||
|
\
|
||
|
do { \
|
||
|
int srcColCnt = srcWidth; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSource = pSourceBaseCur+SRC_OFFSET; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst00 = pDst; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst01 = pDst00 + srcColCnt; \
|
||
|
\
|
||
|
SETUP_MIRROR(srcWidth); \
|
||
|
\
|
||
|
/* duplicate current source line into 4 destinations */ \
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) in; \
|
||
|
\
|
||
|
in = LOAD(pSource, offset); \
|
||
|
if (true,##__VA_ARGS__) { \
|
||
|
PAVING_OP(pDst00++, in); \
|
||
|
PAVING_OP(pDst01++, in); \
|
||
|
} else { \
|
||
|
pDst00 ++; \
|
||
|
pDst01 ++; \
|
||
|
} \
|
||
|
\
|
||
|
srcColCnt -= 1; \
|
||
|
} \
|
||
|
while ((int32_t) srcColCnt > 0); \
|
||
|
\
|
||
|
pDst += 2 * srcWidth; \
|
||
|
tilePairColsCnt--; \
|
||
|
} \
|
||
|
while (tilePairColsCnt != 0); \
|
||
|
\
|
||
|
rowCnt++; \
|
||
|
pTargetBaseCur += iTargetStride; \
|
||
|
pSourceBaseCur += (iSourceStride * DIR); \
|
||
|
} \
|
||
|
while (rowCnt < destHeight); \
|
||
|
}
|
||
|
|
||
|
|
||
|
#define __ARM_2D_PAVING_1x1(sz, SRC_OFFSET, DIR, SETUP_MIRROR, LOAD, ...) \
|
||
|
{ \
|
||
|
pSource += SRC_OFFSET; \
|
||
|
\
|
||
|
for (int_fast16_t y = 0; y < ptDstCopySize->iHeight; y++) { \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pDst = pTarget; \
|
||
|
ARM_PIX_SCLTYP(sz) *__RESTRICT pSrc = (ARM_PIX_SCLTYP(sz) *)pSource; \
|
||
|
uint32_t srcWidth = ptSrcCopySize->iWidth; \
|
||
|
uint32_t dstWidth = ptDstCopySize->iWidth; \
|
||
|
\
|
||
|
SETUP_MIRROR(srcWidth); \
|
||
|
\
|
||
|
do { \
|
||
|
ARM_PIX_SCLTYP(sz) in; \
|
||
|
\
|
||
|
in = LOAD(pSrc, offset); \
|
||
|
if (true,##__VA_ARGS__) { \
|
||
|
PAVING_OP(pDst++,in); \
|
||
|
} else { \
|
||
|
pDst++; \
|
||
|
} \
|
||
|
\
|
||
|
dstWidth -= 1; \
|
||
|
} \
|
||
|
while ((int32_t) dstWidth > 0); \
|
||
|
\
|
||
|
pSource += (iSourceStride * DIR); \
|
||
|
pTarget += iTargetStride; \
|
||
|
} \
|
||
|
}
|
||
|
|
||
|
|
||
|
/*============================ TYPES =========================================*/
|
||
|
|
||
|
typedef void (arm_2d_c8bit_paving_2x2) (const uint8_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint8_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_paving_1x2) (const uint8_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint8_t *, int16_t, uint32_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_paving_2x1) (const uint8_t *, int16_t,
|
||
|
const arm_2d_size_t *, uint8_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_paving_1x1) (const uint8_t *, int16_t, uint8_t *, int16_t,
|
||
|
const arm_2d_size_t *, const arm_2d_size_t *);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_c8bit_paving_fct_t {
|
||
|
arm_2d_c8bit_paving_2x2 *pav_2x2;
|
||
|
arm_2d_c8bit_paving_1x2 *pav_1x2;
|
||
|
arm_2d_c8bit_paving_2x1 *pav_2x1;
|
||
|
arm_2d_c8bit_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_c8bit_paving_fct_t;
|
||
|
|
||
|
|
||
|
typedef void (arm_2d_rgb16_paving_2x2) (const uint16_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint16_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_paving_1x2) (const uint16_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint16_t *, int16_t, uint32_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_paving_2x1) (const uint16_t *, int16_t,
|
||
|
const arm_2d_size_t *, uint16_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_paving_1x1) (const uint16_t *, int16_t, uint16_t *, int16_t,
|
||
|
const arm_2d_size_t *, const arm_2d_size_t *);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_rgb16_paving_fct_t {
|
||
|
arm_2d_rgb16_paving_2x2 *pav_2x2;
|
||
|
arm_2d_rgb16_paving_1x2 *pav_1x2;
|
||
|
arm_2d_rgb16_paving_2x1 *pav_2x1;
|
||
|
arm_2d_rgb16_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_rgb16_paving_fct_t;
|
||
|
|
||
|
typedef void (arm_2d_rgb32_paving_2x2) (const uint32_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint32_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_paving_1x2) (const uint32_t *, int16_t, const arm_2d_size_t *,
|
||
|
uint32_t *, int16_t, uint32_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_paving_2x1) (const uint32_t *, int16_t,
|
||
|
const arm_2d_size_t *, uint32_t *, int16_t, uint16_t, uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_paving_1x1) (const uint32_t *, int16_t, uint32_t *, int16_t,
|
||
|
const arm_2d_size_t *, const arm_2d_size_t *);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_rgb32_paving_fct_t {
|
||
|
arm_2d_rgb32_paving_2x2 *pav_2x2;
|
||
|
arm_2d_rgb32_paving_1x2 *pav_1x2;
|
||
|
arm_2d_rgb32_paving_2x1 *pav_2x1;
|
||
|
arm_2d_rgb32_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_rgb32_paving_fct_t;
|
||
|
|
||
|
|
||
|
|
||
|
typedef void (arm_2d_c8bit_cl_key_paving_2x2)( const uint8_t * __RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t * __RESTRICT,
|
||
|
uint8_t * __RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint8_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_cl_key_paving_1x2) ( const uint8_t *__RESTRICT ,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint8_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint32_t,
|
||
|
uint16_t,
|
||
|
uint8_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_cl_key_paving_2x1) ( const uint8_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint8_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint8_t);
|
||
|
|
||
|
typedef void (arm_2d_c8bit_cl_key_paving_1x1) ( const uint8_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint8_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint8_t);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_c8bit_cl_key_paving_fct_t {
|
||
|
arm_2d_c8bit_cl_key_paving_2x2 *pav_2x2;
|
||
|
arm_2d_c8bit_cl_key_paving_1x2 *pav_1x2;
|
||
|
arm_2d_c8bit_cl_key_paving_2x1 *pav_2x1;
|
||
|
arm_2d_c8bit_cl_key_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_c8bit_cl_key_paving_fct_t;
|
||
|
|
||
|
|
||
|
typedef void (arm_2d_rgb16_cl_key_paving_2x2)( const uint16_t * __RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t * __RESTRICT,
|
||
|
uint16_t * __RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_cl_key_paving_1x2) ( const uint16_t *__RESTRICT ,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint16_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint32_t,
|
||
|
uint16_t,
|
||
|
uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_cl_key_paving_2x1) ( const uint16_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint16_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint16_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb16_cl_key_paving_1x1) ( const uint16_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint16_t);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_rgb16_cl_key_paving_fct_t {
|
||
|
arm_2d_rgb16_cl_key_paving_2x2 *pav_2x2;
|
||
|
arm_2d_rgb16_cl_key_paving_1x2 *pav_1x2;
|
||
|
arm_2d_rgb16_cl_key_paving_2x1 *pav_2x1;
|
||
|
arm_2d_rgb16_cl_key_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_rgb16_cl_key_paving_fct_t;
|
||
|
|
||
|
|
||
|
|
||
|
typedef void (arm_2d_rgb32_cl_key_paving_2x2)( const uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint32_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_cl_key_paving_1x2) ( const uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint32_t,
|
||
|
uint16_t,
|
||
|
uint32_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_cl_key_paving_2x1) ( const uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint16_t,
|
||
|
uint16_t,
|
||
|
uint32_t);
|
||
|
|
||
|
typedef void (arm_2d_rgb32_cl_key_paving_1x1) ( const uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
uint32_t *__RESTRICT,
|
||
|
int16_t,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
const arm_2d_size_t *__RESTRICT,
|
||
|
uint32_t);
|
||
|
|
||
|
|
||
|
typedef struct arm_2d_rgb32_cl_key_paving_fct_t {
|
||
|
arm_2d_rgb32_cl_key_paving_2x2 *pav_2x2;
|
||
|
arm_2d_rgb32_cl_key_paving_1x2 *pav_1x2;
|
||
|
arm_2d_rgb32_cl_key_paving_2x1 *pav_2x1;
|
||
|
arm_2d_rgb32_cl_key_paving_1x1 *pav_1x1;
|
||
|
} arm_2d_rgb32_cl_key_paving_fct_t;
|
||
|
|
||
|
|
||
|
/*============================ GLOBAL VARIABLES ==============================*/
|
||
|
/*============================ PROTOTYPES ====================================*/
|
||
|
|
||
|
#if defined(__clang__)
|
||
|
# pragma clang diagnostic pop
|
||
|
#elif __IS_COMPILER_GCC__
|
||
|
# pragma GCC diagnostic pop
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif
|