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