13d0407baSopenharmony_ci/* 23d0407baSopenharmony_ci * Copyright 2015 Rockchip Electronics Co. LTD 33d0407baSopenharmony_ci * 43d0407baSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 53d0407baSopenharmony_ci * you may not use this file except in compliance with the License. 63d0407baSopenharmony_ci * You may obtain a copy of the License at 73d0407baSopenharmony_ci * 83d0407baSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 93d0407baSopenharmony_ci * 103d0407baSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 113d0407baSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 123d0407baSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 133d0407baSopenharmony_ci * See the License for the specific language governing permissions and 143d0407baSopenharmony_ci * limitations under the License. 153d0407baSopenharmony_ci */ 163d0407baSopenharmony_ci 173d0407baSopenharmony_ci#ifndef __MPP_COMMON_H__ 183d0407baSopenharmony_ci#define __MPP_COMMON_H__ 193d0407baSopenharmony_ci 203d0407baSopenharmony_ci#include "rk_type.h" 213d0407baSopenharmony_ci 223d0407baSopenharmony_ci#define MPP_TAG_SIZE 32 233d0407baSopenharmony_ci 243d0407baSopenharmony_ci#define MPP_ABS(x) ((x) < (0) ? -(x) : (x)) 253d0407baSopenharmony_ci 263d0407baSopenharmony_ci#define MPP_MAX(a, b) ((a) > (b) ? (a) : (b)) 273d0407baSopenharmony_ci#define MPP_MAX3(a, b, c) MPP_MAX(MPP_MAX(a,b),c) 283d0407baSopenharmony_ci#define MPP_MAX4(a, b, c, d) MPP_MAX((a), MPP_MAX3((b), (c), (d))) 293d0407baSopenharmony_ci 303d0407baSopenharmony_ci#define MPP_MIN(a,b) ((a) > (b) ? (b) : (a)) 313d0407baSopenharmony_ci#define MPP_MIN3(a,b,c) MPP_MIN(MPP_MIN(a,b),c) 323d0407baSopenharmony_ci#define MPP_MIN4(a, b, c, d) MPP_MIN((a), MPP_MIN3((b), (c), (d))) 333d0407baSopenharmony_ci 343d0407baSopenharmony_ci#define MPP_DIV(a, b) ((b) ? (a) / (b) : (a)) 353d0407baSopenharmony_ci 363d0407baSopenharmony_ci#define MPP_CLIP3(l, h, v) ((v) < (l) ? (l) : ((v) > (h) ? (h) : (v))) 373d0407baSopenharmony_ci#define MPP_SIGN(a) ((a) < (0) ? (-1) : (1)) 383d0407baSopenharmony_ci#define MPP_DIV_SIGN(a, b) (((a) + (MPP_SIGN(a) * (b)) / 2) / (b)) 393d0407baSopenharmony_ci 403d0407baSopenharmony_ci#define MPP_SWAP(type, a, b) do {type SWAP_tmp = b; b = a; a = SWAP_tmp;} while(0) 413d0407baSopenharmony_ci#define MPP_ARRAY_ELEMS(a) (sizeof(a) / sizeof((a)[0])) 423d0407baSopenharmony_ci#define MPP_ALIGN(x, a) (((x)+(a)-1)&~((a)-1)) 433d0407baSopenharmony_ci#define MPP_VSWAP(a, b) { a ^= b; b ^= a; a ^= b; } 443d0407baSopenharmony_ci 453d0407baSopenharmony_ci#define MPP_RB16(x) ((((const RK_U8*)(x))[0] << 8) | ((const RK_U8*)(x))[1]) 463d0407baSopenharmony_ci#define MPP_WB16(p, d) do { \ 473d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d); \ 483d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d)>>8; } while(0) 493d0407baSopenharmony_ci 503d0407baSopenharmony_ci#define MPP_RL16(x) ((((const RK_U8*)(x))[1] << 8) | \ 513d0407baSopenharmony_ci ((const RK_U8*)(x))[0]) 523d0407baSopenharmony_ci#define MPP_WL16(p, d) do { \ 533d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d); \ 543d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>8; } while(0) 553d0407baSopenharmony_ci 563d0407baSopenharmony_ci#define MPP_RB32(x) ((((const RK_U8*)(x))[0] << 24) | \ 573d0407baSopenharmony_ci (((const RK_U8*)(x))[1] << 16) | \ 583d0407baSopenharmony_ci (((const RK_U8*)(x))[2] << 8) | \ 593d0407baSopenharmony_ci ((const RK_U8*)(x))[3]) 603d0407baSopenharmony_ci#define MPP_WB32(p, d) do { \ 613d0407baSopenharmony_ci ((RK_U8*)(p))[3] = (d); \ 623d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d)>>8; \ 633d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>16; \ 643d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d)>>24; } while(0) 653d0407baSopenharmony_ci 663d0407baSopenharmony_ci#define MPP_RL32(x) ((((const RK_U8*)(x))[3] << 24) | \ 673d0407baSopenharmony_ci (((const RK_U8*)(x))[2] << 16) | \ 683d0407baSopenharmony_ci (((const RK_U8*)(x))[1] << 8) | \ 693d0407baSopenharmony_ci ((const RK_U8*)(x))[0]) 703d0407baSopenharmony_ci#define MPP_WL32(p, d) do { \ 713d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d); \ 723d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>8; \ 733d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d)>>16; \ 743d0407baSopenharmony_ci ((RK_U8*)(p))[3] = (d)>>24; } while(0) 753d0407baSopenharmony_ci 763d0407baSopenharmony_ci#define MPP_RB64(x) (((RK_U64)((const RK_U8*)(x))[0] << 56) | \ 773d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[1] << 48) | \ 783d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[2] << 40) | \ 793d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[3] << 32) | \ 803d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[4] << 24) | \ 813d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[5] << 16) | \ 823d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[6] << 8) | \ 833d0407baSopenharmony_ci (RK_U64)((const RK_U8*)(x))[7]) 843d0407baSopenharmony_ci#define MPP_WB64(p, d) do { \ 853d0407baSopenharmony_ci ((RK_U8*)(p))[7] = (d); \ 863d0407baSopenharmony_ci ((RK_U8*)(p))[6] = (d)>>8; \ 873d0407baSopenharmony_ci ((RK_U8*)(p))[5] = (d)>>16; \ 883d0407baSopenharmony_ci ((RK_U8*)(p))[4] = (d)>>24; \ 893d0407baSopenharmony_ci ((RK_U8*)(p))[3] = (d)>>32; \ 903d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d)>>40; \ 913d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>48; \ 923d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d)>>56; } while(0) 933d0407baSopenharmony_ci 943d0407baSopenharmony_ci#define MPP_RL64(x) (((RK_U64)((const RK_U8*)(x))[7] << 56) | \ 953d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[6] << 48) | \ 963d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[5] << 40) | \ 973d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[4] << 32) | \ 983d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[3] << 24) | \ 993d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[2] << 16) | \ 1003d0407baSopenharmony_ci ((RK_U64)((const RK_U8*)(x))[1] << 8) | \ 1013d0407baSopenharmony_ci (RK_U64)((const RK_U8*)(x))[0]) 1023d0407baSopenharmony_ci#define MPP_WL64(p, d) do { \ 1033d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d); \ 1043d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>8; \ 1053d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d)>>16; \ 1063d0407baSopenharmony_ci ((RK_U8*)(p))[3] = (d)>>24; \ 1073d0407baSopenharmony_ci ((RK_U8*)(p))[4] = (d)>>32; \ 1083d0407baSopenharmony_ci ((RK_U8*)(p))[5] = (d)>>40; \ 1093d0407baSopenharmony_ci ((RK_U8*)(p))[6] = (d)>>48; \ 1103d0407baSopenharmony_ci ((RK_U8*)(p))[7] = (d)>>56; } while(0) 1113d0407baSopenharmony_ci 1123d0407baSopenharmony_ci#define MPP_RB24(x) ((((const RK_U8*)(x))[0] << 16) | \ 1133d0407baSopenharmony_ci (((const RK_U8*)(x))[1] << 8) | \ 1143d0407baSopenharmony_ci ((const RK_U8*)(x))[2]) 1153d0407baSopenharmony_ci#define MPP_WB24(p, d) do { \ 1163d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d); \ 1173d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>8; \ 1183d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d)>>16; } while(0) 1193d0407baSopenharmony_ci 1203d0407baSopenharmony_ci#define MPP_RL24(x) ((((const RK_U8*)(x))[2] << 16) | \ 1213d0407baSopenharmony_ci (((const RK_U8*)(x))[1] << 8) | \ 1223d0407baSopenharmony_ci ((const RK_U8*)(x))[0]) 1233d0407baSopenharmony_ci 1243d0407baSopenharmony_ci#define MPP_WL24(p, d) do { \ 1253d0407baSopenharmony_ci ((RK_U8*)(p))[0] = (d); \ 1263d0407baSopenharmony_ci ((RK_U8*)(p))[1] = (d)>>8; \ 1273d0407baSopenharmony_ci ((RK_U8*)(p))[2] = (d)>>16; } while(0) 1283d0407baSopenharmony_ci 1293d0407baSopenharmony_ci#include <stdio.h> 1303d0407baSopenharmony_ci 1313d0407baSopenharmony_ci#define container_of(ptr, type, member) \ 1323d0407baSopenharmony_ci ((type *)((char *)(ptr) - offsetof(type, member))) 1333d0407baSopenharmony_ci 1343d0407baSopenharmony_ci#define __RETURN __Return 1353d0407baSopenharmony_ci#define __FAILED __failed 1363d0407baSopenharmony_ci 1373d0407baSopenharmony_ci#define ARG_T(t) t 1383d0407baSopenharmony_ci#define ARG_N(a,b,c,d,N,...) N 1393d0407baSopenharmony_ci#define ARG_N_HELPER(...) ARG_T(ARG_N(__VA_ARGS__)) 1403d0407baSopenharmony_ci#define COUNT_ARG(...) ARG_N_HELPER(__VA_ARGS__,4,3,2,1,0) 1413d0407baSopenharmony_ci 1423d0407baSopenharmony_ci#define SZ_1K (1024) 1433d0407baSopenharmony_ci#define SZ_2K (SZ_1K*2) 1443d0407baSopenharmony_ci#define SZ_4K (SZ_1K*4) 1453d0407baSopenharmony_ci#define SZ_8K (SZ_1K*8) 1463d0407baSopenharmony_ci#define SZ_16K (SZ_1K*16) 1473d0407baSopenharmony_ci#define SZ_32K (SZ_1K*32) 1483d0407baSopenharmony_ci#define SZ_64K (SZ_1K*64) 1493d0407baSopenharmony_ci#define SZ_128K (SZ_1K*128) 1503d0407baSopenharmony_ci#define SZ_256K (SZ_1K*256) 1513d0407baSopenharmony_ci#define SZ_512K (SZ_1K*512) 1523d0407baSopenharmony_ci#define SZ_1M (SZ_1K*SZ_1K) 1533d0407baSopenharmony_ci#define SZ_2M (SZ_1M*2) 1543d0407baSopenharmony_ci#define SZ_4M (SZ_1M*4) 1553d0407baSopenharmony_ci#define SZ_8M (SZ_1M*8) 1563d0407baSopenharmony_ci#define SZ_16M (SZ_1M*16) 1573d0407baSopenharmony_ci#define SZ_32M (SZ_1M*32) 1583d0407baSopenharmony_ci#define SZ_64M (SZ_1M*64) 1593d0407baSopenharmony_ci#define SZ_80M (SZ_1M*80) 1603d0407baSopenharmony_ci#define SZ_128M (SZ_1M*128) 1613d0407baSopenharmony_ci 1623d0407baSopenharmony_ci#ifdef __cplusplus 1633d0407baSopenharmony_ciextern "C" { 1643d0407baSopenharmony_ci#endif 1653d0407baSopenharmony_ci 1663d0407baSopenharmony_ciRK_S32 mpp_log2(RK_U32 v); 1673d0407baSopenharmony_ciRK_S32 mpp_log2_16bit(RK_U32 v); 1683d0407baSopenharmony_ci 1693d0407baSopenharmony_cistatic __inline RK_S32 mpp_ceil_log2(RK_S32 x) 1703d0407baSopenharmony_ci{ 1713d0407baSopenharmony_ci return mpp_log2((x - 1) << 1); 1723d0407baSopenharmony_ci} 1733d0407baSopenharmony_ci 1743d0407baSopenharmony_cistatic __inline RK_S32 mpp_clip(RK_S32 a, RK_S32 amin, RK_S32 amax) 1753d0407baSopenharmony_ci{ 1763d0407baSopenharmony_ci if (a < amin) return amin; 1773d0407baSopenharmony_ci else if (a > amax) return amax; 1783d0407baSopenharmony_ci else return a; 1793d0407baSopenharmony_ci} 1803d0407baSopenharmony_ci 1813d0407baSopenharmony_cistatic __inline RK_U32 mpp_is_32bit() 1823d0407baSopenharmony_ci{ 1833d0407baSopenharmony_ci return ((sizeof(void *) == 4) ? (1) : (0)); 1843d0407baSopenharmony_ci} 1853d0407baSopenharmony_ci 1863d0407baSopenharmony_ciRK_S32 axb_div_c(RK_S32 a, RK_S32 b, RK_S32 c); 1873d0407baSopenharmony_ciRK_U32 mpp_align_16(RK_U32 val); 1883d0407baSopenharmony_ciRK_U32 mpp_align_64(RK_U32 val); 1893d0407baSopenharmony_ci 1903d0407baSopenharmony_ci#ifdef __cplusplus 1913d0407baSopenharmony_ci} 1923d0407baSopenharmony_ci#endif 1933d0407baSopenharmony_ci 1943d0407baSopenharmony_ci#endif /*__MPP_COMMON_H__*/ 1953d0407baSopenharmony_ci 196