From 3867e245cc0a6f94c9f436f01bf363dbc7b1f730 Mon Sep 17 00:00:00 2001 From: "Igor Zalatov (from Dolphin PC)" Date: Thu, 10 Aug 2023 15:25:28 +0300 Subject: [PATCH] Fix SC3336 driver --- .../smart_sc3336/sc3336_mipi_cmos.c | 18 +- .../smart_sc3336/sc3336_mipi_cmos_ex.h | 1986 ++++++++--------- .../smart_sc3336/sc3336_mipi_sensor_ctl.c | 4 +- 3 files changed, 1005 insertions(+), 1003 deletions(-) diff --git a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos.c b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos.c index cee8f51..0f984ae 100644 --- a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos.c +++ b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos.c @@ -22,15 +22,17 @@ #include #include #include -#include "hi_comm_sns.h" -#include "hi_comm_video.h" -#include "hi_sns_ctrl.h" -#include "mpi_isp.h" -#include "mpi_ae.h" -#include "mpi_awb.h" -#include "hi_comm_isp.h" - +#include "comm_sns.h" +#include "comm_video.h" +#include "sns_ctrl.h" +#include "gk_api_isp.h" +#include "gk_api_ae.h" +#include "gk_api_awb.h" +#include "comm_isp.h" #include "sc3336_mipi_cmos_ex.h" +#include "hicompat.h" + + #ifdef __cplusplus #if __cplusplus extern "C" { diff --git a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos_ex.h b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos_ex.h index bffb52a..d9d7622 100644 --- a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos_ex.h +++ b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_cmos_ex.h @@ -1,993 +1,993 @@ -/****************************************************************************** - - Copyright (C), 2016, Hisilicon Tech. Co., Ltd. - - ****************************************************************************** - File Name : sc3336_cmos_ex.h - Version : Initial Draft - Author : Hisilicon multimedia software group - Created : 2018/07/23 - Description : this file was private for sc3336 master mode sensor - History : - 1.Date : - Author : - Modification: Created file -******************************************************************************/ -#ifndef __SC3336_MIPI_CMOS_EX_H_ -#define __SC3336_MIPI_CMOS_EX_H_ - -#ifdef __cplusplus -#if __cplusplus -extern "C" { -#endif -#endif - -static const ISP_CMOS_LCAC_S g_stIspLCac = { - - /*bEnable*/ - 1, - /*u16PurpleDetRange*/ - 30, - /*VarThr*/ - 0, - /*enOpMode*/ - 0, - /*stManual*/ - { - //u8DePurpleCrStr - 0, - //u8DePurpleCbStr - 3 - }, - /*stAuto*/ - { - //u8DePurpleCrStr - {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, - //u8DePurpleCbStr - {3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3} - } -}; - - -static const ISP_CMOS_LCAC_S g_stIspLCacWdr = { - - /*bEnable*/ - 1, - /*u16PurpleDetRange*/ - 30, - /*VarThr*/ - 130, - /*enOpMode*/ - 0, - /*stManual*/ - { - //u8DePurpleCrStr - 0, - //u8DePurpleCbStr - 3 - }, - /*stAuto*/ - { - //u8DePurpleCrStr - {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, - //u8DePurpleCbStr - {3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3} - } -}; - - -static const ISP_CMOS_DPC_S g_stCmosDpc = { - /* ISO */ - /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200, 1638400, 3276800 */ - { 130, 150, 150, 200, 230, 240, 240, 240, 240, 240, 152, 152, 152, 152, 152, 152}, /* au16Strength[16] */ - { 24, 24, 32, 32, 32, 32, 36, 36, 36, 40, 50, 50, 50, 50, 50, 50}, /* au16BlendRatio[16] */ - 0, /* 0 for after drc, 1 for before wdr */ -}; - -static const ISP_CMOS_GE_S g_stIspGe = { - /* For GE */ - 1, /* bEnable */ - 13, /* u8Slope */ - 13, /* u8SensiSlope */ - 4800, /* u16SensiThr */ - /* ISO */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 4800, 4800, 4800, 4800, 4960, 4960, 4960, 4960, 5120, 5120, 5120, 5120, 5280, 5280, 5280, 5280}, /* au16Threshold[ISP_AUTO_ISO_STRENGTH_NUM] */ - { 128, 128, 128, 128, 129, 129, 129, 129, 130, 130, 130, 130, 131, 131, 131, 131}, /* au16Strength[ISP_AUTO_ISO_STRENGTH_NUM] */ - {16384, 16384, 16384, 16384, 16384, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768} /* au16NpOffset[ISP_AUTO_ISO_STRENGTH_NUM] */ -}; - -static const ISP_CMOS_GE_S g_stIspWdrGe = { - /* For GE */ - 1, /* bEnable */ - 13, /* u8Slope */ - 13, /* u8SensiSlope */ - 4800, /* u16SensiThr */ - - /* ISO */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192,16384, 32768 */ - { 4800, 4800, 4800, 4800, 4960, 4960, 4960, 4960, 5120, 5120, 5120, 5120, 5280, 5280, 5280, 5280}, /* au16Threshold[ISP_AUTO_ISO_STRENGTH_NUM] */ - { 128, 128, 128, 128, 129, 129, 129, 129, 130, 130, 130, 130, 131, 131, 131, 131}, /* au16Strength[ISP_AUTO_ISO_STRENGTH_NUM] */ - {16384, 16384, 16384, 16384, 16384, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768} /* au16NpOffset[ISP_AUTO_ISO_STRENGTH_NUM] */ -}; - -static const ISP_CMOS_DEMOSAIC_S g_stIspDemosaic = { - 1, // bEnable - /* au8NonDirStr */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64}, - /* au8NonDirLFDetailEhc */ - { 32, 32, 32, 36, 36, 36, 32, 22, 20, 18, 18, 18, 18, 18, 18, 18}, - /* au8NonDirHFDetailEhc */ - { 3, 3, 4, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7}, - /* au8DetailSmoothRange */ - { 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 7, 7, 7, 7, 7, 7}, -}; - -static const ISP_CMOS_DEMOSAIC_S g_stIspDemosaicWdr = { - 1, // bEnable - /* au8NonDirStr */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 64, 64, 64, 48, 48, 48, 32, 32, 32, 32, 16, 16, 16, 16, 16, 16}, - /* au8NonDirLFDetailEhc */ - { 40, 40, 40, 40, 32, 24, 18, 16, 16, 16, 16, 16, 16, 16, 16, 16}, - /* au8NonDirHFDetailEhc */ - { 3, 3, 3, 3, 3, 3, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5}, - /* au8DetailSmoothRange */ - { 4, 4, 4, 4, 4, 4, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7}, -}; - -static const ISP_CMOS_ANTIFALSECOLOR_S g_stIspAntiFalseColor = { - 1, /* bEnable */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 10, 10, 10, 12, 15, 16, 16, 15, 8, 6, 5, 4, 3, 2, 1, 0}, /* au8AntiFalseColorThreshold */ - { 8, 8, 10, 12, 15, 16, 16, 15, 8, 6, 5, 4, 3, 2, 1, 0}, /* au8AntiFalseColorStrength */ -}; - -static const ISP_CMOS_ANTIFALSECOLOR_S g_stIspWdrAntiFalseColor = { - 1, /* bEnable */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 2, 1, 0}, /* au8AntiFalseColorThreshold */ - { 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 2, 1, 0}, /* au8AntiFalseColorStrength */ -}; - -/***BAYER NR**/ -static ISP_CMOS_NOISE_CALIBRATION_S g_stIspNoiseCalibratio = { - 10, // Calibration Lut Num - /*************Calibration LUT Table*************/ - { - {100.000000f, 0.025472f, 0.008370f}, - {200.000000f, 0.051026f, 0.020051f}, - {400.000000f, 0.100380f, 0.002657f}, - {800.000000f, 0.199705f, 0.024892f}, - {1600.000000f, 0.397814f, 0.118102f}, - {3200.000000f, 0.792300f, 0.443096f}, - {6400.000000f, 1.554968f, 2.329596f}, - {12800.000000f, 3.029946f, 11.217048f}, - {25600.000000f, 5.870243f, 45.309135f}, - {51200.000000f, 10.794330f, 187.701797f} - } - /*********************************************/ -}; - -static const ISP_CMOS_BAYERNR_S g_stIspBayerNr = { - 1, // bEnable - 0, // bBnrMonoSensorEn - 0, // bNrLscEnable - 96, // u8BnrLscMaxGain - 256, // u16BnrLscCmpStrength - {80, 80, 90, 90, 90, 90, 80, 70, 60, 50, 50, 50, 50, 50, 40, 40}, // FineStr - { - {1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3}, // ChromaStrR - {0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2}, // ChromaStrGr - {0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2}, // ChromaStrGb - {1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3} // ChromaStrB - }, - {0, 0, 0, 0}, // WDRFrameStr - {0, 0, 0, 0}, // FusionFrameStr - { - {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrR - {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrGR - {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrGB - {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170} // CoarseStrB - }, - {40, 40, 35, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30}, // lutCoringWeight - { - 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, \ - 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 100, 100, 100, 100, 100, 100, 100 - }, // CoringRatio -}; - -static const ISP_CMOS_LDCI_S g_stIspLdci = { - /* bEnable */ - 1, - /* u8GaussLPFSigma */ - 36, - - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - /* au8HePosWgt */ - { 50, 50, 50, 50, 48, 30, 30, 20, 10, 0, 0, 0, 0, 0, 0, 0}, - - /* au8HePosSigma */ - { 80, 72, 64, 48, 40, 24, 24, 20, 12, 8, 6, 2, 1, 1, 1, 1}, - - /* au8HePosMean */ - { 60, 50, 40, 40, 30, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20}, - - /* au8HeNegWgt */ - { 50, 45, 45, 45, 45, 40, 40, 30, 20, 10, 0, 0, 0, 0, 0, 0}, - - /* au8HeNegSigma */ - { 80, 80, 80, 80, 80, 72, 64, 54, 36, 8, 6, 2, 1, 1, 1, 1}, - - /* au8HeNegMean */ - {128, 128, 50, 60, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70}, - - /* au16BlcCtrl */ - { 20, 20, 20, 20, 20, 20, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30} -}; - -static const ISP_CMOS_GAMMA_S g_stIspGamma = { - /* au16Gamma[GAMMA_EXT_NODE_NUMBER] */ - { - 0, 19, 38, 58, 77, 97, 117, 137, 156, 176, 195, 215, 234, 253, 272, 290, 308, 326, 344, 364, 383, 401, 419, 436, 453, 470, 487, 504, 521, 539, 557, 576, - 596, 617, 627, 637, 648, 658, 669, 679, 690, 701, 712, 723, 734, 745, 757, 768, 779, 791, 803, 815, 827, 839, 851, 863, 876, 888, 901, 914, 927, 940, - 953, 967, 981, 987, 994, 1001, 1008, 1015, 1022, 1029, 1036, 1043, 1051, 1058, 1066, 1073, 1081, 1088, 1096, 1104, 1111, 1119, 1127, 1135, 1143, - 1150, 1158, 1166, 1174, 1182, 1190, 1198, 1206, 1214, 1222, 1230, 1238, 1246, 1254, 1262, 1270, 1278, 1286, 1294, 1302, 1310, 1318, 1326, 1334, - 1341, 1349, 1357, 1365, 1372, 1380, 1387, 1395, 1402, 1409, 1417, 1424, 1431, 1438, 1445, 1452, 1459, 1466, 1472, 1479, 1485, 1492, 1499, 1505, - 1511, 1518, 1524, 1531, 1537, 1543, 1549, 1556, 1562, 1568, 1574, 1580, 1586, 1592, 1598, 1604, 1610, 1616, 1622, 1628, 1634, 1639, 1645, 1651, - 1657, 1663, 1668, 1674, 1680, 1685, 1691, 1697, 1702, 1708, 1713, 1719, 1724, 1730, 1736, 1741, 1747, 1752, 1758, 1763, 1769, 1774, 1780, 1785, - 1790, 1796, 1801, 1807, 1812, 1818, 1823, 1829, 1834, 1840, 1845, 1850, 1856, 1861, 1867, 1872, 1877, 1883, 1888, 1893, 1899, 1904, 1909, 1915, - 1920, 1925, 1930, 1936, 1941, 1946, 1951, 1957, 1962, 1967, 1972, 1977, 1982, 1988, 1993, 1998, 2003, 2008, 2013, 2018, 2023, 2028, 2033, 2038, - 2043, 2048, 2053, 2058, 2063, 2068, 2073, 2078, 2082, 2087, 2092, 2097, 2102, 2107, 2111, 2116, 2121, 2126, 2131, 2135, 2140, 2145, 2149, 2154, - 2159, 2164, 2168, 2173, 2177, 2182, 2187, 2191, 2196, 2200, 2205, 2210, 2214, 2219, 2223, 2228, 2232, 2237, 2241, 2246, 2250, 2254, 2259, 2263, - 2268, 2272, 2276, 2281, 2285, 2289, 2294, 2298, 2302, 2307, 2311, 2315, 2319, 2324, 2328, 2332, 2336, 2340, 2344, 2349, 2353, 2357, 2361, 2365, - 2369, 2373, 2377, 2381, 2385, 2389, 2393, 2397, 2401, 2405, 2409, 2413, 2416, 2420, 2424, 2428, 2432, 2436, 2439, 2443, 2447, 2450, 2454, 2458, - 2461, 2465, 2468, 2472, 2475, 2479, 2482, 2486, 2489, 2493, 2496, 2500, 2503, 2506, 2510, 2513, 2516, 2520, 2523, 2526, 2529, 2533, 2536, 2539, - 2542, 2546, 2549, 2552, 2555, 2558, 2561, 2565, 2568, 2571, 2574, 2577, 2580, 2583, 2586, 2590, 2593, 2596, 2599, 2602, 2605, 2608, 2611, 2614, - 2617, 2621, 2624, 2627, 2630, 2633, 2636, 2639, 2642, 2646, 2649, 2652, 2656, 2659, 2662, 2665, 2668, 2671, 2674, 2677, 2680, 2683, 2686, 2690, - 2693, 2696, 2699, 2702, 2705, 2708, 2711, 2714, 2717, 2720, 2723, 2726, 2729, 2732, 2735, 2738, 2741, 2744, 2747, 2750, 2753, 2756, 2759, 2762, - 2764, 2767, 2770, 2773, 2776, 2779, 2782, 2785, 2788, 2791, 2794, 2796, 2799, 2802, 2805, 2808, 2811, 2814, 2817, 2820, 2822, 2825, 2828, 2831, - 2834, 2837, 2840, 2843, 2845, 2848, 2851, 2853, 2856, 2859, 2862, 2865, 2868, 2871, 2874, 2877, 2879, 2882, 2885, 2887, 2890, 2893, 2896, 2899, - 2901, 2904, 2907, 2909, 2912, 2915, 2918, 2920, 2923, 2926, 2929, 2932, 2934, 2937, 2940, 2942, 2945, 2948, 2951, 2954, 2956, 2959, 2962, 2964, - 2966, 2969, 2972, 2974, 2977, 2980, 2983, 2986, 2988, 2991, 2994, 2996, 2998, 3001, 3004, 3006, 3009, 3012, 3015, 3018, 3020, 3023, 3026, 3028, - 3031, 3033, 3035, 3038, 3040, 3043, 3046, 3048, 3051, 3054, 3057, 3059, 3062, 3064, 3066, 3069, 3071, 3074, 3077, 3080, 3082, 3085, 3088, 3090, - 3093, 3095, 3097, 3100, 3102, 3105, 3108, 3110, 3113, 3115, 3117, 3120, 3122, 3125, 3128, 3130, 3133, 3135, 3138, 3140, 3143, 3145, 3147, 3150, - 3152, 3155, 3158, 3160, 3163, 3165, 3167, 3170, 3172, 3175, 3178, 3180, 3183, 3185, 3187, 3189, 3192, 3194, 3196, 3199, 3201, 3204, 3207, 3209, - 3211, 3214, 3217, 3219, 3222, 3224, 3226, 3228, 3231, 3233, 3235, 3238, 3241, 3243, 3245, 3247, 3250, 3252, 3254, 3257, 3260, 3262, 3264, 3267, - 3269, 3271, 3273, 3276, 3279, 3281, 3283, 3286, 3288, 3290, 3292, 3295, 3298, 3300, 3302, 3305, 3307, 3309, 3311, 3313, 3316, 3318, 3320, 3322, - 3325, 3327, 3329, 3332, 3335, 3337, 3339, 3342, 3344, 3346, 3348, 3350, 3353, 3355, 3357, 3360, 3362, 3364, 3366, 3368, 3371, 3373, 3375, 3378, - 3380, 3382, 3384, 3386, 3389, 3391, 3393, 3396, 3398, 3400, 3402, 3405, 3407, 3409, 3411, 3413, 3416, 3418, 3420, 3423, 3425, 3427, 3429, 3431, - 3434, 3436, 3438, 3441, 3443, 3445, 3447, 3449, 3452, 3454, 3456, 3459, 3461, 3463, 3465, 3467, 3469, 3471, 3473, 3475, 3478, 3480, 3482, 3484, - 3487, 3489, 3491, 3494, 3496, 3498, 3500, 3502, 3504, 3506, 3508, 3511, 3513, 3515, 3517, 3519, 3521, 3523, 3525, 3528, 3530, 3532, 3534, 3536, - 3538, 3540, 3542, 3545, 3547, 3549, 3551, 3553, 3555, 3557, 3559, 3561, 3564, 3566, 3568, 3570, 3572, 3574, 3576, 3578, 3581, 3583, 3585, 3587, - 3589, 3591, 3593, 3595, 3598, 3600, 3602, 3604, 3606, 3608, 3610, 3612, 3614, 3616, 3618, 3620, 3622, 3624, 3626, 3628, 3631, 3633, 3635, 3637, - 3639, 3641, 3643, 3645, 3647, 3649, 3651, 3653, 3655, 3657, 3659, 3661, 3663, 3665, 3667, 3670, 3672, 3674, 3676, 3678, 3680, 3682, 3684, 3686, - 3688, 3690, 3692, 3694, 3696, 3698, 3700, 3702, 3704, 3706, 3708, 3710, 3712, 3714, 3716, 3718, 3720, 3722, 3724, 3726, 3728, 3730, 3732, 3734, - 3736, 3738, 3740, 3742, 3744, 3746, 3748, 3750, 3752, 3754, 3756, 3758, 3760, 3762, 3764, 3766, 3767, 3769, 3771, 3773, 3775, 3777, 3779, 3781, - 3783, 3785, 3787, 3789, 3791, 3793, 3795, 3797, 3799, 3801, 3803, 3804, 3806, 3808, 3810, 3812, 3814, 3816, 3818, 3820, 3822, 3824, 3826, 3828, - 3830, 3832, 3834, 3836, 3837, 3839, 3841, 3843, 3845, 3847, 3849, 3851, 3853, 3855, 3857, 3858, 3860, 3862, 3864, 3866, 3868, 3870, 3872, 3873, - 3875, 3877, 3879, 3881, 3883, 3885, 3887, 3888, 3890, 3892, 3894, 3896, 3898, 3900, 3902, 3904, 3905, 3907, 3909, 3911, 3913, 3915, 3917, 3919, - 3920, 3922, 3924, 3926, 3928, 3930, 3932, 3934, 3935, 3937, 3939, 3941, 3943, 3945, 3947, 3949, 3950, 3952, 3954, 3955, 3957, 3959, 3961, 3963, - 3965, 3967, 3969, 3971, 3972, 3974, 3976, 3977, 3979, 3981, 3983, 3985, 3987, 3989, 3991, 3993, 3994, 3996, 3998, 4000, 4001, 4003, 4005, 4006, - 4008, 4010, 4012, 4014, 4016, 4018, 4020, 4022, 4023, 4025, 4027, 4028, 4030, 4032, 4034, 4036, 4037, 4039, 4041, 4042, 4044, 4046, 4048, 4050, - 4052, 4054, 4056, 4058, 4059, 4061, 4063, 4064, 4066, 4068, 4070, 4072, 4073, 4075, 4077, 4078, 4080, 4082, 4084, 4086, 4087, 4089, 4091, 4092, - 4094, 4095 - } -}; - -static const ISP_CMOS_PREGAMMA_S g_stPreGamma = { - 0, - { - 3821, 7131, 9741, 11691, 13307, 14713, 15971, 17118, 18179, 20099, 21818, 23385, 24833, 26185, 27456, 28659, - 29804, 30897, 31945, 32952, 33923, 35770, 37506, 39150, 40713, 42207, 43638, 45014, 46340, 47622, 48863, 50066, - 51235, 52373, 53481, 54561, 55616, 57656, 59611, 61491, 63303, 65054, 66749, 68393, 69990, 71543, 73057, 74533, - 75974, 77383, 78761, 80110, 81432, 83999, 86475, 88866, 91182, 93428, 95609, 97731, 99799, 101815, 103784, 105708, - 107590, 109433, 111239, 113010, 114747, 118128, 121395, 124558, 127626, 130606, 133505, 136330, 139084, 141773, 144402, 146973, - 149491, 151957, 154376, 156749, 159079, 161368, 163618, 165831, 168008, 170152, 172263, 174342, 176392, 178413, 180407, 182374, - 184315, 186232, 188125, 189995, 191842, 193668, 197259, 200771, 204210, 207580, 210884, 214126, 217308, 220435, 223509, 226532, - 229506, 232434, 235318, 238159, 240959, 243720, 246443, 249130, 251782, 254400, 256986, 259540, 262064, 264559, 267025, 269464, - 271876, 274262, 276623, 278960, 281273, 283562, 288076, 292504, 296852, 301124, 305323, 309452, 313515, 317515, 321454, 325335, - 329160, 332931, 336651, 340322, 343945, 347521, 351054, 354543, 357991, 361399, 364767, 368099, 371394, 374653, 377878, 381070, - 384230, 387358, 390456, 393523, 396562, 399573, 405512, 411348, 417083, 422724, 428274, 433738, 439119, 444420, 449646, 454798, - 459880, 464894, 469842, 474728, 479554, 484320, 489030, 493685, 498287, 502838, 507339, 511791, 516197, 520557, 524874, 529147, - 533378, 537569, 541720, 545833, 549908, 553946, 557949, 561917, 565852, 569753, 577458, 585040, 592504, 599854, 607096, 614234, - 621272, 628214, 635064, 641824, 648498, 655090, 661601, 668035, 674394, 680681, 686897, 693045, 699128, 705146, 711103, 716999, - 722836, 728616, 734341, 740012, 745630, 751197, 756713, 762181, 767602, 778305, 788831, 799189, 809384, 819425, 829318, 839069, - 848683, 858166, 867523, 876757, 885875, 894879, 903774, 912563, 921249, 938329, 955037, 971395, 987423, 1003139, 1018560, 1033701, - 1048575 - } -}; - -static const ISP_CMOS_SHARPEN_S g_stIspYuvSharpen = { - /* u8SkinUmin */ - 110, - /* u8SkinVmin */ - 128, - /* u8SkinUmax */ - 128, - /* u8SkinVmax */ - 149, - - /* Manual Para */ - { - /* au8LumaWgt */ - {31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, - /* u16TextureStr */ - {420, 420, 390, 390, 390, 390, 390, 370, 350, 330, 310, 290, 270, 270, 270, 270, 270, 270, 266, 260, 244, 230, 230, 230, 230, 230, 230, 210, 190, 190, 170, 150}, - /* u16EdgeStr */ - {120, 123, 125, 128, 130, 135, 140, 148, 160, 168, 180, 190, 200, 210, 210, 210, 210, 210, 200, 190, 185, 175, 165, 160, 146, 136, 130, 128, 125, 123, 120, 120}, - /* u16TextureFreq; */ - 160, - /* u16EdgeFreq; */ - 100, - /* u8OverShoot; */ - 55, - /* u8UnderShoot; */ - 70, - /* u8shootSupStr; */ - 10, - /* u8shootSupAdj; */ - 9, - /* u8DetailCtrl; */ - 128, - /* u8DetailCtrlThr; */ - 180, - /* u8EdgeFiltStr; */ - 60, - /*u8EdgeFiltMaxCap; */ - 18, - /*u8RGain; */ - 28, - /* u8GGain; */ - 32, - /* u8BGain; */ - 31, - /* u8SkinGain; */ - 23, - /* u8MaxSharpGain; */ - 67, - /* u8WeakDetailGain */ - 6 - }, - /* Auto Para */ - { - /* au16LumaWgt */ - /* ISO */ - /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400,3276800 */ - { { 31, 31, 20, 31, 31, 26, 31, 31, 31, 31, 31, 31, 31, 1, 1, 1}, - { 31, 31, 20, 31, 31, 26, 31, 31, 31, 31, 31, 31, 31, 2, 2, 2}, - { 31, 31, 20, 31, 31, 27, 31, 31, 31, 31, 31, 31, 31, 4, 4, 4}, - { 31, 31, 20, 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 5, 5, 5}, - { 31, 31, 20, 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 7, 7, 7}, - { 31, 31, 20, 31, 31, 29, 31, 31, 31, 31, 31, 31, 31, 8, 8, 8}, - { 31, 31, 20, 31, 31, 30, 31, 31, 31, 31, 31, 31, 31, 9, 9, 9}, - { 31, 31, 23, 31, 31, 30, 31, 31, 31, 31, 31, 31, 31, 10, 10, 10}, - { 31, 31, 25, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 12, 12, 12}, - { 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 13, 13, 13}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 14, 14, 14}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 15, 15, 15}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 17, 17, 17}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 18, 18, 18}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 19, 19, 19}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 20, 20, 20}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 22, 22, 22}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 23, 23, 23}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 24, 24, 24}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, - { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28} - }, - /* au16TextureStr */ - /* ISO */ - /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400,3276800 */ - { { 285, 285, 264, 264, 264, 128, 128, 128, 128, 128, 128, 128, 128, 28, 28, 28}, - { 300, 300, 276, 276, 276, 148, 148, 148, 148, 148, 148, 148, 148, 43, 43, 43}, - { 315, 315, 292, 292, 292, 177, 177, 177, 177, 177, 177, 177, 177, 59, 59, 59}, - { 328, 328, 307, 307, 307, 211, 211, 211, 211, 211, 211, 211, 211, 75, 75, 75}, - { 337, 337, 316, 316, 316, 247, 247, 247, 247, 247, 247, 247, 247, 91, 91, 91}, - { 345, 345, 324, 324, 324, 281, 281, 281, 281, 281, 281, 281, 281, 106, 106, 106}, - { 352, 352, 331, 331, 331, 310, 310, 310, 310, 310, 310, 310, 310, 121, 121, 121}, - { 357, 357, 336, 336, 336, 331, 331, 331, 331, 331, 331, 331, 331, 136, 136, 136}, - { 359, 359, 337, 337, 337, 342, 342, 342, 342, 342, 342, 342, 342, 152, 152, 152}, - { 361, 361, 338, 338, 338, 348, 348, 348, 348, 348, 348, 348, 348, 167, 167, 167}, - { 363, 363, 338, 338, 338, 351, 351, 351, 351, 351, 351, 351, 351, 183, 183, 183}, - { 364, 364, 338, 338, 338, 352, 352, 352, 352, 352, 352, 352, 352, 199, 199, 199}, - { 364, 364, 337, 337, 337, 350, 350, 350, 350, 350, 350, 350, 350, 214, 214, 214}, - { 365, 365, 336, 336, 336, 347, 347, 347, 347, 347, 347, 347, 347, 228, 228, 228}, - { 364, 364, 335, 335, 335, 344, 344, 344, 344, 344, 344, 344, 344, 241, 241, 241}, - { 363, 363, 333, 333, 333, 341, 341, 341, 341, 341, 341, 341, 341, 254, 254, 254}, - { 361, 361, 331, 331, 331, 338, 338, 338, 338, 338, 338, 338, 338, 267, 267, 267}, - { 358, 358, 328, 328, 328, 333, 333, 333, 333, 333, 333, 333, 333, 283, 283, 283}, - { 355, 355, 324, 324, 324, 327, 327, 327, 327, 327, 327, 327, 327, 298, 298, 298}, - { 351, 351, 320, 320, 320, 320, 320, 320, 320, 320, 320, 320, 320, 313, 313, 313}, - { 346, 346, 316, 316, 316, 313, 313, 313, 313, 313, 313, 313, 313, 325, 325, 325}, - { 342, 342, 312, 312, 312, 305, 305, 305, 305, 305, 305, 305, 305, 338, 338, 338}, - { 337, 337, 308, 308, 308, 296, 296, 296, 296, 296, 296, 296, 296, 348, 348, 348}, - { 333, 333, 304, 304, 304, 288, 288, 288, 288, 288, 288, 288, 288, 353, 353, 353}, - { 329, 329, 300, 300, 300, 279, 279, 279, 279, 279, 279, 279, 279, 350, 350, 350}, - { 324, 324, 295, 295, 295, 270, 270, 270, 270, 270, 270, 270, 270, 343, 343, 343}, - { 318, 318, 290, 290, 290, 260, 260, 260, 260, 260, 260, 260, 260, 330, 330, 330}, - { 313, 313, 285, 285, 285, 249, 249, 249, 249, 249, 249, 249, 249, 313, 313, 313}, - { 308, 308, 280, 280, 280, 239, 239, 239, 239, 239, 239, 239, 239, 287, 287, 287}, - { 303, 303, 276, 276, 276, 228, 228, 228, 228, 228, 228, 228, 228, 254, 254, 254}, - { 299, 299, 272, 272, 272, 217, 217, 217, 217, 217, 217, 217, 217, 219, 219, 219}, - { 296, 296, 269, 269, 269, 207, 207, 207, 207, 207, 207, 207, 207, 186, 186, 186} - }, - /* au16EdgeStr */ - /* ISO */ - /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400, 3276800 */ - { { 250, 256, 262, 279, 320, 417, 320, 320, 432, 258, 400, 224, 224, 224, 224, 224}, - { 250, 260, 270, 296, 331, 421, 337, 337, 440, 291, 412, 244, 244, 244, 244, 244}, - { 250, 264, 279, 314, 343, 425, 354, 355, 451, 325, 424, 265, 265, 265, 265, 265}, - { 250, 268, 288, 332, 356, 429, 371, 373, 466, 359, 436, 285, 285, 285, 285, 285}, - { 250, 272, 296, 350, 368, 433, 386, 390, 485, 391, 452, 303, 303, 303, 303, 303}, - { 250, 276, 305, 368, 380, 437, 398, 406, 503, 420, 470, 319, 319, 319, 319, 319}, - { 250, 280, 313, 384, 391, 441, 410, 421, 523, 448, 490, 333, 333, 333, 333, 333}, - { 250, 286, 321, 398, 401, 445, 420, 436, 544, 475, 512, 346, 346, 346, 346, 346}, - { 250, 292, 328, 411, 410, 448, 430, 451, 565, 501, 534, 357, 357, 357, 357, 357}, - { 249, 299, 334, 420, 416, 450, 438, 463, 584, 525, 556, 364, 364, 364, 364, 364}, - { 249, 307, 339, 428, 422, 452, 446, 475, 603, 548, 580, 370, 370, 370, 370, 370}, - { 249, 316, 344, 434, 427, 453, 453, 486, 622, 570, 603, 374, 374, 374, 374, 374}, - { 248, 326, 349, 439, 431, 454, 460, 498, 641, 592, 623, 379, 379, 379, 379, 379}, - { 248, 335, 353, 442, 434, 455, 466, 511, 658, 614, 639, 384, 384, 384, 384, 384}, - { 248, 344, 357, 445, 437, 456, 473, 524, 671, 637, 652, 390, 390, 390, 390, 390}, - { 247, 351, 360, 447, 439, 456, 479, 538, 673, 658, 664, 394, 394, 394, 394, 394}, - { 247, 357, 364, 449, 442, 457, 485, 550, 674, 674, 674, 398, 398, 398, 398, 398}, - { 246, 361, 367, 450, 444, 456, 489, 563, 683, 686, 683, 398, 398, 398, 398, 398}, - { 245, 364, 369, 450, 445, 455, 492, 575, 690, 691, 690, 398, 398, 398, 398, 398}, - { 244, 366, 371, 450, 446, 454, 496, 585, 695, 695, 695, 398, 398, 398, 398, 398}, - { 243, 366, 373, 448, 446, 453, 500, 590, 696, 696, 696, 398, 398, 398, 398, 398}, - { 242, 366, 375, 445, 445, 451, 504, 594, 697, 697, 697, 398, 398, 398, 398, 398}, - { 241, 366, 376, 441, 445, 450, 508, 597, 696, 696, 696, 399, 399, 399, 399, 399}, - { 241, 366, 377, 436, 444, 449, 511, 600, 697, 697, 697, 402, 402, 402, 402, 402}, - { 240, 365, 377, 429, 442, 448, 509, 601, 697, 697, 697, 405, 405, 405, 405, 405}, - { 239, 363, 377, 422, 440, 447, 506, 600, 698, 698, 698, 408, 408, 408, 408, 408}, - { 238, 361, 377, 413, 437, 446, 502, 600, 699, 699, 699, 411, 411, 411, 411, 411}, - { 238, 359, 376, 403, 434, 446, 500, 600, 700, 700, 700, 413, 413, 413, 413, 413}, - { 237, 356, 376, 393, 431, 445, 498, 600, 700, 700, 700, 411, 411, 411, 411, 411}, - { 236, 353, 375, 383, 428, 445, 498, 600, 700, 700, 700, 408, 408, 408, 408, 408}, - { 235, 351, 375, 373, 425, 444, 498, 600, 700, 700, 700, 405, 405, 405, 405, 405}, - { 235, 349, 375, 364, 423, 444, 498, 600, 700, 700, 700, 402, 402, 402, 402, 402} - }, - /* au16TextureFreq */ - /* ISO */ - /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200, 1638400, 3276800 */ - { 180, 180, 180, 180, 160, 160, 160, 170, 170, 170, 170, 170, 170, 170, 170, 170}, - - /* au16EdgeFreq */ - { 130, 115, 100, 100, 100, 100, 100, 100, 100, 100, 96, 96, 96, 96, 96, 96}, - - /* au8OverShoot */ - { 65, 70, 75, 70, 65, 55, 40, 40, 30, 30, 40, 40, 10, 10, 10, 10}, - - /* au8UnderShoot */ - { 85, 87, 90, 80, 80, 70, 60, 55, 45, 45, 50, 50, 15, 15, 15, 15}, - - /* au16shootSupStr */ - { 8, 8, 7, 7, 7, 6, 5, 5, 0, 0, 0, 0, 0, 0, 0, 0}, - - /* au8ShootSupAdj */ - { 9, 9, 8, 8, 7, 7, 6, 6, 0, 0, 0, 0, 0, 0, 0, 0}, - - /* au8DetailCtrl */ - { 128, 128, 128, 128, 128, 128, 128, 128, 128, 128, 120, 120, 120, 120, 120, 120}, - - /* au8DetailCtrlThr */ - { 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160}, - - /* au8EdgeFiltStr */ - { 50, 50, 50, 55, 57, 60, 61, 62, 62, 62, 62, 62, 62, 62, 62, 62}, - - /* au8EdgeFiltMaxCap */ - { 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18 }, - - /* au8RGain */ - { 28, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, - - /* au8GGain */ - { 31, 31, 31, 31, 16, 16, 16, 16, 31, 31, 31, 31, 31, 31, 31, 31}, - - /* au8BGain */ - { 31, 31, 31, 31, 16, 16, 16, 16, 31, 31, 31, 31, 31, 31, 31, 31}, - - /* au8SkinGain */ - { 25, 27, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, - - /* u8MaxSharpGain */ - { 72, 72, 72, 74, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80}, - /* au8WeakDetailGain */ - { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } - - }, -}; - -static AWB_CCM_S g_stAwbCcm = { - 4, - { - { - 6150, - { - 0x0292, 0x81C6, 0x0034, - 0x806E, 0x01D1, 0x8063, - 0x8021, 0x815B, 0x027C - }, - }, - - { - 4850, - { - 0x02A5, 0x81D3, 0x002E, - 0x806D, 0x01AB, 0x803E, - 0x8023, 0x819F, 0x02C2 - }, - }, - - { - 3650, - { - 0x026E, 0x8172, 0x0004, - 0x809F, 0x01D6, 0x8037, - 0x8047, 0x81C4, 0x030B - }, - }, - - { - 2650, - { - 0x01E5, 0x80B7, 0x802E, - 0x8096, 0x01A6, 0x8010, - 0x80B9, 0x82B1, 0x046A - }, - }, - }, -}; - -static AWB_AGC_TABLE_S g_stAwbAgcTable = { - /* bvalid */ - 1, - - /* saturation */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - {115, 110, 110, 110, 108, 105, 100, 95, 90, 90, 90, 80, 80, 80, 80, 80} -}; - -static const ISP_CMOS_WDR_S g_stIspWDR = { - /* bFusionMode */ - 0, - - /* bMotionComp */ - 1, - - /* u16ShortThr */ - 4032, - - /* u16LongThr */ - 3008, - - /* bForceLong */ - 1, - - /* u16ForceLongLowThr */ - - 500, - - /* u16ForceLongHigThr */ - 700, - - /* bShortExpoChk */ - 0, - - /* u16ShortCheckThd */ - 0x8, - - /* au8MdThrLowGain[16] */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - { 64, 64, 64, 64, 128, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}, - - /* au8MdThrHigGain[16] */ - {128, 128, 128, 128, 128, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}, - - /* au16FusionThr[2] */ - {3855, 3000}, - - /* u8MdtStillThd */ - 0x14, - - /* u8MdtLongBlend */ - 0x0 -}; - -static const ISP_CMOS_DEHAZE_S g_stIspDehaze = { - /* bEnable */ - 0, - /* bUserLutEnable */ - 0, - /* enOpType */ - 0, - /* u8AutoStrength */ - 128, - /* u8ManualStrength */ - 128 -}; - -static const ISP_CMOS_DRC_S g_stIspDRC = { - /* bEnable */ - 0, - /* enOpType */ - 0, - /* u16ManualStrength */ - 512, - /* u16AutoStrength */ - 512, - /* u8SpatialFltCoef */ - 1, - /* u8RangeFltCoef */ - 2, - /* u8ContrastControl */ - 8, - /* s8DetailAdjustFactor */ - 0, - /* u8RangeAdaMax */ - 8, - /* u8FltScaleFine */ - 6, - /* u8FltScaleCoarse */ - 6, - /* u8GradRevMax */ - 64, - /* u8GradRevThr */ - 50, - /* u8BrightGainLmt */ - 12, - /* u8BrightGainLmtStep */ - 8, - /* u8DarkGainLmtY */ - 0, - /* u8DarkGainLmtC */ - 0, - /* u8PDStrength */ - 35, - /* u8LocalMixingBrightMax */ - 64, - /* u8LocalMixingBrightMin */ - 32, - /* u8LocalMixingBrightThr */ - 96, - /* s8LocalMixingBrightSlo */ - -3, - /* u8LocalMixingDarkMax */ - 64, - /* u8LocalMixingDarkMin */ - 32, - /* u8LocalMixingDarkThr */ - 200, - /* s8LocalMixingDarkSlo */ - 5, - /* ColorCorrectionLut[33] */ - {1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024}, - /*ToneMappingValue[200]*/ - {8, 8, 16, 24, 31, 39, 48, 56, 65, 75, 85, 95, 106, 118, 130, 143, 156, 170, 185, 201, 218, 235, 254, 274, 294, 316, 339, 364, 390, 417, 446, 477, 509, 543, 579, 617, 658, 701, 746, 794, 844, 898, 955, 1015, 1078, 1145, 1216, - 1291, 1370, 1454, 1543, 1637, 1736, 1841, 1952, 2069, 2194, 2325, 2465, 2612, 2767, 2932, 3106, 3290, 3485, 3691, 3909, 4140, 4384, 4641, 4914, 5202, 5507, 5830, 6171, 6531, 6913, 7316, 7742, 8193, 8669, 9173, 9705, 10268, - 10863, 11492, 12145, 12808, 13483, 14171, 14872, 15587, 16319, 17069, 17840, 18635, 19458, 19881, 20313, 20754, 21204, 21661, 22122, 22586, 23053, 23525, 24000, 24480, 24965, 25455, 25950, 26451, 26959, 27473, 27995, 28524, - 29062, 29609, 30165, 30732, 31309, 31899, 32501, 33116, 33746, 34391, 35043, 35706, 36381, 37066, 37763, 38472, 39192, 39925, 40671, 41429, 42201, 42591, 42986, 43383, 43784, 44189, 44597, 45008, 45424, 45842, 46265, 46691, - 47121, 47555, 47993, 48434, 48880, 49329, 49783, 50241, 50703, 51169, 51639, 52113, 52592, 53075, 53564, 54056, 54552, 55054, 55560, 56071, 56586, 56846, 57107, 57369, 57632, 57896, 58162, 58429, 58697, 58967, 59238, 59510, - 59783, 60057, 60333, 60611, 60889, 61169, 61451, 61733, 62017, 62303, 62589, 62877, 63167, 63458, 63750, 64044, 64340, 64636, 64934, 65234}, - /* u8Asymmetry */ - 2, - /* u8SecondPole */ - 180, - /* u8Stretch */ - 54, - /* u8Compress */ - 180, - /* u8CurveSel */ - 0, - /* au16Xpoint */ - {0, 200, 400, 600, 1000}, - /* au16Ypoint */ - {0, 200, 400, 600, 1000}, - /* au16Slope */ - {1000, 1000, 1000, 1000, 1000} -}; - -static const ISP_CMOS_DRC_S g_stIspDRCWDR = { - /* bEnable */ - 1, - /* enOpType */ - 0, - /* u16ManualStrength */ - 1023, - /* u16AutoStrength */ - 512, - /* u8SpatialFltCoef */ - 0, - /* u8RangeFltCoef */ - 1, - /* u8ContrastControl */ - 9, - /* s8DetailAdjustFactor */ - 12, - /* u8RangeAdaMax */ - 4, - /* u8FltScaleFine */ - 3, - /* u8FltScaleCoarse */ - 3, - /* u8GradRevMax */ - 30, - /* u8GradRevThr */ - 50, - /* u8BrightGainLmt */ - 12, - /* u8BrightGainLmtStep */ - 10, - /* u8DarkGainLmtY */ - 0, - /* u8DarkGainLmtC */ - 0, - /* u8PDStrength */ - 35, - /* u8LocalMixingBrightMax */ - 36, - /* u8LocalMixingBrightMin */ - 24, - /* u8LocalMixingBrightThr */ - 96, - /* s8LocalMixingBrightSlo */ - -3, - /* u8LocalMixingDarkMax */ - 36, - /* u8LocalMixingDarkMin */ - 24, - /* u8LocalMixingDarkThr */ - 200, - /* s8LocalMixingDarkSlo */ - 5, - /* ColorCorrectionLut[33] */ - {1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 772, 768, 764, 760, 756, 752, 748, 744, 740, 736, 732, 728, 724, 720, 716, 712, 708, 704, 700}, - /* ToneMappingValue[200] */ - {8, 8, 16, 24, 31, 39, 48, 56, 65, 75, 85, 95, 106, 118, 130, 143, 156, 170, 185, 201, 218, 235, 254, 274, 294, 316, 339, 364, 390, 417, 446, 477, 509, 543, 579, 617, 658, 701, 746, 794, 844, 898, 955, 1015, 1078, 1145, 1216, - 1291, 1370, 1454, 1543, 1637, 1736, 1841, 1952, 2069, 2194, 2325, 2465, 2612, 2767, 2932, 3106, 3290, 3485, 3691, 3909, 4140, 4384, 4641, 4914, 5202, 5507, 5830, 6171, 6531, 6913, 7316, 7742, 8193, 8669, 9173, 9705, 10268, - 10863, 11492, 12145, 12808, 13483, 14171, 14872, 15587, 16319, 17069, 17840, 18635, 19458, 19881, 20313, 20754, 21204, 21661, 22122, 22586, 23053, 23525, 24000, 24480, 24965, 25455, 25950, 26451, 26959, 27473, 27995, 28524, - 29062, 29609, 30165, 30732, 31309, 31899, 32501, 33116, 33746, 34391, 35043, 35706, 36381, 37066, 37763, 38472, 39192, 39925, 40671, 41429, 42201, 42591, 42986, 43383, 43784, 44189, 44597, 45008, 45424, 45842, 46265, 46691, - 47121, 47555, 47993, 48434, 48880, 49329, 49783, 50241, 50703, 51169, 51639, 52113, 52592, 53075, 53564, 54056, 54552, 55054, 55560, 56071, 56586, 56846, 57107, 57369, 57632, 57896, 58162, 58429, 58697, 58967, 59238, 59510, - 59783, 60057, 60333, 60611, 60889, 61169, 61451, 61733, 62017, 62303, 62589, 62877, 63167, 63458, 63750, 64044, 64340, 64636, 64934, 65234}, - /* u8Asymmetry */ - 6, - /* u8SecondPole */ - 180, - /* u8Stretch */ - 50, - /* u8Compress */ - 150, - /* u8CurveSel */ - 0, - /* au16Xpoint */ - {0, 200, 400, 600, 1000}, - /* au16Ypoint */ - {0, 200, 400, 600, 1000}, - /* au16Slope */ - {1000, 1000, 1000, 1000, 1000} -}; - -static const ISP_CMOS_CA_S g_stIspCA = { - /* CA */ - 1, - /* Y */ - { - 516, 525, 534, 544, 554, 563, 573, 583, 594, 604, 614, 624, 634, 644, 654, 664, - 674, 684, 694, 704, 713, 723, 732, 741, 750, 758, 766, 775, 782, 790, 797, 804, - 811, 817, 823, 828, 834, 839, 844, 848, 853, 857, 861, 865, 868, 872, 875, 878, - 881, 884, 887, 890, 892, 895, 898, 900, 903, 905, 908, 910, 913, 915, 918, 921, - 924, 926, 929, 932, 935, 937, 940, 943, 945, 948, 950, 952, 955, 957, 959, 961, - 964, 966, 968, 970, 972, 974, 976, 978, 979, 981, 983, 985, 987, 988, 990, 992, - 993, 994, 995, 996, 997, 998, 998, 999, 1000, 1001, 1002, 1002, 1003, 1004, 1005, 1006, - 1006, 1007, 1008, 1009, 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1018, 1019, 1020, 1022, 1024 - }, - /* ISO */ - /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ - {1300, 1300, 1250, 1200, 1150, 1100, 1050, 1000, 950, 900, 900, 800, 800, 800, 800, 800} -}; - - -static const ISP_CMOS_LSC_S g_stCmosLsc = { - /* MeshStrength */ - 256, - /* MeshScale */ - 4, - /* ISP_LSC_CABLI_TABLE_S */ - { - { - // Rgain: - { - 0x26b, 0x1de, 0x179, 0x12a, 0xee, 0xc4, 0xa2, 0x94, 0x94, 0x97, 0xad, 0xc8, 0x10d, 0x133, 0x184, 0x1fd, 0x284, - 0x235, 0x1ba, 0x158, 0x10d, 0xd3, 0xad, 0x8c, 0x7b, 0x74, 0x7b, 0x90, 0xaf, 0xd8, 0x114, 0x164, 0x1d1, 0x253, - 0x210, 0x194, 0x136, 0xec, 0xbc, 0x91, 0x6f, 0x5d, 0x59, 0x5f, 0x75, 0x94, 0xbf, 0xf7, 0x149, 0x1ac, 0x229, - 0x1e1, 0x177, 0x11a, 0xd7, 0xa6, 0x7c, 0x5b, 0x44, 0x3e, 0x4a, 0x5c, 0x7d, 0xab, 0xe2, 0x127, 0x18f, 0x200, - 0x1c8, 0x15f, 0x10d, 0xc9, 0x98, 0x69, 0x4a, 0x32, 0x2a, 0x33, 0x4a, 0x6b, 0x9e, 0xd0, 0x113, 0x175, 0x1e5, - 0x1b6, 0x14f, 0xf9, 0xbf, 0x84, 0x57, 0x34, 0x21, 0x18, 0x21, 0x3a, 0x5e, 0x8e, 0xc2, 0x105, 0x162, 0x1d8, - 0x1a9, 0x140, 0xef, 0xb4, 0x7d, 0x50, 0x2d, 0x11, 0xa, 0x15, 0x2f, 0x57, 0x83, 0xb9, 0xfb, 0x156, 0x1c3, - 0x1a5, 0x134, 0xe9, 0xae, 0x7a, 0x4b, 0x26, 0x8, 0x4, 0xc, 0x28, 0x4f, 0x7f, 0xb8, 0xf7, 0x151, 0x1bf, - 0x19d, 0x134, 0xe8, 0xac, 0x75, 0x48, 0x34, 0x4, 0x0, 0xa, 0x25, 0x50, 0x7e, 0xb5, 0xf8, 0x150, 0x1bd, - 0x199, 0x134, 0xea, 0xae, 0x73, 0x4b, 0x32, 0x5, 0x2, 0xd, 0x2a, 0x4e, 0x83, 0xbc, 0xf9, 0x151, 0x1c0, - 0x1a5, 0x139, 0xee, 0xb1, 0x7e, 0x51, 0x2f, 0x14, 0xd, 0x16, 0x31, 0x56, 0x86, 0xbb, 0x100, 0x158, 0x1c3, - 0x1b2, 0x147, 0xfe, 0xbd, 0x87, 0x5f, 0x3b, 0x24, 0x1b, 0x24, 0x43, 0x64, 0x90, 0xc8, 0x107, 0x164, 0x1d2, - 0x1c1, 0x159, 0x107, 0xca, 0x94, 0x6e, 0x4d, 0x36, 0x30, 0x36, 0x4e, 0x74, 0x9b, 0xd1, 0x11a, 0x173, 0x1e2, - 0x1de, 0x16f, 0x119, 0xda, 0xa7, 0x7f, 0x64, 0x4e, 0x45, 0x4f, 0x62, 0x86, 0xb1, 0xe6, 0x128, 0x188, 0x1fd, - 0x1f9, 0x18a, 0x131, 0xf2, 0xbf, 0x99, 0x79, 0x65, 0x60, 0x6a, 0x7b, 0x9e, 0xc9, 0xfb, 0x13d, 0x19f, 0x21e, - 0x21c, 0x1a9, 0x14b, 0x109, 0xd6, 0xb4, 0x96, 0x83, 0x7f, 0x83, 0x94, 0xb7, 0xe0, 0x115, 0x15d, 0x1c1, 0x23f, - 0x244, 0x1c8, 0x167, 0x127, 0xf5, 0xcc, 0xb1, 0x9f, 0x99, 0x98, 0xb3, 0xce, 0xf7, 0x12e, 0x17a, 0x1e9, 0x262, - }, - - // Grgain: - { - 0x27c, 0x1fd, 0x18b, 0x138, 0xfb, 0xd2, 0xb1, 0xa3, 0x9d, 0xa0, 0xb7, 0xd8, 0x11d, 0x141, 0x1a4, 0x21c, 0x2ab, - 0x24a, 0x1d0, 0x164, 0x113, 0xde, 0xb4, 0x96, 0x83, 0x7e, 0x84, 0x9a, 0xbb, 0xe8, 0x128, 0x17a, 0x1ec, 0x274, - 0x21c, 0x1a8, 0x140, 0xf8, 0xc5, 0x9b, 0x77, 0x64, 0x5d, 0x67, 0x80, 0x9f, 0xca, 0x105, 0x15a, 0x1c1, 0x24e, - 0x1f6, 0x18b, 0x127, 0xe6, 0xaf, 0x82, 0x62, 0x4b, 0x46, 0x4e, 0x64, 0x85, 0xb6, 0xee, 0x13c, 0x1a6, 0x22d, - 0x1de, 0x170, 0x118, 0xd3, 0x9d, 0x6f, 0x4c, 0x35, 0x2a, 0x37, 0x4f, 0x76, 0xa3, 0xdb, 0x123, 0x187, 0x20b, - 0x1ca, 0x15c, 0x107, 0xc6, 0x8e, 0x5d, 0x3c, 0x21, 0x19, 0x27, 0x41, 0x68, 0x94, 0xce, 0x116, 0x17a, 0x1fa, - 0x1b4, 0x151, 0xfc, 0xbd, 0x85, 0x54, 0x31, 0x12, 0x9, 0x16, 0x34, 0x5c, 0x89, 0xc6, 0x10a, 0x16b, 0x1e5, - 0x1ae, 0x147, 0xf7, 0xb7, 0x80, 0x53, 0x29, 0xa, 0x4, 0x12, 0x2c, 0x56, 0x86, 0xc1, 0x103, 0x166, 0x1dc, - 0x1ac, 0x144, 0xf5, 0xb5, 0x7d, 0x4c, 0x37, 0x7, 0x1, 0xc, 0x2a, 0x55, 0x83, 0xbe, 0x101, 0x166, 0x1d7, - 0x1aa, 0x145, 0xf9, 0xb6, 0x82, 0x52, 0x3a, 0xb, 0x5, 0xd, 0x2d, 0x57, 0x88, 0xc0, 0x102, 0x162, 0x1dc, - 0x1b4, 0x14d, 0xfe, 0xbc, 0x87, 0x5c, 0x36, 0x16, 0xf, 0x19, 0x36, 0x5f, 0x8f, 0xca, 0x10d, 0x16b, 0x1e2, - 0x1be, 0x15a, 0x10b, 0xca, 0x90, 0x63, 0x3e, 0x26, 0x1f, 0x2b, 0x44, 0x69, 0x9c, 0xd2, 0x119, 0x175, 0x1f3, - 0x1c9, 0x16a, 0x114, 0xd5, 0x9e, 0x77, 0x54, 0x3a, 0x33, 0x3a, 0x54, 0x79, 0xa8, 0xe1, 0x127, 0x184, 0x203, - 0x1ed, 0x186, 0x12a, 0xe7, 0xb1, 0x87, 0x6a, 0x55, 0x4c, 0x54, 0x6d, 0x8f, 0xbb, 0xf4, 0x137, 0x1a0, 0x21a, - 0x20d, 0x1a0, 0x140, 0xfc, 0xc7, 0xa3, 0x81, 0x6d, 0x66, 0x71, 0x85, 0xa5, 0xd3, 0x108, 0x152, 0x1b9, 0x23c, - 0x231, 0x1bf, 0x160, 0x119, 0xe6, 0xbd, 0x9e, 0x8a, 0x84, 0x8c, 0xa2, 0xc5, 0xf0, 0x123, 0x16d, 0x1da, 0x260, - 0x25c, 0x1e1, 0x17f, 0x136, 0xfd, 0xda, 0xbe, 0xaa, 0x9f, 0xa9, 0xbb, 0xda, 0x104, 0x13e, 0x18e, 0x1ff, 0x285, - }, - - // Gbgain: - { - 0x28b, 0x1fd, 0x18e, 0x139, 0xfd, 0xd7, 0xb6, 0xa3, 0xa4, 0xa9, 0xbc, 0xde, 0x126, 0x14d, 0x1a5, 0x21f, 0x2b1, - 0x256, 0x1d6, 0x16a, 0x11d, 0xe4, 0xb9, 0x9b, 0x87, 0x83, 0x8b, 0xa0, 0xc1, 0xec, 0x12e, 0x183, 0x1f5, 0x284, - 0x229, 0x1ad, 0x142, 0xfb, 0xc9, 0x9f, 0x7c, 0x6a, 0x62, 0x6c, 0x84, 0xa4, 0xd2, 0x10f, 0x15f, 0x1ce, 0x252, - 0x201, 0x18a, 0x129, 0xe8, 0xb1, 0x86, 0x67, 0x4d, 0x4b, 0x51, 0x6a, 0x8b, 0xbc, 0xf9, 0x140, 0x1ac, 0x229, - 0x1ea, 0x176, 0x116, 0xd2, 0x9e, 0x73, 0x4e, 0x38, 0x2f, 0x3c, 0x54, 0x7a, 0xaa, 0xe0, 0x127, 0x18f, 0x211, - 0x1ce, 0x160, 0x107, 0xc8, 0x94, 0x5f, 0x3d, 0x22, 0x1e, 0x28, 0x43, 0x6b, 0x9a, 0xd1, 0x11c, 0x17d, 0x1fa, - 0x1bf, 0x153, 0x101, 0xbe, 0x86, 0x54, 0x2f, 0x14, 0xc, 0x1b, 0x36, 0x60, 0x91, 0xc9, 0x110, 0x16f, 0x1eb, - 0x1bf, 0x14a, 0xfa, 0xb8, 0x81, 0x4f, 0x28, 0xb, 0x3, 0x11, 0x2e, 0x56, 0x8a, 0xc6, 0x10a, 0x16a, 0x1e2, - 0x1b1, 0x149, 0xfa, 0xb8, 0x7f, 0x50, 0x37, 0x8, 0x0, 0xf, 0x2e, 0x57, 0x89, 0xc2, 0x107, 0x16a, 0x1df, - 0x1b9, 0x148, 0xf9, 0xba, 0x82, 0x54, 0x36, 0xd, 0x5, 0x10, 0x2f, 0x5a, 0x8b, 0xc5, 0x10a, 0x167, 0x1dd, - 0x1c0, 0x150, 0x100, 0xbf, 0x86, 0x5a, 0x34, 0x16, 0x10, 0x18, 0x39, 0x61, 0x91, 0xcb, 0x115, 0x171, 0x1e9, - 0x1d0, 0x15d, 0x10b, 0xc9, 0x93, 0x66, 0x43, 0x26, 0x1f, 0x29, 0x46, 0x6d, 0x9f, 0xd4, 0x11a, 0x17d, 0x1f3, - 0x1e1, 0x16e, 0x11a, 0xd6, 0x9d, 0x76, 0x54, 0x3c, 0x35, 0x40, 0x59, 0x7b, 0xad, 0xe4, 0x128, 0x187, 0x20a, - 0x200, 0x184, 0x12c, 0xe8, 0xb3, 0x87, 0x66, 0x51, 0x4d, 0x55, 0x6d, 0x93, 0xbd, 0xf9, 0x13f, 0x1a2, 0x21d, - 0x214, 0x1a4, 0x145, 0xfd, 0xc7, 0x9f, 0x82, 0x6d, 0x66, 0x6d, 0x86, 0xa8, 0xd7, 0x10c, 0x155, 0x1bd, 0x246, - 0x242, 0x1c2, 0x161, 0x119, 0xe4, 0xb9, 0x9d, 0x8f, 0x83, 0x8d, 0xa3, 0xc4, 0xf1, 0x12a, 0x174, 0x1e1, 0x26b, - 0x261, 0x1de, 0x17f, 0x131, 0xfd, 0xd8, 0xbc, 0xac, 0x9d, 0xa9, 0xbe, 0xe0, 0x109, 0x142, 0x193, 0x208, 0x28f, - }, - - // Bgain: - { - 0x28e, 0x202, 0x186, 0x12f, 0xfb, 0xcc, 0xb4, 0xa4, 0xa4, 0xa9, 0xba, 0xe2, 0x120, 0x14b, 0x1a5, 0x220, 0x2b6, - 0x251, 0x1d8, 0x16e, 0x114, 0xde, 0xb3, 0x92, 0x83, 0x81, 0x88, 0xa1, 0xbe, 0xec, 0x128, 0x17d, 0x1f1, 0x274, - 0x228, 0x1ac, 0x144, 0xfc, 0xc2, 0x97, 0x7c, 0x67, 0x61, 0x67, 0x7e, 0x9e, 0xcf, 0x107, 0x155, 0x1c9, 0x252, - 0x1fa, 0x183, 0x12a, 0xe4, 0xb0, 0x83, 0x61, 0x4d, 0x48, 0x50, 0x67, 0x86, 0xb4, 0xec, 0x133, 0x1a4, 0x22c, - 0x1da, 0x16d, 0x113, 0xcd, 0x9f, 0x70, 0x4e, 0x3a, 0x2f, 0x3c, 0x51, 0x75, 0xa0, 0xdb, 0x11e, 0x185, 0x201, - 0x1c5, 0x15d, 0x101, 0xc5, 0x8b, 0x5b, 0x41, 0x24, 0x1e, 0x27, 0x3d, 0x65, 0x93, 0xce, 0x114, 0x179, 0x1fc, - 0x1bc, 0x150, 0xfb, 0xbe, 0x87, 0x57, 0x30, 0x17, 0xd, 0x18, 0x37, 0x5f, 0x8b, 0xbf, 0x105, 0x16b, 0x1e9, - 0x1ac, 0x147, 0xf1, 0xb8, 0x80, 0x4f, 0x29, 0xf, 0x5, 0x10, 0x32, 0x5c, 0x88, 0xc2, 0x107, 0x160, 0x1d4, - 0x1af, 0x143, 0xf7, 0xb4, 0x7d, 0x4f, 0x3a, 0x7, 0x1, 0xc, 0x2f, 0x57, 0x8b, 0xc0, 0x102, 0x15f, 0x1d8, - 0x1a8, 0x147, 0xf5, 0xb6, 0x80, 0x51, 0x37, 0xc, 0x5, 0x10, 0x2f, 0x5a, 0x8b, 0xc8, 0x108, 0x163, 0x1da, - 0x1bc, 0x151, 0xfb, 0xba, 0x8a, 0x59, 0x36, 0x15, 0xf, 0x1b, 0x38, 0x62, 0x92, 0xc9, 0x10e, 0x171, 0x1ec, - 0x1cd, 0x156, 0x105, 0xc6, 0x8c, 0x66, 0x45, 0x27, 0x23, 0x27, 0x47, 0x6f, 0x9a, 0xd8, 0x115, 0x17e, 0x1ee, - 0x1da, 0x16c, 0x110, 0xd2, 0x9e, 0x78, 0x54, 0x3d, 0x38, 0x3e, 0x58, 0x78, 0xad, 0xe3, 0x126, 0x186, 0x20d, - 0x201, 0x18e, 0x12b, 0xe2, 0xb1, 0x87, 0x67, 0x54, 0x51, 0x58, 0x6c, 0x93, 0xb8, 0xf4, 0x13b, 0x1a3, 0x229, - 0x217, 0x1aa, 0x147, 0x100, 0xc8, 0xa0, 0x82, 0x6c, 0x66, 0x6c, 0x86, 0xa9, 0xd0, 0x107, 0x156, 0x1bb, 0x23b, - 0x232, 0x1c2, 0x165, 0x117, 0xe4, 0xbf, 0xa2, 0x8c, 0x85, 0x8a, 0x9f, 0xc1, 0xeb, 0x126, 0x16b, 0x1dd, 0x26c, - 0x262, 0x1ea, 0x17c, 0x132, 0xf7, 0xd2, 0xc0, 0xa9, 0x9f, 0xa5, 0xb9, 0xd3, 0x102, 0x137, 0x184, 0x206, 0x289, - }, - }, - - { - // Rgain: - { - 0x399, 0x2df, 0x23e, 0x1cd, 0x170, 0x135, 0xfc, 0xdb, 0xda, 0xe4, 0xfd, 0x12f, 0x16e, 0x1d4, 0x24e, 0x2ee, 0x3e2, - 0x372, 0x2b0, 0x20f, 0x19a, 0x140, 0x109, 0xdc, 0xb7, 0xaf, 0xbe, 0xd5, 0x105, 0x14c, 0x1a4, 0x225, 0x2b8, 0x384, - 0x32a, 0x276, 0x1e3, 0x174, 0x11c, 0xda, 0xaf, 0x92, 0x88, 0x97, 0xac, 0xec, 0x125, 0x180, 0x200, 0x289, 0x34f, - 0x2f6, 0x24f, 0x1bd, 0x14b, 0xfd, 0xba, 0x89, 0x6c, 0x61, 0x71, 0x89, 0xc6, 0x107, 0x15a, 0x1c7, 0x262, 0x319, - 0x2c9, 0x229, 0x1a5, 0x135, 0xdb, 0x9b, 0x6a, 0x4a, 0x3f, 0x4e, 0x6c, 0xa5, 0xeb, 0x13e, 0x1b1, 0x23d, 0x2e3, - 0x2b9, 0x211, 0x187, 0x11b, 0xc9, 0x81, 0x4d, 0x2b, 0x21, 0x2f, 0x58, 0x8f, 0xda, 0x12a, 0x196, 0x229, 0x2c8, - 0x29c, 0x1fb, 0x16e, 0x10d, 0xb5, 0x6e, 0x37, 0x11, 0x7, 0x1a, 0x46, 0x7b, 0xc3, 0x118, 0x187, 0x210, 0x2b7, - 0x2bc, 0x1f5, 0x16b, 0x106, 0xb1, 0x61, 0x2e, 0x4, 0x0, 0xe, 0x3a, 0x71, 0xba, 0x113, 0x17f, 0x206, 0x2a4, - 0x33a, 0x1f3, 0x165, 0xfd, 0xab, 0x62, 0x2d, 0x2, 0x3, 0x8, 0x35, 0x6e, 0xb6, 0x10f, 0x179, 0x202, 0x29f, - 0x2f0, 0x1e6, 0x165, 0x103, 0xac, 0x63, 0x30, 0x7, 0x1, 0xb, 0x36, 0x70, 0xb8, 0x112, 0x176, 0x208, 0x2a4, - 0x2d2, 0x1f4, 0x171, 0x106, 0xb6, 0x70, 0x38, 0x15, 0xa, 0x18, 0x40, 0x78, 0xbf, 0x11c, 0x181, 0x20c, 0x2ac, - 0x2d0, 0x202, 0x17e, 0x118, 0xc0, 0x7c, 0x4a, 0x2e, 0x1d, 0x2e, 0x4f, 0x87, 0xcd, 0x122, 0x190, 0x21a, 0x2bb, - 0x2be, 0x216, 0x194, 0x12d, 0xd9, 0x99, 0x64, 0x49, 0x3d, 0x48, 0x68, 0x9d, 0xdd, 0x13f, 0x1a3, 0x229, 0x2cf, - 0x2e4, 0x236, 0x1bb, 0x144, 0xf0, 0xb5, 0x81, 0x63, 0x62, 0x66, 0x86, 0xb7, 0xfb, 0x14e, 0x1be, 0x249, 0x2ed, - 0x30c, 0x26c, 0x1ce, 0x164, 0x110, 0xd4, 0xa4, 0x86, 0x7f, 0x86, 0xa6, 0xd7, 0x115, 0x171, 0x1da, 0x270, 0x31c, - 0x339, 0x28d, 0x1fb, 0x18d, 0x133, 0xf6, 0xc5, 0xaa, 0xa1, 0xae, 0xca, 0xf8, 0x138, 0x195, 0x210, 0x2a1, 0x355, - 0x37f, 0x2be, 0x229, 0x1b1, 0x159, 0x118, 0xeb, 0xd3, 0xc6, 0xd4, 0xed, 0x11f, 0x15d, 0x1cd, 0x23d, 0x2cc, 0x388, - }, - - // Grgain: - { - 0x324, 0x279, 0x1f5, 0x191, 0x148, 0x113, 0xe4, 0xcd, 0xc9, 0xd4, 0xf2, 0x11f, 0x164, 0x1b6, 0x22c, 0x2ba, 0x392, - 0x2f1, 0x250, 0x1cb, 0x16c, 0x11f, 0xe9, 0xc2, 0xa8, 0xa5, 0xb1, 0xcf, 0xfa, 0x13d, 0x193, 0x208, 0x28d, 0x349, - 0x2b8, 0x225, 0x1a9, 0x148, 0xfa, 0xc5, 0x9c, 0x80, 0x7e, 0x8e, 0xa5, 0xe3, 0x11b, 0x16e, 0x1e6, 0x266, 0x316, - 0x28b, 0x201, 0x18e, 0x12a, 0xe4, 0xa5, 0x79, 0x60, 0x59, 0x6a, 0x85, 0xbf, 0xfe, 0x151, 0x1b7, 0x243, 0x2e3, - 0x26b, 0x1e5, 0x174, 0x111, 0xc4, 0x88, 0x5d, 0x40, 0x39, 0x4a, 0x69, 0xa2, 0xea, 0x137, 0x19e, 0x223, 0x2b8, - 0x253, 0x1cd, 0x159, 0xfc, 0xb2, 0x73, 0x43, 0x26, 0x1e, 0x30, 0x57, 0x90, 0xd8, 0x124, 0x188, 0x211, 0x2a4, - 0x247, 0x1bd, 0x14c, 0xf2, 0xa4, 0x65, 0x31, 0x10, 0x6, 0x1a, 0x49, 0x7c, 0xc3, 0x116, 0x17a, 0x201, 0x292, - 0x263, 0x1b6, 0x141, 0xec, 0xa1, 0x5a, 0x26, 0x3, 0x1, 0xf, 0x3f, 0x74, 0xb9, 0x111, 0x172, 0x1f3, 0x285, - 0x2dc, 0x1b4, 0x13e, 0xe6, 0x98, 0x56, 0x25, 0x1, 0x5, 0xb, 0x38, 0x71, 0xb8, 0x10e, 0x16f, 0x1ed, 0x281, - 0x291, 0x1af, 0x142, 0xe5, 0x9d, 0x5a, 0x2b, 0x7, 0x2, 0xe, 0x3c, 0x74, 0xbb, 0x10f, 0x170, 0x1f0, 0x27f, - 0x28d, 0x1b7, 0x14b, 0xee, 0xa5, 0x64, 0x35, 0x13, 0xa, 0x1c, 0x42, 0x7d, 0xbe, 0x116, 0x17b, 0x1f8, 0x28c, - 0x27e, 0x1c3, 0x156, 0xfc, 0xb1, 0x76, 0x46, 0x2e, 0x1f, 0x2f, 0x55, 0x8c, 0xd1, 0x127, 0x185, 0x207, 0x2a5, - 0x265, 0x1d8, 0x169, 0x111, 0xc5, 0x8a, 0x5c, 0x49, 0x3f, 0x4c, 0x6e, 0xa0, 0xe2, 0x13b, 0x199, 0x215, 0x2ac, - 0x282, 0x1f2, 0x188, 0x125, 0xde, 0xa5, 0x79, 0x5e, 0x63, 0x67, 0x89, 0xb8, 0xf8, 0x14c, 0x1ae, 0x231, 0x2cb, - 0x2a6, 0x221, 0x19c, 0x141, 0xfb, 0xc2, 0x9a, 0x82, 0x7d, 0x88, 0xa6, 0xd6, 0x114, 0x168, 0x1cd, 0x257, 0x2f4, - 0x2cd, 0x240, 0x1c2, 0x166, 0x11e, 0xe7, 0xbc, 0xa8, 0xa0, 0xac, 0xca, 0xf7, 0x138, 0x18a, 0x1f8, 0x27d, 0x31d, - 0x317, 0x268, 0x1ef, 0x189, 0x13b, 0x106, 0xde, 0xc9, 0xc3, 0xd3, 0xed, 0x119, 0x15a, 0x1c1, 0x221, 0x2a9, 0x357, - }, - - // Gbgain: - { - 0x32b, 0x277, 0x1f2, 0x18f, 0x148, 0x116, 0xe3, 0xc9, 0xc9, 0xd5, 0xf1, 0x11c, 0x15a, 0x1b4, 0x22d, 0x2bd, 0x38d, - 0x2f4, 0x24d, 0x1ca, 0x16d, 0x11b, 0xea, 0xc4, 0xa8, 0xa3, 0xb3, 0xc9, 0xfb, 0x13d, 0x190, 0x204, 0x28e, 0x348, - 0x2b8, 0x221, 0x1a8, 0x149, 0xfe, 0xc5, 0x9b, 0x80, 0x7a, 0x8e, 0xa6, 0xe2, 0x119, 0x16f, 0x1e4, 0x269, 0x315, - 0x28e, 0x201, 0x18a, 0x12d, 0xe3, 0xa2, 0x78, 0x60, 0x58, 0x6c, 0x86, 0xc0, 0xfc, 0x14e, 0x1b9, 0x242, 0x2e7, - 0x270, 0x1e1, 0x178, 0x115, 0xc5, 0x8a, 0x5e, 0x41, 0x3a, 0x4b, 0x6a, 0xa2, 0xe7, 0x136, 0x19e, 0x225, 0x2bd, - 0x258, 0x1ce, 0x15c, 0xff, 0xb1, 0x75, 0x44, 0x26, 0x1e, 0x30, 0x57, 0x8d, 0xd7, 0x125, 0x18c, 0x212, 0x2a7, - 0x241, 0x1bd, 0x14f, 0xf2, 0xa5, 0x65, 0x30, 0x11, 0x7, 0x1b, 0x48, 0x7d, 0xc3, 0x118, 0x17b, 0x1ff, 0x297, - 0x26b, 0x1ba, 0x147, 0xef, 0xa1, 0x5b, 0x28, 0x4, 0x1, 0x10, 0x3e, 0x75, 0xba, 0x112, 0x171, 0x1f4, 0x28b, - 0x2de, 0x1b6, 0x140, 0xe5, 0x98, 0x5a, 0x27, 0x1, 0x5, 0xb, 0x37, 0x71, 0xb8, 0x10f, 0x171, 0x1f2, 0x27f, - 0x293, 0x1b0, 0x144, 0xe6, 0x9c, 0x5a, 0x2c, 0x7, 0x4, 0xe, 0x39, 0x74, 0xbc, 0x10f, 0x16e, 0x1f4, 0x282, - 0x285, 0x1ba, 0x14b, 0xef, 0xa5, 0x66, 0x36, 0x15, 0xb, 0x1d, 0x46, 0x7c, 0xc1, 0x117, 0x17c, 0x1f8, 0x293, - 0x27c, 0x1c5, 0x159, 0xfd, 0xb1, 0x79, 0x47, 0x2e, 0x1f, 0x33, 0x56, 0x8e, 0xce, 0x129, 0x187, 0x206, 0x295, - 0x266, 0x1db, 0x16d, 0x111, 0xc6, 0x8d, 0x5f, 0x49, 0x3f, 0x4a, 0x6f, 0xa3, 0xe1, 0x13a, 0x19c, 0x219, 0x2ac, - 0x280, 0x1f4, 0x18a, 0x126, 0xde, 0xa5, 0x7e, 0x61, 0x61, 0x67, 0x87, 0xbd, 0xf6, 0x14e, 0x1ae, 0x232, 0x2cb, - 0x2ae, 0x21f, 0x1a0, 0x141, 0xf8, 0xc4, 0x99, 0x84, 0x7f, 0x89, 0xa6, 0xd4, 0x115, 0x169, 0x1d1, 0x255, 0x2f2, - 0x2d4, 0x243, 0x1c6, 0x165, 0x11a, 0xe6, 0xc0, 0xa8, 0xa0, 0xaa, 0xca, 0xfc, 0x137, 0x18a, 0x1f9, 0x282, 0x324, - 0x310, 0x26a, 0x1f0, 0x18a, 0x13d, 0x108, 0xde, 0xca, 0xc3, 0xcf, 0xf0, 0x11d, 0x15b, 0x1c1, 0x227, 0x2aa, 0x360, - }, - - // Bgain: - { - 0x2f0, 0x24a, 0x1d2, 0x175, 0x137, 0x105, 0xd7, 0xbd, 0xc0, 0xca, 0xec, 0x10f, 0x14b, 0x1a7, 0x21b, 0x29c, 0x35e, - 0x2b8, 0x228, 0x1ad, 0x155, 0x114, 0xe1, 0xbe, 0xa0, 0x9d, 0xad, 0xc1, 0xf3, 0x138, 0x183, 0x1f5, 0x278, 0x325, - 0x28f, 0x1fe, 0x18b, 0x138, 0xf1, 0xbc, 0x96, 0x7e, 0x78, 0x8a, 0xa2, 0xda, 0x114, 0x162, 0x1d6, 0x253, 0x2f5, - 0x25e, 0x1df, 0x171, 0x11b, 0xd7, 0x9f, 0x76, 0x5d, 0x5b, 0x69, 0x84, 0xbd, 0xf9, 0x14a, 0x1ae, 0x232, 0x2c8, - 0x249, 0x1c4, 0x15d, 0x105, 0xba, 0x83, 0x5a, 0x3c, 0x37, 0x4c, 0x67, 0x9f, 0xe7, 0x12f, 0x195, 0x214, 0x2a1, - 0x234, 0x1af, 0x141, 0xf0, 0xa8, 0x71, 0x3e, 0x23, 0x1d, 0x30, 0x58, 0x91, 0xd3, 0x122, 0x180, 0x202, 0x287, - 0x21e, 0x19d, 0x138, 0xe3, 0x9d, 0x61, 0x2e, 0xf, 0x6, 0x1a, 0x47, 0x7c, 0xbf, 0x119, 0x171, 0x1f5, 0x279, - 0x244, 0x19f, 0x133, 0xdd, 0x97, 0x56, 0x28, 0x4, 0x1, 0x11, 0x3d, 0x77, 0xbc, 0x10f, 0x16f, 0x1e9, 0x276, - 0x2a9, 0x19e, 0x12e, 0xda, 0x92, 0x54, 0x24, 0x4, 0x7, 0xd, 0x3c, 0x75, 0xb4, 0x10b, 0x168, 0x1e9, 0x271, - 0x267, 0x192, 0x128, 0xd9, 0x96, 0x56, 0x2a, 0x6, 0x7, 0x10, 0x3d, 0x74, 0xb6, 0x10c, 0x168, 0x1e4, 0x271, - 0x263, 0x19a, 0x134, 0xdd, 0x9d, 0x65, 0x37, 0x16, 0xe, 0x1f, 0x46, 0x79, 0xbd, 0x112, 0x170, 0x1ef, 0x286, - 0x254, 0x1a5, 0x143, 0xf0, 0xa7, 0x70, 0x46, 0x2e, 0x21, 0x33, 0x55, 0x90, 0xcb, 0x11d, 0x17d, 0x1f9, 0x287, - 0x236, 0x1bd, 0x153, 0x100, 0xba, 0x84, 0x57, 0x45, 0x42, 0x50, 0x6d, 0xa2, 0xde, 0x137, 0x194, 0x20a, 0x297, - 0x25b, 0x1db, 0x175, 0x115, 0xd2, 0x9b, 0x76, 0x5b, 0x5f, 0x69, 0x8a, 0xba, 0xf4, 0x149, 0x1a4, 0x226, 0x2bb, - 0x27d, 0x1fb, 0x186, 0x132, 0xef, 0xbc, 0x97, 0x81, 0x7d, 0x86, 0xa4, 0xd5, 0x112, 0x15e, 0x1bc, 0x242, 0x2da, - 0x2a9, 0x21f, 0x1aa, 0x151, 0x10e, 0xdc, 0xb7, 0xa3, 0x99, 0xaa, 0xc6, 0xee, 0x130, 0x183, 0x1f3, 0x264, 0x304, - 0x2d0, 0x245, 0x1da, 0x175, 0x12c, 0xf9, 0xdb, 0xc3, 0xbb, 0xc8, 0xe7, 0x114, 0x14d, 0x1b2, 0x218, 0x29b, 0x338, - }, - }, - }, -}; - - -#ifdef __cplusplus -#if __cplusplus -} -#endif -#endif /* End of #ifdef __cplusplus */ - - -#endif /* __SC3336_MIPI_CMOS_EX_H_ */ +/****************************************************************************** + + Copyright (C), 2016, Hisilicon Tech. Co., Ltd. + + ****************************************************************************** + File Name : sc3336_cmos_ex.h + Version : Initial Draft + Author : Hisilicon multimedia software group + Created : 2018/07/23 + Description : this file was private for sc3336 master mode sensor + History : + 1.Date : + Author : + Modification: Created file +******************************************************************************/ +#ifndef __SC3336_MIPI_CMOS_EX_H_ +#define __SC3336_MIPI_CMOS_EX_H_ + +#ifdef __cplusplus +#if __cplusplus +extern "C" { +#endif +#endif + +static const ISP_CMOS_LCAC_S g_stIspLCac = { + + /*bEnable*/ + 1, + /*u16PurpleDetRange*/ + 30, + /*VarThr*/ + 0, + /*enOpMode*/ + 0, + /*stManual*/ + { + //u8DePurpleCrStr + 0, + //u8DePurpleCbStr + 3 + }, + /*stAuto*/ + { + //u8DePurpleCrStr + {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, + //u8DePurpleCbStr + {3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3} + } +}; + + +static const ISP_CMOS_LCAC_S g_stIspLCacWdr = { + + /*bEnable*/ + 1, + /*u16PurpleDetRange*/ + 30, + /*VarThr*/ + 130, + /*enOpMode*/ + 0, + /*stManual*/ + { + //u8DePurpleCrStr + 0, + //u8DePurpleCbStr + 3 + }, + /*stAuto*/ + { + //u8DePurpleCrStr + {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}, + //u8DePurpleCbStr + {3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3} + } +}; + + +static const ISP_CMOS_DPC_S g_stCmosDpc = { + /* ISO */ + /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200, 1638400, 3276800 */ + { 130, 150, 150, 200, 230, 240, 240, 240, 240, 240, 152, 152, 152, 152, 152, 152}, /* au16Strength[16] */ + { 24, 24, 32, 32, 32, 32, 36, 36, 36, 40, 50, 50, 50, 50, 50, 50}, /* au16BlendRatio[16] */ + 0, /* 0 for after drc, 1 for before wdr */ +}; + +static const ISP_CMOS_GE_S g_stIspGe = { + /* For GE */ + 1, /* bEnable */ + 13, /* u8Slope */ + 13, /* u8SensiSlope */ + 4800, /* u16SensiThr */ + /* ISO */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 4800, 4800, 4800, 4800, 4960, 4960, 4960, 4960, 5120, 5120, 5120, 5120, 5280, 5280, 5280, 5280}, /* au16Threshold[ISP_AUTO_ISO_STRENGTH_NUM] */ + { 128, 128, 128, 128, 129, 129, 129, 129, 130, 130, 130, 130, 131, 131, 131, 131}, /* au16Strength[ISP_AUTO_ISO_STRENGTH_NUM] */ + {16384, 16384, 16384, 16384, 16384, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768} /* au16NpOffset[ISP_AUTO_ISO_STRENGTH_NUM] */ +}; + +static const ISP_CMOS_GE_S g_stIspWdrGe = { + /* For GE */ + 1, /* bEnable */ + 13, /* u8Slope */ + 13, /* u8SensiSlope */ + 4800, /* u16SensiThr */ + + /* ISO */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192,16384, 32768 */ + { 4800, 4800, 4800, 4800, 4960, 4960, 4960, 4960, 5120, 5120, 5120, 5120, 5280, 5280, 5280, 5280}, /* au16Threshold[ISP_AUTO_ISO_STRENGTH_NUM] */ + { 128, 128, 128, 128, 129, 129, 129, 129, 130, 130, 130, 130, 131, 131, 131, 131}, /* au16Strength[ISP_AUTO_ISO_STRENGTH_NUM] */ + {16384, 16384, 16384, 16384, 16384, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768, 32768} /* au16NpOffset[ISP_AUTO_ISO_STRENGTH_NUM] */ +}; + +static const ISP_CMOS_DEMOSAIC_S g_stIspDemosaic = { + 1, // bEnable + /* au8NonDirStr */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64, 64}, + /* au8NonDirLFDetailEhc */ + { 32, 32, 32, 36, 36, 36, 32, 22, 20, 18, 18, 18, 18, 18, 18, 18}, + /* au8NonDirHFDetailEhc */ + { 3, 3, 4, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7}, + /* au8DetailSmoothRange */ + { 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 7, 7, 7, 7, 7, 7}, +}; + +static const ISP_CMOS_DEMOSAIC_S g_stIspDemosaicWdr = { + 1, // bEnable + /* au8NonDirStr */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 64, 64, 64, 48, 48, 48, 32, 32, 32, 32, 16, 16, 16, 16, 16, 16}, + /* au8NonDirLFDetailEhc */ + { 40, 40, 40, 40, 32, 24, 18, 16, 16, 16, 16, 16, 16, 16, 16, 16}, + /* au8NonDirHFDetailEhc */ + { 3, 3, 3, 3, 3, 3, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5}, + /* au8DetailSmoothRange */ + { 4, 4, 4, 4, 4, 4, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7}, +}; + +static const ISP_CMOS_ANTIFALSECOLOR_S g_stIspAntiFalseColor = { + 1, /* bEnable */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 10, 10, 10, 12, 15, 16, 16, 15, 8, 6, 5, 4, 3, 2, 1, 0}, /* au8AntiFalseColorThreshold */ + { 8, 8, 10, 12, 15, 16, 16, 15, 8, 6, 5, 4, 3, 2, 1, 0}, /* au8AntiFalseColorStrength */ +}; + +static const ISP_CMOS_ANTIFALSECOLOR_S g_stIspWdrAntiFalseColor = { + 1, /* bEnable */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 2, 1, 0}, /* au8AntiFalseColorThreshold */ + { 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 2, 1, 0}, /* au8AntiFalseColorStrength */ +}; + +/***BAYER NR**/ +static ISP_CMOS_NOISE_CALIBRATION_S g_stIspNoiseCalibratio = { + 10, // Calibration Lut Num + /*************Calibration LUT Table*************/ + { + {100.000000f, 0.025472f, 0.008370f}, + {200.000000f, 0.051026f, 0.020051f}, + {400.000000f, 0.100380f, 0.002657f}, + {800.000000f, 0.199705f, 0.024892f}, + {1600.000000f, 0.397814f, 0.118102f}, + {3200.000000f, 0.792300f, 0.443096f}, + {6400.000000f, 1.554968f, 2.329596f}, + {12800.000000f, 3.029946f, 11.217048f}, + {25600.000000f, 5.870243f, 45.309135f}, + {51200.000000f, 10.794330f, 187.701797f} + } + /*********************************************/ +}; + +static const ISP_CMOS_BAYERNR_S g_stIspBayerNr = { + 1, // bEnable + 0, // bBnrMonoSensorEn + 0, // bNrLscEnable + 96, // u8BnrLscMaxGain + 256, // u16BnrLscCmpStrength + {80, 80, 90, 90, 90, 90, 80, 70, 60, 50, 50, 50, 50, 50, 40, 40}, // FineStr + { + {1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3}, // ChromaStrR + {0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2}, // ChromaStrGr + {0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2}, // ChromaStrGb + {1, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3} // ChromaStrB + }, + {0, 0, 0, 0}, // WDRFrameStr + {0, 0, 0, 0}, // FusionFrameStr + { + {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrR + {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrGR + {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170}, // CoarseStrGB + {90, 100, 100, 110, 110, 120, 130, 150, 160, 170, 170, 170, 170, 170, 170, 170} // CoarseStrB + }, + {40, 40, 35, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30}, // lutCoringWeight + { + 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, 90, \ + 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 100, 100, 100, 100, 100, 100, 100 + }, // CoringRatio +}; + +static const ISP_CMOS_LDCI_S g_stIspLdci = { + /* bEnable */ + 1, + /* u8GaussLPFSigma */ + 36, + + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + /* au8HePosWgt */ + { 50, 50, 50, 50, 48, 30, 30, 20, 10, 0, 0, 0, 0, 0, 0, 0}, + + /* au8HePosSigma */ + { 80, 72, 64, 48, 40, 24, 24, 20, 12, 8, 6, 2, 1, 1, 1, 1}, + + /* au8HePosMean */ + { 60, 50, 40, 40, 30, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20}, + + /* au8HeNegWgt */ + { 50, 45, 45, 45, 45, 40, 40, 30, 20, 10, 0, 0, 0, 0, 0, 0}, + + /* au8HeNegSigma */ + { 80, 80, 80, 80, 80, 72, 64, 54, 36, 8, 6, 2, 1, 1, 1, 1}, + + /* au8HeNegMean */ + {128, 128, 50, 60, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70, 70}, + + /* au16BlcCtrl */ + { 20, 20, 20, 20, 20, 20, 30, 30, 30, 30, 30, 30, 30, 30, 30, 30} +}; + +static const ISP_CMOS_GAMMA_S g_stIspGamma = { + /* au16Gamma[GAMMA_EXT_NODE_NUMBER] */ + { + 0, 19, 38, 58, 77, 97, 117, 137, 156, 176, 195, 215, 234, 253, 272, 290, 308, 326, 344, 364, 383, 401, 419, 436, 453, 470, 487, 504, 521, 539, 557, 576, + 596, 617, 627, 637, 648, 658, 669, 679, 690, 701, 712, 723, 734, 745, 757, 768, 779, 791, 803, 815, 827, 839, 851, 863, 876, 888, 901, 914, 927, 940, + 953, 967, 981, 987, 994, 1001, 1008, 1015, 1022, 1029, 1036, 1043, 1051, 1058, 1066, 1073, 1081, 1088, 1096, 1104, 1111, 1119, 1127, 1135, 1143, + 1150, 1158, 1166, 1174, 1182, 1190, 1198, 1206, 1214, 1222, 1230, 1238, 1246, 1254, 1262, 1270, 1278, 1286, 1294, 1302, 1310, 1318, 1326, 1334, + 1341, 1349, 1357, 1365, 1372, 1380, 1387, 1395, 1402, 1409, 1417, 1424, 1431, 1438, 1445, 1452, 1459, 1466, 1472, 1479, 1485, 1492, 1499, 1505, + 1511, 1518, 1524, 1531, 1537, 1543, 1549, 1556, 1562, 1568, 1574, 1580, 1586, 1592, 1598, 1604, 1610, 1616, 1622, 1628, 1634, 1639, 1645, 1651, + 1657, 1663, 1668, 1674, 1680, 1685, 1691, 1697, 1702, 1708, 1713, 1719, 1724, 1730, 1736, 1741, 1747, 1752, 1758, 1763, 1769, 1774, 1780, 1785, + 1790, 1796, 1801, 1807, 1812, 1818, 1823, 1829, 1834, 1840, 1845, 1850, 1856, 1861, 1867, 1872, 1877, 1883, 1888, 1893, 1899, 1904, 1909, 1915, + 1920, 1925, 1930, 1936, 1941, 1946, 1951, 1957, 1962, 1967, 1972, 1977, 1982, 1988, 1993, 1998, 2003, 2008, 2013, 2018, 2023, 2028, 2033, 2038, + 2043, 2048, 2053, 2058, 2063, 2068, 2073, 2078, 2082, 2087, 2092, 2097, 2102, 2107, 2111, 2116, 2121, 2126, 2131, 2135, 2140, 2145, 2149, 2154, + 2159, 2164, 2168, 2173, 2177, 2182, 2187, 2191, 2196, 2200, 2205, 2210, 2214, 2219, 2223, 2228, 2232, 2237, 2241, 2246, 2250, 2254, 2259, 2263, + 2268, 2272, 2276, 2281, 2285, 2289, 2294, 2298, 2302, 2307, 2311, 2315, 2319, 2324, 2328, 2332, 2336, 2340, 2344, 2349, 2353, 2357, 2361, 2365, + 2369, 2373, 2377, 2381, 2385, 2389, 2393, 2397, 2401, 2405, 2409, 2413, 2416, 2420, 2424, 2428, 2432, 2436, 2439, 2443, 2447, 2450, 2454, 2458, + 2461, 2465, 2468, 2472, 2475, 2479, 2482, 2486, 2489, 2493, 2496, 2500, 2503, 2506, 2510, 2513, 2516, 2520, 2523, 2526, 2529, 2533, 2536, 2539, + 2542, 2546, 2549, 2552, 2555, 2558, 2561, 2565, 2568, 2571, 2574, 2577, 2580, 2583, 2586, 2590, 2593, 2596, 2599, 2602, 2605, 2608, 2611, 2614, + 2617, 2621, 2624, 2627, 2630, 2633, 2636, 2639, 2642, 2646, 2649, 2652, 2656, 2659, 2662, 2665, 2668, 2671, 2674, 2677, 2680, 2683, 2686, 2690, + 2693, 2696, 2699, 2702, 2705, 2708, 2711, 2714, 2717, 2720, 2723, 2726, 2729, 2732, 2735, 2738, 2741, 2744, 2747, 2750, 2753, 2756, 2759, 2762, + 2764, 2767, 2770, 2773, 2776, 2779, 2782, 2785, 2788, 2791, 2794, 2796, 2799, 2802, 2805, 2808, 2811, 2814, 2817, 2820, 2822, 2825, 2828, 2831, + 2834, 2837, 2840, 2843, 2845, 2848, 2851, 2853, 2856, 2859, 2862, 2865, 2868, 2871, 2874, 2877, 2879, 2882, 2885, 2887, 2890, 2893, 2896, 2899, + 2901, 2904, 2907, 2909, 2912, 2915, 2918, 2920, 2923, 2926, 2929, 2932, 2934, 2937, 2940, 2942, 2945, 2948, 2951, 2954, 2956, 2959, 2962, 2964, + 2966, 2969, 2972, 2974, 2977, 2980, 2983, 2986, 2988, 2991, 2994, 2996, 2998, 3001, 3004, 3006, 3009, 3012, 3015, 3018, 3020, 3023, 3026, 3028, + 3031, 3033, 3035, 3038, 3040, 3043, 3046, 3048, 3051, 3054, 3057, 3059, 3062, 3064, 3066, 3069, 3071, 3074, 3077, 3080, 3082, 3085, 3088, 3090, + 3093, 3095, 3097, 3100, 3102, 3105, 3108, 3110, 3113, 3115, 3117, 3120, 3122, 3125, 3128, 3130, 3133, 3135, 3138, 3140, 3143, 3145, 3147, 3150, + 3152, 3155, 3158, 3160, 3163, 3165, 3167, 3170, 3172, 3175, 3178, 3180, 3183, 3185, 3187, 3189, 3192, 3194, 3196, 3199, 3201, 3204, 3207, 3209, + 3211, 3214, 3217, 3219, 3222, 3224, 3226, 3228, 3231, 3233, 3235, 3238, 3241, 3243, 3245, 3247, 3250, 3252, 3254, 3257, 3260, 3262, 3264, 3267, + 3269, 3271, 3273, 3276, 3279, 3281, 3283, 3286, 3288, 3290, 3292, 3295, 3298, 3300, 3302, 3305, 3307, 3309, 3311, 3313, 3316, 3318, 3320, 3322, + 3325, 3327, 3329, 3332, 3335, 3337, 3339, 3342, 3344, 3346, 3348, 3350, 3353, 3355, 3357, 3360, 3362, 3364, 3366, 3368, 3371, 3373, 3375, 3378, + 3380, 3382, 3384, 3386, 3389, 3391, 3393, 3396, 3398, 3400, 3402, 3405, 3407, 3409, 3411, 3413, 3416, 3418, 3420, 3423, 3425, 3427, 3429, 3431, + 3434, 3436, 3438, 3441, 3443, 3445, 3447, 3449, 3452, 3454, 3456, 3459, 3461, 3463, 3465, 3467, 3469, 3471, 3473, 3475, 3478, 3480, 3482, 3484, + 3487, 3489, 3491, 3494, 3496, 3498, 3500, 3502, 3504, 3506, 3508, 3511, 3513, 3515, 3517, 3519, 3521, 3523, 3525, 3528, 3530, 3532, 3534, 3536, + 3538, 3540, 3542, 3545, 3547, 3549, 3551, 3553, 3555, 3557, 3559, 3561, 3564, 3566, 3568, 3570, 3572, 3574, 3576, 3578, 3581, 3583, 3585, 3587, + 3589, 3591, 3593, 3595, 3598, 3600, 3602, 3604, 3606, 3608, 3610, 3612, 3614, 3616, 3618, 3620, 3622, 3624, 3626, 3628, 3631, 3633, 3635, 3637, + 3639, 3641, 3643, 3645, 3647, 3649, 3651, 3653, 3655, 3657, 3659, 3661, 3663, 3665, 3667, 3670, 3672, 3674, 3676, 3678, 3680, 3682, 3684, 3686, + 3688, 3690, 3692, 3694, 3696, 3698, 3700, 3702, 3704, 3706, 3708, 3710, 3712, 3714, 3716, 3718, 3720, 3722, 3724, 3726, 3728, 3730, 3732, 3734, + 3736, 3738, 3740, 3742, 3744, 3746, 3748, 3750, 3752, 3754, 3756, 3758, 3760, 3762, 3764, 3766, 3767, 3769, 3771, 3773, 3775, 3777, 3779, 3781, + 3783, 3785, 3787, 3789, 3791, 3793, 3795, 3797, 3799, 3801, 3803, 3804, 3806, 3808, 3810, 3812, 3814, 3816, 3818, 3820, 3822, 3824, 3826, 3828, + 3830, 3832, 3834, 3836, 3837, 3839, 3841, 3843, 3845, 3847, 3849, 3851, 3853, 3855, 3857, 3858, 3860, 3862, 3864, 3866, 3868, 3870, 3872, 3873, + 3875, 3877, 3879, 3881, 3883, 3885, 3887, 3888, 3890, 3892, 3894, 3896, 3898, 3900, 3902, 3904, 3905, 3907, 3909, 3911, 3913, 3915, 3917, 3919, + 3920, 3922, 3924, 3926, 3928, 3930, 3932, 3934, 3935, 3937, 3939, 3941, 3943, 3945, 3947, 3949, 3950, 3952, 3954, 3955, 3957, 3959, 3961, 3963, + 3965, 3967, 3969, 3971, 3972, 3974, 3976, 3977, 3979, 3981, 3983, 3985, 3987, 3989, 3991, 3993, 3994, 3996, 3998, 4000, 4001, 4003, 4005, 4006, + 4008, 4010, 4012, 4014, 4016, 4018, 4020, 4022, 4023, 4025, 4027, 4028, 4030, 4032, 4034, 4036, 4037, 4039, 4041, 4042, 4044, 4046, 4048, 4050, + 4052, 4054, 4056, 4058, 4059, 4061, 4063, 4064, 4066, 4068, 4070, 4072, 4073, 4075, 4077, 4078, 4080, 4082, 4084, 4086, 4087, 4089, 4091, 4092, + 4094, 4095 + } +}; + +static const ISP_CMOS_PREGAMMA_S g_stPreGamma = { + 0, + { + 3821, 7131, 9741, 11691, 13307, 14713, 15971, 17118, 18179, 20099, 21818, 23385, 24833, 26185, 27456, 28659, + 29804, 30897, 31945, 32952, 33923, 35770, 37506, 39150, 40713, 42207, 43638, 45014, 46340, 47622, 48863, 50066, + 51235, 52373, 53481, 54561, 55616, 57656, 59611, 61491, 63303, 65054, 66749, 68393, 69990, 71543, 73057, 74533, + 75974, 77383, 78761, 80110, 81432, 83999, 86475, 88866, 91182, 93428, 95609, 97731, 99799, 101815, 103784, 105708, + 107590, 109433, 111239, 113010, 114747, 118128, 121395, 124558, 127626, 130606, 133505, 136330, 139084, 141773, 144402, 146973, + 149491, 151957, 154376, 156749, 159079, 161368, 163618, 165831, 168008, 170152, 172263, 174342, 176392, 178413, 180407, 182374, + 184315, 186232, 188125, 189995, 191842, 193668, 197259, 200771, 204210, 207580, 210884, 214126, 217308, 220435, 223509, 226532, + 229506, 232434, 235318, 238159, 240959, 243720, 246443, 249130, 251782, 254400, 256986, 259540, 262064, 264559, 267025, 269464, + 271876, 274262, 276623, 278960, 281273, 283562, 288076, 292504, 296852, 301124, 305323, 309452, 313515, 317515, 321454, 325335, + 329160, 332931, 336651, 340322, 343945, 347521, 351054, 354543, 357991, 361399, 364767, 368099, 371394, 374653, 377878, 381070, + 384230, 387358, 390456, 393523, 396562, 399573, 405512, 411348, 417083, 422724, 428274, 433738, 439119, 444420, 449646, 454798, + 459880, 464894, 469842, 474728, 479554, 484320, 489030, 493685, 498287, 502838, 507339, 511791, 516197, 520557, 524874, 529147, + 533378, 537569, 541720, 545833, 549908, 553946, 557949, 561917, 565852, 569753, 577458, 585040, 592504, 599854, 607096, 614234, + 621272, 628214, 635064, 641824, 648498, 655090, 661601, 668035, 674394, 680681, 686897, 693045, 699128, 705146, 711103, 716999, + 722836, 728616, 734341, 740012, 745630, 751197, 756713, 762181, 767602, 778305, 788831, 799189, 809384, 819425, 829318, 839069, + 848683, 858166, 867523, 876757, 885875, 894879, 903774, 912563, 921249, 938329, 955037, 971395, 987423, 1003139, 1018560, 1033701, + 1048575 + } +}; + +static const ISP_CMOS_SHARPEN_S g_stIspYuvSharpen = { + /* u8SkinUmin */ + 110, + /* u8SkinVmin */ + 128, + /* u8SkinUmax */ + 128, + /* u8SkinVmax */ + 149, + + /* Manual Para */ + { + /* au8LumaWgt */ + {31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, + /* u16TextureStr */ + {420, 420, 390, 390, 390, 390, 390, 370, 350, 330, 310, 290, 270, 270, 270, 270, 270, 270, 266, 260, 244, 230, 230, 230, 230, 230, 230, 210, 190, 190, 170, 150}, + /* u16EdgeStr */ + {120, 123, 125, 128, 130, 135, 140, 148, 160, 168, 180, 190, 200, 210, 210, 210, 210, 210, 200, 190, 185, 175, 165, 160, 146, 136, 130, 128, 125, 123, 120, 120}, + /* u16TextureFreq; */ + 160, + /* u16EdgeFreq; */ + 100, + /* u8OverShoot; */ + 55, + /* u8UnderShoot; */ + 70, + /* u8shootSupStr; */ + 10, + /* u8shootSupAdj; */ + 9, + /* u8DetailCtrl; */ + 128, + /* u8DetailCtrlThr; */ + 180, + /* u8EdgeFiltStr; */ + 60, + /*u8EdgeFiltMaxCap; */ + 18, + /*u8RGain; */ + 28, + /* u8GGain; */ + 32, + /* u8BGain; */ + 31, + /* u8SkinGain; */ + 23, + /* u8MaxSharpGain; */ + 67, + /* u8WeakDetailGain */ + 6 + }, + /* Auto Para */ + { + /* au16LumaWgt */ + /* ISO */ + /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400,3276800 */ + { { 31, 31, 20, 31, 31, 26, 31, 31, 31, 31, 31, 31, 31, 1, 1, 1}, + { 31, 31, 20, 31, 31, 26, 31, 31, 31, 31, 31, 31, 31, 2, 2, 2}, + { 31, 31, 20, 31, 31, 27, 31, 31, 31, 31, 31, 31, 31, 4, 4, 4}, + { 31, 31, 20, 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 5, 5, 5}, + { 31, 31, 20, 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 7, 7, 7}, + { 31, 31, 20, 31, 31, 29, 31, 31, 31, 31, 31, 31, 31, 8, 8, 8}, + { 31, 31, 20, 31, 31, 30, 31, 31, 31, 31, 31, 31, 31, 9, 9, 9}, + { 31, 31, 23, 31, 31, 30, 31, 31, 31, 31, 31, 31, 31, 10, 10, 10}, + { 31, 31, 25, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 12, 12, 12}, + { 31, 31, 28, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 13, 13, 13}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 14, 14, 14}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 15, 15, 15}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 17, 17, 17}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 18, 18, 18}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 19, 19, 19}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 20, 20, 20}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 22, 22, 22}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 23, 23, 23}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 24, 24, 24}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 26, 26, 26}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 27, 27, 27}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28}, + { 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 28, 28, 28} + }, + /* au16TextureStr */ + /* ISO */ + /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400,3276800 */ + { { 285, 285, 264, 264, 264, 128, 128, 128, 128, 128, 128, 128, 128, 28, 28, 28}, + { 300, 300, 276, 276, 276, 148, 148, 148, 148, 148, 148, 148, 148, 43, 43, 43}, + { 315, 315, 292, 292, 292, 177, 177, 177, 177, 177, 177, 177, 177, 59, 59, 59}, + { 328, 328, 307, 307, 307, 211, 211, 211, 211, 211, 211, 211, 211, 75, 75, 75}, + { 337, 337, 316, 316, 316, 247, 247, 247, 247, 247, 247, 247, 247, 91, 91, 91}, + { 345, 345, 324, 324, 324, 281, 281, 281, 281, 281, 281, 281, 281, 106, 106, 106}, + { 352, 352, 331, 331, 331, 310, 310, 310, 310, 310, 310, 310, 310, 121, 121, 121}, + { 357, 357, 336, 336, 336, 331, 331, 331, 331, 331, 331, 331, 331, 136, 136, 136}, + { 359, 359, 337, 337, 337, 342, 342, 342, 342, 342, 342, 342, 342, 152, 152, 152}, + { 361, 361, 338, 338, 338, 348, 348, 348, 348, 348, 348, 348, 348, 167, 167, 167}, + { 363, 363, 338, 338, 338, 351, 351, 351, 351, 351, 351, 351, 351, 183, 183, 183}, + { 364, 364, 338, 338, 338, 352, 352, 352, 352, 352, 352, 352, 352, 199, 199, 199}, + { 364, 364, 337, 337, 337, 350, 350, 350, 350, 350, 350, 350, 350, 214, 214, 214}, + { 365, 365, 336, 336, 336, 347, 347, 347, 347, 347, 347, 347, 347, 228, 228, 228}, + { 364, 364, 335, 335, 335, 344, 344, 344, 344, 344, 344, 344, 344, 241, 241, 241}, + { 363, 363, 333, 333, 333, 341, 341, 341, 341, 341, 341, 341, 341, 254, 254, 254}, + { 361, 361, 331, 331, 331, 338, 338, 338, 338, 338, 338, 338, 338, 267, 267, 267}, + { 358, 358, 328, 328, 328, 333, 333, 333, 333, 333, 333, 333, 333, 283, 283, 283}, + { 355, 355, 324, 324, 324, 327, 327, 327, 327, 327, 327, 327, 327, 298, 298, 298}, + { 351, 351, 320, 320, 320, 320, 320, 320, 320, 320, 320, 320, 320, 313, 313, 313}, + { 346, 346, 316, 316, 316, 313, 313, 313, 313, 313, 313, 313, 313, 325, 325, 325}, + { 342, 342, 312, 312, 312, 305, 305, 305, 305, 305, 305, 305, 305, 338, 338, 338}, + { 337, 337, 308, 308, 308, 296, 296, 296, 296, 296, 296, 296, 296, 348, 348, 348}, + { 333, 333, 304, 304, 304, 288, 288, 288, 288, 288, 288, 288, 288, 353, 353, 353}, + { 329, 329, 300, 300, 300, 279, 279, 279, 279, 279, 279, 279, 279, 350, 350, 350}, + { 324, 324, 295, 295, 295, 270, 270, 270, 270, 270, 270, 270, 270, 343, 343, 343}, + { 318, 318, 290, 290, 290, 260, 260, 260, 260, 260, 260, 260, 260, 330, 330, 330}, + { 313, 313, 285, 285, 285, 249, 249, 249, 249, 249, 249, 249, 249, 313, 313, 313}, + { 308, 308, 280, 280, 280, 239, 239, 239, 239, 239, 239, 239, 239, 287, 287, 287}, + { 303, 303, 276, 276, 276, 228, 228, 228, 228, 228, 228, 228, 228, 254, 254, 254}, + { 299, 299, 272, 272, 272, 217, 217, 217, 217, 217, 217, 217, 217, 219, 219, 219}, + { 296, 296, 269, 269, 269, 207, 207, 207, 207, 207, 207, 207, 207, 186, 186, 186} + }, + /* au16EdgeStr */ + /* ISO */ + /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200,1638400, 3276800 */ + { { 250, 256, 262, 279, 320, 417, 320, 320, 432, 258, 400, 224, 224, 224, 224, 224}, + { 250, 260, 270, 296, 331, 421, 337, 337, 440, 291, 412, 244, 244, 244, 244, 244}, + { 250, 264, 279, 314, 343, 425, 354, 355, 451, 325, 424, 265, 265, 265, 265, 265}, + { 250, 268, 288, 332, 356, 429, 371, 373, 466, 359, 436, 285, 285, 285, 285, 285}, + { 250, 272, 296, 350, 368, 433, 386, 390, 485, 391, 452, 303, 303, 303, 303, 303}, + { 250, 276, 305, 368, 380, 437, 398, 406, 503, 420, 470, 319, 319, 319, 319, 319}, + { 250, 280, 313, 384, 391, 441, 410, 421, 523, 448, 490, 333, 333, 333, 333, 333}, + { 250, 286, 321, 398, 401, 445, 420, 436, 544, 475, 512, 346, 346, 346, 346, 346}, + { 250, 292, 328, 411, 410, 448, 430, 451, 565, 501, 534, 357, 357, 357, 357, 357}, + { 249, 299, 334, 420, 416, 450, 438, 463, 584, 525, 556, 364, 364, 364, 364, 364}, + { 249, 307, 339, 428, 422, 452, 446, 475, 603, 548, 580, 370, 370, 370, 370, 370}, + { 249, 316, 344, 434, 427, 453, 453, 486, 622, 570, 603, 374, 374, 374, 374, 374}, + { 248, 326, 349, 439, 431, 454, 460, 498, 641, 592, 623, 379, 379, 379, 379, 379}, + { 248, 335, 353, 442, 434, 455, 466, 511, 658, 614, 639, 384, 384, 384, 384, 384}, + { 248, 344, 357, 445, 437, 456, 473, 524, 671, 637, 652, 390, 390, 390, 390, 390}, + { 247, 351, 360, 447, 439, 456, 479, 538, 673, 658, 664, 394, 394, 394, 394, 394}, + { 247, 357, 364, 449, 442, 457, 485, 550, 674, 674, 674, 398, 398, 398, 398, 398}, + { 246, 361, 367, 450, 444, 456, 489, 563, 683, 686, 683, 398, 398, 398, 398, 398}, + { 245, 364, 369, 450, 445, 455, 492, 575, 690, 691, 690, 398, 398, 398, 398, 398}, + { 244, 366, 371, 450, 446, 454, 496, 585, 695, 695, 695, 398, 398, 398, 398, 398}, + { 243, 366, 373, 448, 446, 453, 500, 590, 696, 696, 696, 398, 398, 398, 398, 398}, + { 242, 366, 375, 445, 445, 451, 504, 594, 697, 697, 697, 398, 398, 398, 398, 398}, + { 241, 366, 376, 441, 445, 450, 508, 597, 696, 696, 696, 399, 399, 399, 399, 399}, + { 241, 366, 377, 436, 444, 449, 511, 600, 697, 697, 697, 402, 402, 402, 402, 402}, + { 240, 365, 377, 429, 442, 448, 509, 601, 697, 697, 697, 405, 405, 405, 405, 405}, + { 239, 363, 377, 422, 440, 447, 506, 600, 698, 698, 698, 408, 408, 408, 408, 408}, + { 238, 361, 377, 413, 437, 446, 502, 600, 699, 699, 699, 411, 411, 411, 411, 411}, + { 238, 359, 376, 403, 434, 446, 500, 600, 700, 700, 700, 413, 413, 413, 413, 413}, + { 237, 356, 376, 393, 431, 445, 498, 600, 700, 700, 700, 411, 411, 411, 411, 411}, + { 236, 353, 375, 383, 428, 445, 498, 600, 700, 700, 700, 408, 408, 408, 408, 408}, + { 235, 351, 375, 373, 425, 444, 498, 600, 700, 700, 700, 405, 405, 405, 405, 405}, + { 235, 349, 375, 364, 423, 444, 498, 600, 700, 700, 700, 402, 402, 402, 402, 402} + }, + /* au16TextureFreq */ + /* ISO */ + /* 100, 200, 400, 800, 1600, 3200, 6400, 12800, 25600, 51200, 102400, 204800, 409600, 819200, 1638400, 3276800 */ + { 180, 180, 180, 180, 160, 160, 160, 170, 170, 170, 170, 170, 170, 170, 170, 170}, + + /* au16EdgeFreq */ + { 130, 115, 100, 100, 100, 100, 100, 100, 100, 100, 96, 96, 96, 96, 96, 96}, + + /* au8OverShoot */ + { 65, 70, 75, 70, 65, 55, 40, 40, 30, 30, 40, 40, 10, 10, 10, 10}, + + /* au8UnderShoot */ + { 85, 87, 90, 80, 80, 70, 60, 55, 45, 45, 50, 50, 15, 15, 15, 15}, + + /* au16shootSupStr */ + { 8, 8, 7, 7, 7, 6, 5, 5, 0, 0, 0, 0, 0, 0, 0, 0}, + + /* au8ShootSupAdj */ + { 9, 9, 8, 8, 7, 7, 6, 6, 0, 0, 0, 0, 0, 0, 0, 0}, + + /* au8DetailCtrl */ + { 128, 128, 128, 128, 128, 128, 128, 128, 128, 128, 120, 120, 120, 120, 120, 120}, + + /* au8DetailCtrlThr */ + { 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160, 160}, + + /* au8EdgeFiltStr */ + { 50, 50, 50, 55, 57, 60, 61, 62, 62, 62, 62, 62, 62, 62, 62, 62}, + + /* au8EdgeFiltMaxCap */ + { 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18, 18 }, + + /* au8RGain */ + { 28, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, + + /* au8GGain */ + { 31, 31, 31, 31, 16, 16, 16, 16, 31, 31, 31, 31, 31, 31, 31, 31}, + + /* au8BGain */ + { 31, 31, 31, 31, 16, 16, 16, 16, 31, 31, 31, 31, 31, 31, 31, 31}, + + /* au8SkinGain */ + { 25, 27, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31}, + + /* u8MaxSharpGain */ + { 72, 72, 72, 74, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80, 80}, + /* au8WeakDetailGain */ + { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } + + }, +}; + +static AWB_CCM_S g_stAwbCcm = { + 4, + { + { + 6150, + { + 0x0292, 0x81C6, 0x0034, + 0x806E, 0x01D1, 0x8063, + 0x8021, 0x815B, 0x027C + }, + }, + + { + 4850, + { + 0x02A5, 0x81D3, 0x002E, + 0x806D, 0x01AB, 0x803E, + 0x8023, 0x819F, 0x02C2 + }, + }, + + { + 3650, + { + 0x026E, 0x8172, 0x0004, + 0x809F, 0x01D6, 0x8037, + 0x8047, 0x81C4, 0x030B + }, + }, + + { + 2650, + { + 0x01E5, 0x80B7, 0x802E, + 0x8096, 0x01A6, 0x8010, + 0x80B9, 0x82B1, 0x046A + }, + }, + }, +}; + +static AWB_AGC_TABLE_S g_stAwbAgcTable = { + /* bvalid */ + 1, + + /* saturation */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + {115, 110, 110, 110, 108, 105, 100, 95, 90, 90, 90, 80, 80, 80, 80, 80} +}; + +static const ISP_CMOS_WDR_S g_stIspWDR = { + /* bFusionMode */ + 0, + + /* bMotionComp */ + 1, + + /* u16ShortThr */ + 4032, + + /* u16LongThr */ + 3008, + + /* bForceLong */ + 1, + + /* u16ForceLongLowThr */ + + 500, + + /* u16ForceLongHigThr */ + 700, + + /* bShortExpoChk */ + 0, + + /* u16ShortCheckThd */ + 0x8, + + /* au8MdThrLowGain[16] */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + { 64, 64, 64, 64, 128, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}, + + /* au8MdThrHigGain[16] */ + {128, 128, 128, 128, 128, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255, 255}, + + /* au16FusionThr[2] */ + {3855, 3000}, + + /* u8MdtStillThd */ + 0x14, + + /* u8MdtLongBlend */ + 0x0 +}; + +static const ISP_CMOS_DEHAZE_S g_stIspDehaze = { + /* bEnable */ + 0, + /* bUserLutEnable */ + 0, + /* enOpType */ + 0, + /* u8AutoStrength */ + 128, + /* u8ManualStrength */ + 128 +}; + +static const ISP_CMOS_DRC_S g_stIspDRC = { + /* bEnable */ + 0, + /* enOpType */ + 0, + /* u16ManualStrength */ + 512, + /* u16AutoStrength */ + 512, + /* u8SpatialFltCoef */ + 1, + /* u8RangeFltCoef */ + 2, + /* u8ContrastControl */ + 8, + /* s8DetailAdjustFactor */ + 0, + /* u8RangeAdaMax */ + 8, + /* u8FltScaleFine */ + 6, + /* u8FltScaleCoarse */ + 6, + /* u8GradRevMax */ + 64, + /* u8GradRevThr */ + 50, + /* u8BrightGainLmt */ + 12, + /* u8BrightGainLmtStep */ + 8, + /* u8DarkGainLmtY */ + 0, + /* u8DarkGainLmtC */ + 0, + /* u8PDStrength */ + 35, + /* u8LocalMixingBrightMax */ + 64, + /* u8LocalMixingBrightMin */ + 32, + /* u8LocalMixingBrightThr */ + 96, + /* s8LocalMixingBrightSlo */ + -3, + /* u8LocalMixingDarkMax */ + 64, + /* u8LocalMixingDarkMin */ + 32, + /* u8LocalMixingDarkThr */ + 200, + /* s8LocalMixingDarkSlo */ + 5, + /* ColorCorrectionLut[33] */ + {1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024}, + /*ToneMappingValue[200]*/ + {8, 8, 16, 24, 31, 39, 48, 56, 65, 75, 85, 95, 106, 118, 130, 143, 156, 170, 185, 201, 218, 235, 254, 274, 294, 316, 339, 364, 390, 417, 446, 477, 509, 543, 579, 617, 658, 701, 746, 794, 844, 898, 955, 1015, 1078, 1145, 1216, + 1291, 1370, 1454, 1543, 1637, 1736, 1841, 1952, 2069, 2194, 2325, 2465, 2612, 2767, 2932, 3106, 3290, 3485, 3691, 3909, 4140, 4384, 4641, 4914, 5202, 5507, 5830, 6171, 6531, 6913, 7316, 7742, 8193, 8669, 9173, 9705, 10268, + 10863, 11492, 12145, 12808, 13483, 14171, 14872, 15587, 16319, 17069, 17840, 18635, 19458, 19881, 20313, 20754, 21204, 21661, 22122, 22586, 23053, 23525, 24000, 24480, 24965, 25455, 25950, 26451, 26959, 27473, 27995, 28524, + 29062, 29609, 30165, 30732, 31309, 31899, 32501, 33116, 33746, 34391, 35043, 35706, 36381, 37066, 37763, 38472, 39192, 39925, 40671, 41429, 42201, 42591, 42986, 43383, 43784, 44189, 44597, 45008, 45424, 45842, 46265, 46691, + 47121, 47555, 47993, 48434, 48880, 49329, 49783, 50241, 50703, 51169, 51639, 52113, 52592, 53075, 53564, 54056, 54552, 55054, 55560, 56071, 56586, 56846, 57107, 57369, 57632, 57896, 58162, 58429, 58697, 58967, 59238, 59510, + 59783, 60057, 60333, 60611, 60889, 61169, 61451, 61733, 62017, 62303, 62589, 62877, 63167, 63458, 63750, 64044, 64340, 64636, 64934, 65234}, + /* u8Asymmetry */ + 2, + /* u8SecondPole */ + 180, + /* u8Stretch */ + 54, + /* u8Compress */ + 180, + /* u8CurveSel */ + 0, + /* au16Xpoint */ + {0, 200, 400, 600, 1000}, + /* au16Ypoint */ + {0, 200, 400, 600, 1000}, + /* au16Slope */ + {1000, 1000, 1000, 1000, 1000} +}; + +static const ISP_CMOS_DRC_S g_stIspDRCWDR = { + /* bEnable */ + 1, + /* enOpType */ + 0, + /* u16ManualStrength */ + 1023, + /* u16AutoStrength */ + 512, + /* u8SpatialFltCoef */ + 0, + /* u8RangeFltCoef */ + 1, + /* u8ContrastControl */ + 9, + /* s8DetailAdjustFactor */ + 12, + /* u8RangeAdaMax */ + 4, + /* u8FltScaleFine */ + 3, + /* u8FltScaleCoarse */ + 3, + /* u8GradRevMax */ + 30, + /* u8GradRevThr */ + 50, + /* u8BrightGainLmt */ + 12, + /* u8BrightGainLmtStep */ + 10, + /* u8DarkGainLmtY */ + 0, + /* u8DarkGainLmtC */ + 0, + /* u8PDStrength */ + 35, + /* u8LocalMixingBrightMax */ + 36, + /* u8LocalMixingBrightMin */ + 24, + /* u8LocalMixingBrightThr */ + 96, + /* s8LocalMixingBrightSlo */ + -3, + /* u8LocalMixingDarkMax */ + 36, + /* u8LocalMixingDarkMin */ + 24, + /* u8LocalMixingDarkThr */ + 200, + /* s8LocalMixingDarkSlo */ + 5, + /* ColorCorrectionLut[33] */ + {1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 1024, 772, 768, 764, 760, 756, 752, 748, 744, 740, 736, 732, 728, 724, 720, 716, 712, 708, 704, 700}, + /* ToneMappingValue[200] */ + {8, 8, 16, 24, 31, 39, 48, 56, 65, 75, 85, 95, 106, 118, 130, 143, 156, 170, 185, 201, 218, 235, 254, 274, 294, 316, 339, 364, 390, 417, 446, 477, 509, 543, 579, 617, 658, 701, 746, 794, 844, 898, 955, 1015, 1078, 1145, 1216, + 1291, 1370, 1454, 1543, 1637, 1736, 1841, 1952, 2069, 2194, 2325, 2465, 2612, 2767, 2932, 3106, 3290, 3485, 3691, 3909, 4140, 4384, 4641, 4914, 5202, 5507, 5830, 6171, 6531, 6913, 7316, 7742, 8193, 8669, 9173, 9705, 10268, + 10863, 11492, 12145, 12808, 13483, 14171, 14872, 15587, 16319, 17069, 17840, 18635, 19458, 19881, 20313, 20754, 21204, 21661, 22122, 22586, 23053, 23525, 24000, 24480, 24965, 25455, 25950, 26451, 26959, 27473, 27995, 28524, + 29062, 29609, 30165, 30732, 31309, 31899, 32501, 33116, 33746, 34391, 35043, 35706, 36381, 37066, 37763, 38472, 39192, 39925, 40671, 41429, 42201, 42591, 42986, 43383, 43784, 44189, 44597, 45008, 45424, 45842, 46265, 46691, + 47121, 47555, 47993, 48434, 48880, 49329, 49783, 50241, 50703, 51169, 51639, 52113, 52592, 53075, 53564, 54056, 54552, 55054, 55560, 56071, 56586, 56846, 57107, 57369, 57632, 57896, 58162, 58429, 58697, 58967, 59238, 59510, + 59783, 60057, 60333, 60611, 60889, 61169, 61451, 61733, 62017, 62303, 62589, 62877, 63167, 63458, 63750, 64044, 64340, 64636, 64934, 65234}, + /* u8Asymmetry */ + 6, + /* u8SecondPole */ + 180, + /* u8Stretch */ + 50, + /* u8Compress */ + 150, + /* u8CurveSel */ + 0, + /* au16Xpoint */ + {0, 200, 400, 600, 1000}, + /* au16Ypoint */ + {0, 200, 400, 600, 1000}, + /* au16Slope */ + {1000, 1000, 1000, 1000, 1000} +}; + +static const ISP_CMOS_CA_S g_stIspCA = { + /* CA */ + 1, + /* Y */ + { + 516, 525, 534, 544, 554, 563, 573, 583, 594, 604, 614, 624, 634, 644, 654, 664, + 674, 684, 694, 704, 713, 723, 732, 741, 750, 758, 766, 775, 782, 790, 797, 804, + 811, 817, 823, 828, 834, 839, 844, 848, 853, 857, 861, 865, 868, 872, 875, 878, + 881, 884, 887, 890, 892, 895, 898, 900, 903, 905, 908, 910, 913, 915, 918, 921, + 924, 926, 929, 932, 935, 937, 940, 943, 945, 948, 950, 952, 955, 957, 959, 961, + 964, 966, 968, 970, 972, 974, 976, 978, 979, 981, 983, 985, 987, 988, 990, 992, + 993, 994, 995, 996, 997, 998, 998, 999, 1000, 1001, 1002, 1002, 1003, 1004, 1005, 1006, + 1006, 1007, 1008, 1009, 1010, 1011, 1012, 1013, 1014, 1015, 1016, 1018, 1019, 1020, 1022, 1024 + }, + /* ISO */ + /* 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768 */ + {1300, 1300, 1250, 1200, 1150, 1100, 1050, 1000, 950, 900, 900, 800, 800, 800, 800, 800} +}; + + +static const ISP_CMOS_LSC_S g_stCmosLsc = { + /* MeshStrength */ + 256, + /* MeshScale */ + 4, + /* ISP_LSC_CABLI_TABLE_S */ + { + { + // Rgain: + { + 0x26b, 0x1de, 0x179, 0x12a, 0xee, 0xc4, 0xa2, 0x94, 0x94, 0x97, 0xad, 0xc8, 0x10d, 0x133, 0x184, 0x1fd, 0x284, + 0x235, 0x1ba, 0x158, 0x10d, 0xd3, 0xad, 0x8c, 0x7b, 0x74, 0x7b, 0x90, 0xaf, 0xd8, 0x114, 0x164, 0x1d1, 0x253, + 0x210, 0x194, 0x136, 0xec, 0xbc, 0x91, 0x6f, 0x5d, 0x59, 0x5f, 0x75, 0x94, 0xbf, 0xf7, 0x149, 0x1ac, 0x229, + 0x1e1, 0x177, 0x11a, 0xd7, 0xa6, 0x7c, 0x5b, 0x44, 0x3e, 0x4a, 0x5c, 0x7d, 0xab, 0xe2, 0x127, 0x18f, 0x200, + 0x1c8, 0x15f, 0x10d, 0xc9, 0x98, 0x69, 0x4a, 0x32, 0x2a, 0x33, 0x4a, 0x6b, 0x9e, 0xd0, 0x113, 0x175, 0x1e5, + 0x1b6, 0x14f, 0xf9, 0xbf, 0x84, 0x57, 0x34, 0x21, 0x18, 0x21, 0x3a, 0x5e, 0x8e, 0xc2, 0x105, 0x162, 0x1d8, + 0x1a9, 0x140, 0xef, 0xb4, 0x7d, 0x50, 0x2d, 0x11, 0xa, 0x15, 0x2f, 0x57, 0x83, 0xb9, 0xfb, 0x156, 0x1c3, + 0x1a5, 0x134, 0xe9, 0xae, 0x7a, 0x4b, 0x26, 0x8, 0x4, 0xc, 0x28, 0x4f, 0x7f, 0xb8, 0xf7, 0x151, 0x1bf, + 0x19d, 0x134, 0xe8, 0xac, 0x75, 0x48, 0x34, 0x4, 0x0, 0xa, 0x25, 0x50, 0x7e, 0xb5, 0xf8, 0x150, 0x1bd, + 0x199, 0x134, 0xea, 0xae, 0x73, 0x4b, 0x32, 0x5, 0x2, 0xd, 0x2a, 0x4e, 0x83, 0xbc, 0xf9, 0x151, 0x1c0, + 0x1a5, 0x139, 0xee, 0xb1, 0x7e, 0x51, 0x2f, 0x14, 0xd, 0x16, 0x31, 0x56, 0x86, 0xbb, 0x100, 0x158, 0x1c3, + 0x1b2, 0x147, 0xfe, 0xbd, 0x87, 0x5f, 0x3b, 0x24, 0x1b, 0x24, 0x43, 0x64, 0x90, 0xc8, 0x107, 0x164, 0x1d2, + 0x1c1, 0x159, 0x107, 0xca, 0x94, 0x6e, 0x4d, 0x36, 0x30, 0x36, 0x4e, 0x74, 0x9b, 0xd1, 0x11a, 0x173, 0x1e2, + 0x1de, 0x16f, 0x119, 0xda, 0xa7, 0x7f, 0x64, 0x4e, 0x45, 0x4f, 0x62, 0x86, 0xb1, 0xe6, 0x128, 0x188, 0x1fd, + 0x1f9, 0x18a, 0x131, 0xf2, 0xbf, 0x99, 0x79, 0x65, 0x60, 0x6a, 0x7b, 0x9e, 0xc9, 0xfb, 0x13d, 0x19f, 0x21e, + 0x21c, 0x1a9, 0x14b, 0x109, 0xd6, 0xb4, 0x96, 0x83, 0x7f, 0x83, 0x94, 0xb7, 0xe0, 0x115, 0x15d, 0x1c1, 0x23f, + 0x244, 0x1c8, 0x167, 0x127, 0xf5, 0xcc, 0xb1, 0x9f, 0x99, 0x98, 0xb3, 0xce, 0xf7, 0x12e, 0x17a, 0x1e9, 0x262, + }, + + // Grgain: + { + 0x27c, 0x1fd, 0x18b, 0x138, 0xfb, 0xd2, 0xb1, 0xa3, 0x9d, 0xa0, 0xb7, 0xd8, 0x11d, 0x141, 0x1a4, 0x21c, 0x2ab, + 0x24a, 0x1d0, 0x164, 0x113, 0xde, 0xb4, 0x96, 0x83, 0x7e, 0x84, 0x9a, 0xbb, 0xe8, 0x128, 0x17a, 0x1ec, 0x274, + 0x21c, 0x1a8, 0x140, 0xf8, 0xc5, 0x9b, 0x77, 0x64, 0x5d, 0x67, 0x80, 0x9f, 0xca, 0x105, 0x15a, 0x1c1, 0x24e, + 0x1f6, 0x18b, 0x127, 0xe6, 0xaf, 0x82, 0x62, 0x4b, 0x46, 0x4e, 0x64, 0x85, 0xb6, 0xee, 0x13c, 0x1a6, 0x22d, + 0x1de, 0x170, 0x118, 0xd3, 0x9d, 0x6f, 0x4c, 0x35, 0x2a, 0x37, 0x4f, 0x76, 0xa3, 0xdb, 0x123, 0x187, 0x20b, + 0x1ca, 0x15c, 0x107, 0xc6, 0x8e, 0x5d, 0x3c, 0x21, 0x19, 0x27, 0x41, 0x68, 0x94, 0xce, 0x116, 0x17a, 0x1fa, + 0x1b4, 0x151, 0xfc, 0xbd, 0x85, 0x54, 0x31, 0x12, 0x9, 0x16, 0x34, 0x5c, 0x89, 0xc6, 0x10a, 0x16b, 0x1e5, + 0x1ae, 0x147, 0xf7, 0xb7, 0x80, 0x53, 0x29, 0xa, 0x4, 0x12, 0x2c, 0x56, 0x86, 0xc1, 0x103, 0x166, 0x1dc, + 0x1ac, 0x144, 0xf5, 0xb5, 0x7d, 0x4c, 0x37, 0x7, 0x1, 0xc, 0x2a, 0x55, 0x83, 0xbe, 0x101, 0x166, 0x1d7, + 0x1aa, 0x145, 0xf9, 0xb6, 0x82, 0x52, 0x3a, 0xb, 0x5, 0xd, 0x2d, 0x57, 0x88, 0xc0, 0x102, 0x162, 0x1dc, + 0x1b4, 0x14d, 0xfe, 0xbc, 0x87, 0x5c, 0x36, 0x16, 0xf, 0x19, 0x36, 0x5f, 0x8f, 0xca, 0x10d, 0x16b, 0x1e2, + 0x1be, 0x15a, 0x10b, 0xca, 0x90, 0x63, 0x3e, 0x26, 0x1f, 0x2b, 0x44, 0x69, 0x9c, 0xd2, 0x119, 0x175, 0x1f3, + 0x1c9, 0x16a, 0x114, 0xd5, 0x9e, 0x77, 0x54, 0x3a, 0x33, 0x3a, 0x54, 0x79, 0xa8, 0xe1, 0x127, 0x184, 0x203, + 0x1ed, 0x186, 0x12a, 0xe7, 0xb1, 0x87, 0x6a, 0x55, 0x4c, 0x54, 0x6d, 0x8f, 0xbb, 0xf4, 0x137, 0x1a0, 0x21a, + 0x20d, 0x1a0, 0x140, 0xfc, 0xc7, 0xa3, 0x81, 0x6d, 0x66, 0x71, 0x85, 0xa5, 0xd3, 0x108, 0x152, 0x1b9, 0x23c, + 0x231, 0x1bf, 0x160, 0x119, 0xe6, 0xbd, 0x9e, 0x8a, 0x84, 0x8c, 0xa2, 0xc5, 0xf0, 0x123, 0x16d, 0x1da, 0x260, + 0x25c, 0x1e1, 0x17f, 0x136, 0xfd, 0xda, 0xbe, 0xaa, 0x9f, 0xa9, 0xbb, 0xda, 0x104, 0x13e, 0x18e, 0x1ff, 0x285, + }, + + // Gbgain: + { + 0x28b, 0x1fd, 0x18e, 0x139, 0xfd, 0xd7, 0xb6, 0xa3, 0xa4, 0xa9, 0xbc, 0xde, 0x126, 0x14d, 0x1a5, 0x21f, 0x2b1, + 0x256, 0x1d6, 0x16a, 0x11d, 0xe4, 0xb9, 0x9b, 0x87, 0x83, 0x8b, 0xa0, 0xc1, 0xec, 0x12e, 0x183, 0x1f5, 0x284, + 0x229, 0x1ad, 0x142, 0xfb, 0xc9, 0x9f, 0x7c, 0x6a, 0x62, 0x6c, 0x84, 0xa4, 0xd2, 0x10f, 0x15f, 0x1ce, 0x252, + 0x201, 0x18a, 0x129, 0xe8, 0xb1, 0x86, 0x67, 0x4d, 0x4b, 0x51, 0x6a, 0x8b, 0xbc, 0xf9, 0x140, 0x1ac, 0x229, + 0x1ea, 0x176, 0x116, 0xd2, 0x9e, 0x73, 0x4e, 0x38, 0x2f, 0x3c, 0x54, 0x7a, 0xaa, 0xe0, 0x127, 0x18f, 0x211, + 0x1ce, 0x160, 0x107, 0xc8, 0x94, 0x5f, 0x3d, 0x22, 0x1e, 0x28, 0x43, 0x6b, 0x9a, 0xd1, 0x11c, 0x17d, 0x1fa, + 0x1bf, 0x153, 0x101, 0xbe, 0x86, 0x54, 0x2f, 0x14, 0xc, 0x1b, 0x36, 0x60, 0x91, 0xc9, 0x110, 0x16f, 0x1eb, + 0x1bf, 0x14a, 0xfa, 0xb8, 0x81, 0x4f, 0x28, 0xb, 0x3, 0x11, 0x2e, 0x56, 0x8a, 0xc6, 0x10a, 0x16a, 0x1e2, + 0x1b1, 0x149, 0xfa, 0xb8, 0x7f, 0x50, 0x37, 0x8, 0x0, 0xf, 0x2e, 0x57, 0x89, 0xc2, 0x107, 0x16a, 0x1df, + 0x1b9, 0x148, 0xf9, 0xba, 0x82, 0x54, 0x36, 0xd, 0x5, 0x10, 0x2f, 0x5a, 0x8b, 0xc5, 0x10a, 0x167, 0x1dd, + 0x1c0, 0x150, 0x100, 0xbf, 0x86, 0x5a, 0x34, 0x16, 0x10, 0x18, 0x39, 0x61, 0x91, 0xcb, 0x115, 0x171, 0x1e9, + 0x1d0, 0x15d, 0x10b, 0xc9, 0x93, 0x66, 0x43, 0x26, 0x1f, 0x29, 0x46, 0x6d, 0x9f, 0xd4, 0x11a, 0x17d, 0x1f3, + 0x1e1, 0x16e, 0x11a, 0xd6, 0x9d, 0x76, 0x54, 0x3c, 0x35, 0x40, 0x59, 0x7b, 0xad, 0xe4, 0x128, 0x187, 0x20a, + 0x200, 0x184, 0x12c, 0xe8, 0xb3, 0x87, 0x66, 0x51, 0x4d, 0x55, 0x6d, 0x93, 0xbd, 0xf9, 0x13f, 0x1a2, 0x21d, + 0x214, 0x1a4, 0x145, 0xfd, 0xc7, 0x9f, 0x82, 0x6d, 0x66, 0x6d, 0x86, 0xa8, 0xd7, 0x10c, 0x155, 0x1bd, 0x246, + 0x242, 0x1c2, 0x161, 0x119, 0xe4, 0xb9, 0x9d, 0x8f, 0x83, 0x8d, 0xa3, 0xc4, 0xf1, 0x12a, 0x174, 0x1e1, 0x26b, + 0x261, 0x1de, 0x17f, 0x131, 0xfd, 0xd8, 0xbc, 0xac, 0x9d, 0xa9, 0xbe, 0xe0, 0x109, 0x142, 0x193, 0x208, 0x28f, + }, + + // Bgain: + { + 0x28e, 0x202, 0x186, 0x12f, 0xfb, 0xcc, 0xb4, 0xa4, 0xa4, 0xa9, 0xba, 0xe2, 0x120, 0x14b, 0x1a5, 0x220, 0x2b6, + 0x251, 0x1d8, 0x16e, 0x114, 0xde, 0xb3, 0x92, 0x83, 0x81, 0x88, 0xa1, 0xbe, 0xec, 0x128, 0x17d, 0x1f1, 0x274, + 0x228, 0x1ac, 0x144, 0xfc, 0xc2, 0x97, 0x7c, 0x67, 0x61, 0x67, 0x7e, 0x9e, 0xcf, 0x107, 0x155, 0x1c9, 0x252, + 0x1fa, 0x183, 0x12a, 0xe4, 0xb0, 0x83, 0x61, 0x4d, 0x48, 0x50, 0x67, 0x86, 0xb4, 0xec, 0x133, 0x1a4, 0x22c, + 0x1da, 0x16d, 0x113, 0xcd, 0x9f, 0x70, 0x4e, 0x3a, 0x2f, 0x3c, 0x51, 0x75, 0xa0, 0xdb, 0x11e, 0x185, 0x201, + 0x1c5, 0x15d, 0x101, 0xc5, 0x8b, 0x5b, 0x41, 0x24, 0x1e, 0x27, 0x3d, 0x65, 0x93, 0xce, 0x114, 0x179, 0x1fc, + 0x1bc, 0x150, 0xfb, 0xbe, 0x87, 0x57, 0x30, 0x17, 0xd, 0x18, 0x37, 0x5f, 0x8b, 0xbf, 0x105, 0x16b, 0x1e9, + 0x1ac, 0x147, 0xf1, 0xb8, 0x80, 0x4f, 0x29, 0xf, 0x5, 0x10, 0x32, 0x5c, 0x88, 0xc2, 0x107, 0x160, 0x1d4, + 0x1af, 0x143, 0xf7, 0xb4, 0x7d, 0x4f, 0x3a, 0x7, 0x1, 0xc, 0x2f, 0x57, 0x8b, 0xc0, 0x102, 0x15f, 0x1d8, + 0x1a8, 0x147, 0xf5, 0xb6, 0x80, 0x51, 0x37, 0xc, 0x5, 0x10, 0x2f, 0x5a, 0x8b, 0xc8, 0x108, 0x163, 0x1da, + 0x1bc, 0x151, 0xfb, 0xba, 0x8a, 0x59, 0x36, 0x15, 0xf, 0x1b, 0x38, 0x62, 0x92, 0xc9, 0x10e, 0x171, 0x1ec, + 0x1cd, 0x156, 0x105, 0xc6, 0x8c, 0x66, 0x45, 0x27, 0x23, 0x27, 0x47, 0x6f, 0x9a, 0xd8, 0x115, 0x17e, 0x1ee, + 0x1da, 0x16c, 0x110, 0xd2, 0x9e, 0x78, 0x54, 0x3d, 0x38, 0x3e, 0x58, 0x78, 0xad, 0xe3, 0x126, 0x186, 0x20d, + 0x201, 0x18e, 0x12b, 0xe2, 0xb1, 0x87, 0x67, 0x54, 0x51, 0x58, 0x6c, 0x93, 0xb8, 0xf4, 0x13b, 0x1a3, 0x229, + 0x217, 0x1aa, 0x147, 0x100, 0xc8, 0xa0, 0x82, 0x6c, 0x66, 0x6c, 0x86, 0xa9, 0xd0, 0x107, 0x156, 0x1bb, 0x23b, + 0x232, 0x1c2, 0x165, 0x117, 0xe4, 0xbf, 0xa2, 0x8c, 0x85, 0x8a, 0x9f, 0xc1, 0xeb, 0x126, 0x16b, 0x1dd, 0x26c, + 0x262, 0x1ea, 0x17c, 0x132, 0xf7, 0xd2, 0xc0, 0xa9, 0x9f, 0xa5, 0xb9, 0xd3, 0x102, 0x137, 0x184, 0x206, 0x289, + }, + }, + + { + // Rgain: + { + 0x399, 0x2df, 0x23e, 0x1cd, 0x170, 0x135, 0xfc, 0xdb, 0xda, 0xe4, 0xfd, 0x12f, 0x16e, 0x1d4, 0x24e, 0x2ee, 0x3e2, + 0x372, 0x2b0, 0x20f, 0x19a, 0x140, 0x109, 0xdc, 0xb7, 0xaf, 0xbe, 0xd5, 0x105, 0x14c, 0x1a4, 0x225, 0x2b8, 0x384, + 0x32a, 0x276, 0x1e3, 0x174, 0x11c, 0xda, 0xaf, 0x92, 0x88, 0x97, 0xac, 0xec, 0x125, 0x180, 0x200, 0x289, 0x34f, + 0x2f6, 0x24f, 0x1bd, 0x14b, 0xfd, 0xba, 0x89, 0x6c, 0x61, 0x71, 0x89, 0xc6, 0x107, 0x15a, 0x1c7, 0x262, 0x319, + 0x2c9, 0x229, 0x1a5, 0x135, 0xdb, 0x9b, 0x6a, 0x4a, 0x3f, 0x4e, 0x6c, 0xa5, 0xeb, 0x13e, 0x1b1, 0x23d, 0x2e3, + 0x2b9, 0x211, 0x187, 0x11b, 0xc9, 0x81, 0x4d, 0x2b, 0x21, 0x2f, 0x58, 0x8f, 0xda, 0x12a, 0x196, 0x229, 0x2c8, + 0x29c, 0x1fb, 0x16e, 0x10d, 0xb5, 0x6e, 0x37, 0x11, 0x7, 0x1a, 0x46, 0x7b, 0xc3, 0x118, 0x187, 0x210, 0x2b7, + 0x2bc, 0x1f5, 0x16b, 0x106, 0xb1, 0x61, 0x2e, 0x4, 0x0, 0xe, 0x3a, 0x71, 0xba, 0x113, 0x17f, 0x206, 0x2a4, + 0x33a, 0x1f3, 0x165, 0xfd, 0xab, 0x62, 0x2d, 0x2, 0x3, 0x8, 0x35, 0x6e, 0xb6, 0x10f, 0x179, 0x202, 0x29f, + 0x2f0, 0x1e6, 0x165, 0x103, 0xac, 0x63, 0x30, 0x7, 0x1, 0xb, 0x36, 0x70, 0xb8, 0x112, 0x176, 0x208, 0x2a4, + 0x2d2, 0x1f4, 0x171, 0x106, 0xb6, 0x70, 0x38, 0x15, 0xa, 0x18, 0x40, 0x78, 0xbf, 0x11c, 0x181, 0x20c, 0x2ac, + 0x2d0, 0x202, 0x17e, 0x118, 0xc0, 0x7c, 0x4a, 0x2e, 0x1d, 0x2e, 0x4f, 0x87, 0xcd, 0x122, 0x190, 0x21a, 0x2bb, + 0x2be, 0x216, 0x194, 0x12d, 0xd9, 0x99, 0x64, 0x49, 0x3d, 0x48, 0x68, 0x9d, 0xdd, 0x13f, 0x1a3, 0x229, 0x2cf, + 0x2e4, 0x236, 0x1bb, 0x144, 0xf0, 0xb5, 0x81, 0x63, 0x62, 0x66, 0x86, 0xb7, 0xfb, 0x14e, 0x1be, 0x249, 0x2ed, + 0x30c, 0x26c, 0x1ce, 0x164, 0x110, 0xd4, 0xa4, 0x86, 0x7f, 0x86, 0xa6, 0xd7, 0x115, 0x171, 0x1da, 0x270, 0x31c, + 0x339, 0x28d, 0x1fb, 0x18d, 0x133, 0xf6, 0xc5, 0xaa, 0xa1, 0xae, 0xca, 0xf8, 0x138, 0x195, 0x210, 0x2a1, 0x355, + 0x37f, 0x2be, 0x229, 0x1b1, 0x159, 0x118, 0xeb, 0xd3, 0xc6, 0xd4, 0xed, 0x11f, 0x15d, 0x1cd, 0x23d, 0x2cc, 0x388, + }, + + // Grgain: + { + 0x324, 0x279, 0x1f5, 0x191, 0x148, 0x113, 0xe4, 0xcd, 0xc9, 0xd4, 0xf2, 0x11f, 0x164, 0x1b6, 0x22c, 0x2ba, 0x392, + 0x2f1, 0x250, 0x1cb, 0x16c, 0x11f, 0xe9, 0xc2, 0xa8, 0xa5, 0xb1, 0xcf, 0xfa, 0x13d, 0x193, 0x208, 0x28d, 0x349, + 0x2b8, 0x225, 0x1a9, 0x148, 0xfa, 0xc5, 0x9c, 0x80, 0x7e, 0x8e, 0xa5, 0xe3, 0x11b, 0x16e, 0x1e6, 0x266, 0x316, + 0x28b, 0x201, 0x18e, 0x12a, 0xe4, 0xa5, 0x79, 0x60, 0x59, 0x6a, 0x85, 0xbf, 0xfe, 0x151, 0x1b7, 0x243, 0x2e3, + 0x26b, 0x1e5, 0x174, 0x111, 0xc4, 0x88, 0x5d, 0x40, 0x39, 0x4a, 0x69, 0xa2, 0xea, 0x137, 0x19e, 0x223, 0x2b8, + 0x253, 0x1cd, 0x159, 0xfc, 0xb2, 0x73, 0x43, 0x26, 0x1e, 0x30, 0x57, 0x90, 0xd8, 0x124, 0x188, 0x211, 0x2a4, + 0x247, 0x1bd, 0x14c, 0xf2, 0xa4, 0x65, 0x31, 0x10, 0x6, 0x1a, 0x49, 0x7c, 0xc3, 0x116, 0x17a, 0x201, 0x292, + 0x263, 0x1b6, 0x141, 0xec, 0xa1, 0x5a, 0x26, 0x3, 0x1, 0xf, 0x3f, 0x74, 0xb9, 0x111, 0x172, 0x1f3, 0x285, + 0x2dc, 0x1b4, 0x13e, 0xe6, 0x98, 0x56, 0x25, 0x1, 0x5, 0xb, 0x38, 0x71, 0xb8, 0x10e, 0x16f, 0x1ed, 0x281, + 0x291, 0x1af, 0x142, 0xe5, 0x9d, 0x5a, 0x2b, 0x7, 0x2, 0xe, 0x3c, 0x74, 0xbb, 0x10f, 0x170, 0x1f0, 0x27f, + 0x28d, 0x1b7, 0x14b, 0xee, 0xa5, 0x64, 0x35, 0x13, 0xa, 0x1c, 0x42, 0x7d, 0xbe, 0x116, 0x17b, 0x1f8, 0x28c, + 0x27e, 0x1c3, 0x156, 0xfc, 0xb1, 0x76, 0x46, 0x2e, 0x1f, 0x2f, 0x55, 0x8c, 0xd1, 0x127, 0x185, 0x207, 0x2a5, + 0x265, 0x1d8, 0x169, 0x111, 0xc5, 0x8a, 0x5c, 0x49, 0x3f, 0x4c, 0x6e, 0xa0, 0xe2, 0x13b, 0x199, 0x215, 0x2ac, + 0x282, 0x1f2, 0x188, 0x125, 0xde, 0xa5, 0x79, 0x5e, 0x63, 0x67, 0x89, 0xb8, 0xf8, 0x14c, 0x1ae, 0x231, 0x2cb, + 0x2a6, 0x221, 0x19c, 0x141, 0xfb, 0xc2, 0x9a, 0x82, 0x7d, 0x88, 0xa6, 0xd6, 0x114, 0x168, 0x1cd, 0x257, 0x2f4, + 0x2cd, 0x240, 0x1c2, 0x166, 0x11e, 0xe7, 0xbc, 0xa8, 0xa0, 0xac, 0xca, 0xf7, 0x138, 0x18a, 0x1f8, 0x27d, 0x31d, + 0x317, 0x268, 0x1ef, 0x189, 0x13b, 0x106, 0xde, 0xc9, 0xc3, 0xd3, 0xed, 0x119, 0x15a, 0x1c1, 0x221, 0x2a9, 0x357, + }, + + // Gbgain: + { + 0x32b, 0x277, 0x1f2, 0x18f, 0x148, 0x116, 0xe3, 0xc9, 0xc9, 0xd5, 0xf1, 0x11c, 0x15a, 0x1b4, 0x22d, 0x2bd, 0x38d, + 0x2f4, 0x24d, 0x1ca, 0x16d, 0x11b, 0xea, 0xc4, 0xa8, 0xa3, 0xb3, 0xc9, 0xfb, 0x13d, 0x190, 0x204, 0x28e, 0x348, + 0x2b8, 0x221, 0x1a8, 0x149, 0xfe, 0xc5, 0x9b, 0x80, 0x7a, 0x8e, 0xa6, 0xe2, 0x119, 0x16f, 0x1e4, 0x269, 0x315, + 0x28e, 0x201, 0x18a, 0x12d, 0xe3, 0xa2, 0x78, 0x60, 0x58, 0x6c, 0x86, 0xc0, 0xfc, 0x14e, 0x1b9, 0x242, 0x2e7, + 0x270, 0x1e1, 0x178, 0x115, 0xc5, 0x8a, 0x5e, 0x41, 0x3a, 0x4b, 0x6a, 0xa2, 0xe7, 0x136, 0x19e, 0x225, 0x2bd, + 0x258, 0x1ce, 0x15c, 0xff, 0xb1, 0x75, 0x44, 0x26, 0x1e, 0x30, 0x57, 0x8d, 0xd7, 0x125, 0x18c, 0x212, 0x2a7, + 0x241, 0x1bd, 0x14f, 0xf2, 0xa5, 0x65, 0x30, 0x11, 0x7, 0x1b, 0x48, 0x7d, 0xc3, 0x118, 0x17b, 0x1ff, 0x297, + 0x26b, 0x1ba, 0x147, 0xef, 0xa1, 0x5b, 0x28, 0x4, 0x1, 0x10, 0x3e, 0x75, 0xba, 0x112, 0x171, 0x1f4, 0x28b, + 0x2de, 0x1b6, 0x140, 0xe5, 0x98, 0x5a, 0x27, 0x1, 0x5, 0xb, 0x37, 0x71, 0xb8, 0x10f, 0x171, 0x1f2, 0x27f, + 0x293, 0x1b0, 0x144, 0xe6, 0x9c, 0x5a, 0x2c, 0x7, 0x4, 0xe, 0x39, 0x74, 0xbc, 0x10f, 0x16e, 0x1f4, 0x282, + 0x285, 0x1ba, 0x14b, 0xef, 0xa5, 0x66, 0x36, 0x15, 0xb, 0x1d, 0x46, 0x7c, 0xc1, 0x117, 0x17c, 0x1f8, 0x293, + 0x27c, 0x1c5, 0x159, 0xfd, 0xb1, 0x79, 0x47, 0x2e, 0x1f, 0x33, 0x56, 0x8e, 0xce, 0x129, 0x187, 0x206, 0x295, + 0x266, 0x1db, 0x16d, 0x111, 0xc6, 0x8d, 0x5f, 0x49, 0x3f, 0x4a, 0x6f, 0xa3, 0xe1, 0x13a, 0x19c, 0x219, 0x2ac, + 0x280, 0x1f4, 0x18a, 0x126, 0xde, 0xa5, 0x7e, 0x61, 0x61, 0x67, 0x87, 0xbd, 0xf6, 0x14e, 0x1ae, 0x232, 0x2cb, + 0x2ae, 0x21f, 0x1a0, 0x141, 0xf8, 0xc4, 0x99, 0x84, 0x7f, 0x89, 0xa6, 0xd4, 0x115, 0x169, 0x1d1, 0x255, 0x2f2, + 0x2d4, 0x243, 0x1c6, 0x165, 0x11a, 0xe6, 0xc0, 0xa8, 0xa0, 0xaa, 0xca, 0xfc, 0x137, 0x18a, 0x1f9, 0x282, 0x324, + 0x310, 0x26a, 0x1f0, 0x18a, 0x13d, 0x108, 0xde, 0xca, 0xc3, 0xcf, 0xf0, 0x11d, 0x15b, 0x1c1, 0x227, 0x2aa, 0x360, + }, + + // Bgain: + { + 0x2f0, 0x24a, 0x1d2, 0x175, 0x137, 0x105, 0xd7, 0xbd, 0xc0, 0xca, 0xec, 0x10f, 0x14b, 0x1a7, 0x21b, 0x29c, 0x35e, + 0x2b8, 0x228, 0x1ad, 0x155, 0x114, 0xe1, 0xbe, 0xa0, 0x9d, 0xad, 0xc1, 0xf3, 0x138, 0x183, 0x1f5, 0x278, 0x325, + 0x28f, 0x1fe, 0x18b, 0x138, 0xf1, 0xbc, 0x96, 0x7e, 0x78, 0x8a, 0xa2, 0xda, 0x114, 0x162, 0x1d6, 0x253, 0x2f5, + 0x25e, 0x1df, 0x171, 0x11b, 0xd7, 0x9f, 0x76, 0x5d, 0x5b, 0x69, 0x84, 0xbd, 0xf9, 0x14a, 0x1ae, 0x232, 0x2c8, + 0x249, 0x1c4, 0x15d, 0x105, 0xba, 0x83, 0x5a, 0x3c, 0x37, 0x4c, 0x67, 0x9f, 0xe7, 0x12f, 0x195, 0x214, 0x2a1, + 0x234, 0x1af, 0x141, 0xf0, 0xa8, 0x71, 0x3e, 0x23, 0x1d, 0x30, 0x58, 0x91, 0xd3, 0x122, 0x180, 0x202, 0x287, + 0x21e, 0x19d, 0x138, 0xe3, 0x9d, 0x61, 0x2e, 0xf, 0x6, 0x1a, 0x47, 0x7c, 0xbf, 0x119, 0x171, 0x1f5, 0x279, + 0x244, 0x19f, 0x133, 0xdd, 0x97, 0x56, 0x28, 0x4, 0x1, 0x11, 0x3d, 0x77, 0xbc, 0x10f, 0x16f, 0x1e9, 0x276, + 0x2a9, 0x19e, 0x12e, 0xda, 0x92, 0x54, 0x24, 0x4, 0x7, 0xd, 0x3c, 0x75, 0xb4, 0x10b, 0x168, 0x1e9, 0x271, + 0x267, 0x192, 0x128, 0xd9, 0x96, 0x56, 0x2a, 0x6, 0x7, 0x10, 0x3d, 0x74, 0xb6, 0x10c, 0x168, 0x1e4, 0x271, + 0x263, 0x19a, 0x134, 0xdd, 0x9d, 0x65, 0x37, 0x16, 0xe, 0x1f, 0x46, 0x79, 0xbd, 0x112, 0x170, 0x1ef, 0x286, + 0x254, 0x1a5, 0x143, 0xf0, 0xa7, 0x70, 0x46, 0x2e, 0x21, 0x33, 0x55, 0x90, 0xcb, 0x11d, 0x17d, 0x1f9, 0x287, + 0x236, 0x1bd, 0x153, 0x100, 0xba, 0x84, 0x57, 0x45, 0x42, 0x50, 0x6d, 0xa2, 0xde, 0x137, 0x194, 0x20a, 0x297, + 0x25b, 0x1db, 0x175, 0x115, 0xd2, 0x9b, 0x76, 0x5b, 0x5f, 0x69, 0x8a, 0xba, 0xf4, 0x149, 0x1a4, 0x226, 0x2bb, + 0x27d, 0x1fb, 0x186, 0x132, 0xef, 0xbc, 0x97, 0x81, 0x7d, 0x86, 0xa4, 0xd5, 0x112, 0x15e, 0x1bc, 0x242, 0x2da, + 0x2a9, 0x21f, 0x1aa, 0x151, 0x10e, 0xdc, 0xb7, 0xa3, 0x99, 0xaa, 0xc6, 0xee, 0x130, 0x183, 0x1f3, 0x264, 0x304, + 0x2d0, 0x245, 0x1da, 0x175, 0x12c, 0xf9, 0xdb, 0xc3, 0xbb, 0xc8, 0xe7, 0x114, 0x14d, 0x1b2, 0x218, 0x29b, 0x338, + }, + }, + }, +}; + + +#ifdef __cplusplus +#if __cplusplus +} +#endif +#endif /* End of #ifdef __cplusplus */ + + +#endif /* __SC3336_MIPI_CMOS_EX_H_ */ diff --git a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_sensor_ctl.c b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_sensor_ctl.c index 0627156..e6e25e2 100644 --- a/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_sensor_ctl.c +++ b/libraries/sensor/hi3516ev200/smart_sc3336/sc3336_mipi_sensor_ctl.c @@ -23,8 +23,8 @@ #include #include -#include "hi_comm_video.h" -#include "hi_sns_ctrl.h" +#include "comm_video.h" +#include "sns_ctrl.h" #ifdef HI_GPIO_I2C #include "gpioi2c_ex.h"