Commit 227d2518 authored by Dmytro Laktyushkin's avatar Dmytro Laktyushkin Committed by Alex Deucher

drm/amd/display: add scaler coefficients for 64 phase 5-8 taps

Signed-off-by: default avatarDmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Acked-by: default avatarHarry Wentland <Harry.Wentland@amd.com>
Reviewed-by: default avatarTony Cheng <Tony.Cheng@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent 5936223f
...@@ -452,6 +452,566 @@ const uint16_t filter_4tap_64p_183[132] = { ...@@ -452,6 +452,566 @@ const uint16_t filter_4tap_64p_183[132] = {
252, 1832, 1784, 220, 252, 1832, 1784, 220,
236, 1808, 1808, 236 }; 236, 1808, 1808, 236 };
const uint16_t filter_5tap_64p_upscale[165] = {
15936, 2496, 2496, 15936, 0,
15948, 2404, 2580, 15924, 0,
15960, 2312, 2664, 15912, 4,
15976, 2220, 2748, 15904, 8,
15992, 2128, 2832, 15896, 12,
16004, 2036, 2912, 15888, 16,
16020, 1944, 2992, 15880, 20,
16036, 1852, 3068, 15876, 20,
16056, 1760, 3140, 15876, 24,
16072, 1668, 3216, 15872, 28,
16088, 1580, 3284, 15872, 32,
16104, 1492, 3352, 15876, 32,
16120, 1404, 3420, 15876, 36,
16140, 1316, 3480, 15884, 40,
16156, 1228, 3540, 15892, 40,
16172, 1144, 3600, 15900, 40,
16188, 1060, 3652, 15908, 44,
16204, 980, 3704, 15924, 44,
16220, 900, 3756, 15936, 44,
16236, 824, 3800, 15956, 44,
16248, 744, 3844, 15972, 44,
16264, 672, 3884, 15996, 44,
16276, 600, 3920, 16020, 44,
16292, 528, 3952, 16044, 40,
16304, 460, 3980, 16072, 40,
16316, 396, 4008, 16104, 36,
16328, 332, 4032, 16136, 32,
16336, 272, 4048, 16172, 28,
16348, 212, 4064, 16208, 24,
16356, 156, 4080, 16248, 16,
16368, 100, 4088, 16292, 12,
16376, 48, 4092, 16336, 4,
0, 0, 4096, 0, 0 };
const uint16_t filter_5tap_64p_117[165] = {
16056, 2372, 2372, 16056, 0,
16052, 2312, 2432, 16060, 0,
16052, 2252, 2488, 16064, 0,
16052, 2188, 2548, 16072, 0,
16052, 2124, 2600, 16076, 0,
16052, 2064, 2656, 16088, 0,
16052, 2000, 2708, 16096, 0,
16056, 1932, 2760, 16108, 0,
16060, 1868, 2808, 16120, 0,
16064, 1804, 2856, 16132, 0,
16068, 1740, 2904, 16148, 16380,
16076, 1676, 2948, 16164, 16380,
16080, 1612, 2992, 16180, 16376,
16088, 1544, 3032, 16200, 16372,
16096, 1480, 3072, 16220, 16372,
16104, 1420, 3108, 16244, 16368,
16112, 1356, 3144, 16268, 16364,
16120, 1292, 3180, 16292, 16360,
16128, 1232, 3212, 16320, 16356,
16136, 1168, 3240, 16344, 16352,
16144, 1108, 3268, 16376, 16344,
16156, 1048, 3292, 20, 16340,
16164, 988, 3316, 52, 16332,
16172, 932, 3336, 88, 16328,
16184, 872, 3356, 124, 16320,
16192, 816, 3372, 160, 16316,
16204, 760, 3388, 196, 16308,
16212, 708, 3400, 236, 16300,
16220, 656, 3412, 276, 16292,
16232, 604, 3420, 320, 16284,
16240, 552, 3424, 364, 16276,
16248, 504, 3428, 408, 16268,
16256, 456, 3428, 456, 16256 };
const uint16_t filter_5tap_64p_150[165] = {
16368, 2064, 2064, 16368, 0,
16352, 2028, 2100, 16380, 16380,
16340, 1996, 2132, 12, 16376,
16328, 1960, 2168, 24, 16376,
16316, 1924, 2204, 44, 16372,
16308, 1888, 2236, 60, 16368,
16296, 1848, 2268, 76, 16364,
16288, 1812, 2300, 96, 16360,
16280, 1772, 2328, 116, 16356,
16272, 1736, 2360, 136, 16352,
16268, 1696, 2388, 160, 16348,
16260, 1656, 2416, 180, 16344,
16256, 1616, 2440, 204, 16340,
16248, 1576, 2464, 228, 16336,
16244, 1536, 2492, 252, 16332,
16240, 1496, 2512, 276, 16324,
16240, 1456, 2536, 304, 16320,
16236, 1416, 2556, 332, 16316,
16232, 1376, 2576, 360, 16312,
16232, 1336, 2592, 388, 16308,
16232, 1296, 2612, 416, 16300,
16232, 1256, 2628, 448, 16296,
16232, 1216, 2640, 480, 16292,
16232, 1172, 2652, 512, 16288,
16232, 1132, 2664, 544, 16284,
16232, 1092, 2676, 576, 16280,
16236, 1056, 2684, 608, 16272,
16236, 1016, 2692, 644, 16268,
16240, 976, 2700, 680, 16264,
16240, 936, 2704, 712, 16260,
16244, 900, 2708, 748, 16256,
16248, 860, 2708, 788, 16252,
16248, 824, 2708, 824, 16248 };
const uint16_t filter_5tap_64p_183[165] = {
228, 1816, 1816, 228, 0,
216, 1792, 1836, 248, 16380,
200, 1772, 1860, 264, 16376,
184, 1748, 1884, 280, 16376,
168, 1728, 1904, 300, 16372,
156, 1704, 1928, 316, 16368,
144, 1680, 1948, 336, 16364,
128, 1656, 1968, 356, 16364,
116, 1632, 1988, 376, 16360,
104, 1604, 2008, 396, 16356,
96, 1580, 2024, 416, 16356,
84, 1556, 2044, 440, 16352,
72, 1528, 2060, 460, 16348,
64, 1504, 2076, 484, 16348,
52, 1476, 2092, 504, 16344,
44, 1448, 2104, 528, 16344,
36, 1424, 2120, 552, 16340,
28, 1396, 2132, 576, 16340,
20, 1368, 2144, 600, 16340,
12, 1340, 2156, 624, 16336,
4, 1312, 2168, 652, 16336,
0, 1284, 2180, 676, 16336,
16376, 1256, 2188, 700, 16332,
16372, 1228, 2196, 728, 16332,
16368, 1200, 2204, 752, 16332,
16364, 1172, 2212, 780, 16332,
16356, 1144, 2216, 808, 16332,
16352, 1116, 2220, 836, 16332,
16352, 1084, 2224, 860, 16332,
16348, 1056, 2228, 888, 16336,
16344, 1028, 2232, 916, 16336,
16340, 1000, 2232, 944, 16336,
16340, 972, 2232, 972, 16340 };
const uint16_t filter_6tap_64p_upscale[198] = {
0, 0, 4092, 0, 0, 0,
12, 16332, 4092, 52, 16368, 0,
24, 16280, 4088, 108, 16356, 0,
36, 16236, 4080, 168, 16340, 0,
44, 16188, 4064, 228, 16324, 0,
56, 16148, 4052, 292, 16308, 0,
64, 16108, 4032, 356, 16292, 4,
72, 16072, 4008, 424, 16276, 4,
80, 16036, 3980, 492, 16256, 4,
88, 16004, 3952, 564, 16240, 8,
96, 15972, 3920, 636, 16220, 8,
100, 15944, 3884, 712, 16204, 12,
108, 15916, 3844, 788, 16184, 16,
112, 15896, 3800, 864, 16164, 20,
116, 15872, 3756, 944, 16144, 20,
120, 15852, 3708, 1024, 16124, 24,
120, 15836, 3656, 1108, 16104, 28,
124, 15824, 3600, 1192, 16084, 32,
124, 15808, 3544, 1276, 16064, 36,
124, 15800, 3484, 1360, 16044, 40,
128, 15792, 3420, 1448, 16024, 44,
128, 15784, 3352, 1536, 16004, 48,
124, 15780, 3288, 1624, 15988, 52,
124, 15776, 3216, 1712, 15968, 56,
124, 15776, 3144, 1800, 15948, 64,
120, 15776, 3068, 1888, 15932, 68,
120, 15780, 2992, 1976, 15912, 72,
116, 15784, 2916, 2064, 15896, 76,
112, 15792, 2836, 2152, 15880, 80,
108, 15796, 2752, 2244, 15868, 84,
104, 15804, 2672, 2328, 15852, 88,
104, 15816, 2588, 2416, 15840, 92,
100, 15828, 2504, 2504, 15828, 100 };
const uint16_t filter_6tap_64p_117[198] = {
16168, 476, 3568, 476, 16168, 0,
16180, 428, 3564, 528, 16156, 0,
16192, 376, 3556, 584, 16144, 4,
16204, 328, 3548, 636, 16128, 4,
16216, 280, 3540, 692, 16116, 8,
16228, 232, 3524, 748, 16104, 12,
16240, 188, 3512, 808, 16092, 12,
16252, 148, 3492, 864, 16080, 16,
16264, 104, 3472, 924, 16068, 16,
16276, 64, 3452, 984, 16056, 20,
16284, 28, 3428, 1044, 16048, 24,
16296, 16376, 3400, 1108, 16036, 24,
16304, 16340, 3372, 1168, 16024, 28,
16316, 16304, 3340, 1232, 16016, 32,
16324, 16272, 3308, 1296, 16004, 32,
16332, 16244, 3272, 1360, 15996, 36,
16344, 16212, 3236, 1424, 15988, 36,
16352, 16188, 3200, 1488, 15980, 40,
16360, 16160, 3160, 1552, 15972, 40,
16368, 16136, 3116, 1616, 15964, 40,
16372, 16112, 3072, 1680, 15956, 44,
16380, 16092, 3028, 1744, 15952, 44,
0, 16072, 2980, 1808, 15948, 44,
8, 16052, 2932, 1872, 15944, 48,
12, 16036, 2880, 1936, 15940, 48,
16, 16020, 2828, 2000, 15936, 48,
20, 16008, 2776, 2064, 15936, 48,
24, 15996, 2724, 2128, 15936, 48,
28, 15984, 2668, 2192, 15936, 48,
32, 15972, 2612, 2252, 15940, 44,
36, 15964, 2552, 2316, 15940, 44,
40, 15956, 2496, 2376, 15944, 44,
40, 15952, 2436, 2436, 15952, 40 };
const uint16_t filter_6tap_64p_150[198] = {
16148, 920, 2724, 920, 16148, 0,
16152, 880, 2724, 956, 16148, 0,
16152, 844, 2720, 996, 16144, 0,
16156, 804, 2716, 1032, 16144, 0,
16156, 768, 2712, 1072, 16144, 0,
16160, 732, 2708, 1112, 16144, 16380,
16164, 696, 2700, 1152, 16144, 16380,
16168, 660, 2692, 1192, 16148, 16380,
16172, 628, 2684, 1232, 16148, 16380,
16176, 592, 2672, 1272, 16152, 16376,
16180, 560, 2660, 1312, 16152, 16376,
16184, 524, 2648, 1348, 16156, 16376,
16192, 492, 2632, 1388, 16160, 16372,
16196, 460, 2616, 1428, 16164, 16372,
16200, 432, 2600, 1468, 16168, 16368,
16204, 400, 2584, 1508, 16176, 16364,
16212, 368, 2564, 1548, 16180, 16364,
16216, 340, 2544, 1588, 16188, 16360,
16220, 312, 2524, 1628, 16196, 16356,
16228, 284, 2504, 1668, 16204, 16356,
16232, 256, 2480, 1704, 16212, 16352,
16240, 232, 2456, 1744, 16224, 16348,
16244, 204, 2432, 1780, 16232, 16344,
16248, 180, 2408, 1820, 16244, 16340,
16256, 156, 2380, 1856, 16256, 16336,
16260, 132, 2352, 1896, 16268, 16332,
16268, 108, 2324, 1932, 16280, 16328,
16272, 88, 2296, 1968, 16292, 16324,
16276, 64, 2268, 2004, 16308, 16320,
16284, 44, 2236, 2036, 16324, 16312,
16288, 24, 2204, 2072, 16340, 16308,
16292, 8, 2172, 2108, 16356, 16304,
16300, 16372, 2140, 2140, 16372, 16300 };
const uint16_t filter_6tap_64p_183[198] = {
16296, 1032, 2196, 1032, 16296, 0,
16292, 1004, 2200, 1060, 16304, 16380,
16288, 976, 2200, 1088, 16308, 16380,
16284, 952, 2196, 1116, 16312, 16376,
16284, 924, 2196, 1144, 16320, 16376,
16280, 900, 2192, 1172, 16324, 16372,
16276, 872, 2192, 1200, 16332, 16368,
16276, 848, 2188, 1228, 16340, 16368,
16272, 820, 2180, 1256, 16348, 16364,
16272, 796, 2176, 1280, 16356, 16360,
16268, 768, 2168, 1308, 16364, 16360,
16268, 744, 2164, 1336, 16372, 16356,
16268, 716, 2156, 1364, 16380, 16352,
16264, 692, 2148, 1392, 4, 16352,
16264, 668, 2136, 1420, 16, 16348,
16264, 644, 2128, 1448, 28, 16344,
16264, 620, 2116, 1472, 36, 16340,
16264, 596, 2108, 1500, 48, 16340,
16268, 572, 2096, 1524, 60, 16336,
16268, 548, 2080, 1552, 72, 16332,
16268, 524, 2068, 1576, 88, 16328,
16268, 504, 2056, 1604, 100, 16324,
16272, 480, 2040, 1628, 112, 16324,
16272, 456, 2024, 1652, 128, 16320,
16272, 436, 2008, 1680, 144, 16316,
16276, 416, 1992, 1704, 156, 16312,
16276, 392, 1976, 1724, 172, 16308,
16280, 372, 1956, 1748, 188, 16308,
16280, 352, 1940, 1772, 204, 16304,
16284, 332, 1920, 1796, 224, 16300,
16288, 312, 1900, 1816, 240, 16296,
16288, 296, 1880, 1840, 256, 16296,
16292, 276, 1860, 1860, 276, 16292 };
const uint16_t filter_7tap_64p_upscale[231] = {
176, 15760, 2488, 2488, 15760, 176, 0,
172, 15772, 2404, 2572, 15752, 180, 16380,
168, 15784, 2324, 2656, 15740, 184, 16380,
164, 15800, 2240, 2736, 15732, 188, 16376,
160, 15812, 2152, 2816, 15728, 192, 16376,
152, 15828, 2068, 2896, 15724, 192, 16376,
148, 15848, 1984, 2972, 15720, 196, 16372,
140, 15864, 1896, 3048, 15720, 196, 16372,
136, 15884, 1812, 3124, 15720, 196, 16368,
128, 15900, 1724, 3196, 15720, 196, 16368,
120, 15920, 1640, 3268, 15724, 196, 16368,
116, 15940, 1552, 3336, 15732, 196, 16364,
108, 15964, 1468, 3400, 15740, 196, 16364,
104, 15984, 1384, 3464, 15748, 192, 16364,
96, 16004, 1300, 3524, 15760, 188, 16364,
88, 16028, 1216, 3584, 15776, 184, 16364,
84, 16048, 1132, 3640, 15792, 180, 16360,
76, 16072, 1048, 3692, 15812, 176, 16360,
68, 16092, 968, 3744, 15832, 168, 16360,
64, 16116, 888, 3788, 15856, 160, 16360,
56, 16140, 812, 3832, 15884, 152, 16360,
52, 16160, 732, 3876, 15912, 144, 16360,
44, 16184, 656, 3912, 15944, 136, 16364,
40, 16204, 584, 3944, 15976, 124, 16364,
32, 16228, 512, 3976, 16012, 116, 16364,
28, 16248, 440, 4004, 16048, 104, 16364,
24, 16268, 372, 4028, 16092, 88, 16368,
20, 16288, 304, 4048, 16132, 76, 16368,
12, 16308, 240, 4064, 16180, 60, 16372,
8, 16328, 176, 4076, 16228, 48, 16372,
4, 16348, 112, 4088, 16276, 32, 16376,
0, 16364, 56, 4092, 16328, 16, 16380,
0, 0, 0, 4096, 0, 0, 0 };
const uint16_t filter_7tap_64p_117[231] = {
92, 15868, 2464, 2464, 15868, 92, 0,
96, 15864, 2404, 2528, 15876, 88, 0,
100, 15860, 2344, 2584, 15884, 84, 0,
104, 15856, 2280, 2644, 15892, 76, 0,
108, 15852, 2216, 2700, 15904, 72, 0,
108, 15852, 2152, 2756, 15916, 64, 0,
112, 15852, 2088, 2812, 15932, 60, 0,
112, 15852, 2024, 2864, 15948, 52, 0,
112, 15856, 1960, 2916, 15964, 44, 0,
116, 15860, 1892, 2964, 15984, 36, 0,
116, 15864, 1828, 3016, 16004, 24, 4,
116, 15868, 1760, 3060, 16024, 16, 4,
116, 15876, 1696, 3108, 16048, 8, 8,
116, 15884, 1628, 3152, 16072, 16380, 8,
112, 15892, 1564, 3192, 16100, 16372, 8,
112, 15900, 1496, 3232, 16124, 16360, 12,
112, 15908, 1428, 3268, 16156, 16348, 12,
108, 15920, 1364, 3304, 16188, 16336, 16,
108, 15928, 1300, 3340, 16220, 16324, 20,
104, 15940, 1232, 3372, 16252, 16312, 20,
104, 15952, 1168, 3400, 16288, 16300, 24,
100, 15964, 1104, 3428, 16328, 16284, 28,
96, 15980, 1040, 3452, 16364, 16272, 28,
96, 15992, 976, 3476, 20, 16256, 32,
92, 16004, 916, 3496, 64, 16244, 36,
88, 16020, 856, 3516, 108, 16228, 40,
84, 16032, 792, 3532, 152, 16216, 44,
80, 16048, 732, 3544, 200, 16200, 48,
80, 16064, 676, 3556, 248, 16184, 48,
76, 16080, 616, 3564, 296, 16168, 52,
72, 16092, 560, 3568, 344, 16156, 56,
68, 16108, 504, 3572, 396, 16140, 60,
64, 16124, 452, 3576, 452, 16124, 64 };
const uint16_t filter_7tap_64p_150[231] = {
16224, 16380, 2208, 2208, 16380, 16224, 0,
16232, 16360, 2172, 2236, 16, 16216, 0,
16236, 16340, 2140, 2268, 40, 16212, 0,
16244, 16324, 2104, 2296, 60, 16204, 4,
16252, 16304, 2072, 2324, 84, 16196, 4,
16256, 16288, 2036, 2352, 108, 16192, 4,
16264, 16268, 2000, 2380, 132, 16184, 8,
16272, 16252, 1960, 2408, 160, 16176, 8,
16276, 16240, 1924, 2432, 184, 16172, 8,
16284, 16224, 1888, 2456, 212, 16164, 8,
16288, 16212, 1848, 2480, 240, 16160, 12,
16296, 16196, 1812, 2500, 268, 16152, 12,
16300, 16184, 1772, 2524, 296, 16144, 12,
16308, 16172, 1736, 2544, 324, 16140, 12,
16312, 16164, 1696, 2564, 356, 16136, 12,
16320, 16152, 1656, 2584, 388, 16128, 12,
16324, 16144, 1616, 2600, 416, 16124, 12,
16328, 16136, 1576, 2616, 448, 16116, 12,
16332, 16128, 1536, 2632, 480, 16112, 12,
16340, 16120, 1496, 2648, 516, 16108, 12,
16344, 16112, 1456, 2660, 548, 16104, 12,
16348, 16104, 1416, 2672, 580, 16100, 12,
16352, 16100, 1376, 2684, 616, 16096, 12,
16356, 16096, 1336, 2696, 652, 16092, 12,
16360, 16092, 1296, 2704, 688, 16088, 12,
16364, 16088, 1256, 2712, 720, 16084, 12,
16368, 16084, 1220, 2720, 760, 16084, 8,
16368, 16080, 1180, 2724, 796, 16080, 8,
16372, 16080, 1140, 2732, 832, 16080, 8,
16376, 16076, 1100, 2732, 868, 16076, 4,
16380, 16076, 1060, 2736, 908, 16076, 4,
16380, 16076, 1020, 2740, 944, 16076, 0,
0, 16076, 984, 2740, 984, 16076, 0 };
const uint16_t filter_7tap_64p_183[231] = {
16216, 324, 1884, 1884, 324, 16216, 0,
16220, 304, 1864, 1904, 344, 16216, 0,
16224, 284, 1844, 1924, 364, 16216, 0,
16224, 264, 1824, 1944, 384, 16212, 16380,
16228, 248, 1804, 1960, 408, 16212, 16380,
16228, 228, 1784, 1976, 428, 16208, 16380,
16232, 212, 1760, 1996, 452, 16208, 16380,
16236, 192, 1740, 2012, 472, 16208, 16376,
16240, 176, 1716, 2028, 496, 16208, 16376,
16240, 160, 1696, 2040, 516, 16208, 16376,
16244, 144, 1672, 2056, 540, 16208, 16376,
16248, 128, 1648, 2068, 564, 16208, 16372,
16252, 112, 1624, 2084, 588, 16208, 16372,
16256, 96, 1600, 2096, 612, 16208, 16368,
16256, 84, 1576, 2108, 636, 16208, 16368,
16260, 68, 1552, 2120, 660, 16208, 16368,
16264, 56, 1524, 2132, 684, 16212, 16364,
16268, 40, 1500, 2140, 712, 16212, 16364,
16272, 28, 1476, 2152, 736, 16216, 16360,
16276, 16, 1448, 2160, 760, 16216, 16356,
16280, 4, 1424, 2168, 788, 16220, 16356,
16284, 16376, 1396, 2176, 812, 16224, 16352,
16288, 16368, 1372, 2184, 840, 16224, 16352,
16292, 16356, 1344, 2188, 864, 16228, 16348,
16292, 16344, 1320, 2196, 892, 16232, 16344,
16296, 16336, 1292, 2200, 916, 16236, 16344,
16300, 16324, 1264, 2204, 944, 16240, 16340,
16304, 16316, 1240, 2208, 972, 16248, 16336,
16308, 16308, 1212, 2212, 996, 16252, 16332,
16312, 16300, 1184, 2216, 1024, 16256, 16332,
16316, 16292, 1160, 2216, 1052, 16264, 16328,
16316, 16284, 1132, 2216, 1076, 16268, 16324,
16320, 16276, 1104, 2216, 1104, 16276, 16320 };
const uint16_t filter_8tap_64p_upscale[264] = {
0, 0, 0, 4096, 0, 0, 0, 0,
16376, 20, 16328, 4092, 56, 16364, 4, 0,
16372, 36, 16272, 4088, 116, 16340, 12, 0,
16364, 56, 16220, 4080, 180, 16320, 20, 0,
16360, 76, 16172, 4064, 244, 16296, 24, 16380,
16356, 92, 16124, 4048, 312, 16276, 32, 16380,
16352, 108, 16080, 4032, 380, 16252, 40, 16380,
16344, 124, 16036, 4008, 452, 16228, 48, 16380,
16340, 136, 15996, 3980, 524, 16204, 56, 16380,
16340, 152, 15956, 3952, 600, 16180, 64, 16376,
16336, 164, 15920, 3920, 672, 16156, 76, 16376,
16332, 176, 15888, 3884, 752, 16132, 84, 16376,
16328, 188, 15860, 3844, 828, 16104, 92, 16372,
16328, 200, 15828, 3800, 908, 16080, 100, 16372,
16324, 208, 15804, 3756, 992, 16056, 108, 16372,
16324, 216, 15780, 3708, 1072, 16032, 120, 16368,
16320, 224, 15760, 3656, 1156, 16008, 128, 16368,
16320, 232, 15740, 3604, 1240, 15984, 136, 16364,
16320, 240, 15724, 3548, 1324, 15960, 144, 16364,
16320, 244, 15708, 3488, 1412, 15936, 152, 16360,
16320, 248, 15696, 3428, 1496, 15912, 160, 16360,
16320, 252, 15688, 3364, 1584, 15892, 172, 16356,
16320, 256, 15680, 3296, 1672, 15868, 180, 16352,
16320, 256, 15672, 3228, 1756, 15848, 188, 16352,
16320, 256, 15668, 3156, 1844, 15828, 192, 16348,
16320, 260, 15668, 3084, 1932, 15808, 200, 16348,
16320, 256, 15668, 3012, 2020, 15792, 208, 16344,
16324, 256, 15668, 2936, 2108, 15772, 216, 16344,
16324, 256, 15672, 2856, 2192, 15756, 220, 16340,
16324, 252, 15676, 2776, 2280, 15740, 228, 16336,
16328, 252, 15684, 2696, 2364, 15728, 232, 16336,
16328, 248, 15692, 2616, 2448, 15716, 240, 16332,
16332, 244, 15704, 2532, 2532, 15704, 244, 16332 };
const uint16_t filter_8tap_64p_117[264] = {
116, 16100, 428, 3564, 428, 16100, 116, 0,
112, 16116, 376, 3564, 484, 16084, 120, 16380,
104, 16136, 324, 3560, 540, 16064, 124, 16380,
100, 16152, 272, 3556, 600, 16048, 128, 16380,
96, 16168, 220, 3548, 656, 16032, 136, 16376,
88, 16188, 172, 3540, 716, 16016, 140, 16376,
84, 16204, 124, 3528, 780, 16000, 144, 16376,
80, 16220, 76, 3512, 840, 15984, 148, 16372,
76, 16236, 32, 3496, 904, 15968, 152, 16372,
68, 16252, 16376, 3480, 968, 15952, 156, 16372,
64, 16268, 16332, 3456, 1032, 15936, 160, 16372,
60, 16284, 16292, 3432, 1096, 15920, 164, 16368,
56, 16300, 16252, 3408, 1164, 15908, 164, 16368,
48, 16316, 16216, 3380, 1228, 15892, 168, 16368,
44, 16332, 16180, 3348, 1296, 15880, 168, 16368,
40, 16348, 16148, 3316, 1364, 15868, 172, 16364,
36, 16360, 16116, 3284, 1428, 15856, 172, 16364,
32, 16376, 16084, 3248, 1496, 15848, 176, 16364,
28, 4, 16052, 3208, 1564, 15836, 176, 16364,
24, 16, 16028, 3168, 1632, 15828, 176, 16364,
20, 28, 16000, 3124, 1700, 15820, 176, 16364,
16, 40, 15976, 3080, 1768, 15812, 176, 16364,
12, 52, 15952, 3036, 1836, 15808, 176, 16364,
8, 64, 15932, 2988, 1904, 15800, 176, 16364,
4, 76, 15912, 2940, 1972, 15800, 172, 16364,
4, 84, 15892, 2888, 2040, 15796, 172, 16364,
0, 96, 15876, 2836, 2104, 15792, 168, 16364,
16380, 104, 15864, 2780, 2172, 15792, 164, 16364,
16380, 112, 15848, 2724, 2236, 15792, 160, 16364,
16376, 120, 15836, 2668, 2300, 15796, 156, 16368,
16376, 128, 15828, 2608, 2364, 15800, 152, 16368,
16372, 136, 15816, 2548, 2428, 15804, 148, 16368,
16372, 140, 15812, 2488, 2488, 15812, 140, 16372 };
const uint16_t filter_8tap_64p_150[264] = {
16380, 16020, 1032, 2756, 1032, 16020, 16380, 0,
0, 16020, 992, 2756, 1068, 16024, 16376, 0,
4, 16020, 952, 2752, 1108, 16024, 16372, 0,
8, 16020, 916, 2748, 1148, 16028, 16368, 0,
12, 16020, 876, 2744, 1184, 16032, 16364, 4,
16, 16020, 840, 2740, 1224, 16036, 16356, 4,
20, 16024, 800, 2732, 1264, 16040, 16352, 4,
20, 16024, 764, 2724, 1304, 16044, 16348, 8,
24, 16028, 728, 2716, 1344, 16052, 16340, 8,
28, 16028, 692, 2704, 1380, 16056, 16336, 12,
28, 16032, 656, 2696, 1420, 16064, 16328, 12,
32, 16036, 620, 2684, 1460, 16072, 16324, 12,
36, 16040, 584, 2668, 1500, 16080, 16316, 16,
36, 16044, 548, 2656, 1536, 16088, 16308, 16,
36, 16048, 516, 2640, 1576, 16096, 16304, 20,
40, 16052, 480, 2624, 1612, 16108, 16296, 20,
40, 16060, 448, 2608, 1652, 16120, 16288, 20,
44, 16064, 416, 2588, 1692, 16132, 16280, 24,
44, 16068, 384, 2568, 1728, 16144, 16276, 24,
44, 16076, 352, 2548, 1764, 16156, 16268, 28,
44, 16080, 320, 2528, 1804, 16168, 16260, 28,
44, 16088, 292, 2508, 1840, 16184, 16252, 28,
44, 16096, 264, 2484, 1876, 16200, 16244, 32,
48, 16100, 232, 2460, 1912, 16216, 16236, 32,
48, 16108, 204, 2436, 1948, 16232, 16228, 32,
48, 16116, 176, 2412, 1980, 16248, 16220, 36,
48, 16124, 152, 2384, 2016, 16264, 16216, 36,
44, 16128, 124, 2356, 2052, 16284, 16208, 36,
44, 16136, 100, 2328, 2084, 16304, 16200, 40,
44, 16144, 72, 2300, 2116, 16324, 16192, 40,
44, 16152, 48, 2272, 2148, 16344, 16184, 40,
44, 16160, 24, 2244, 2180, 16364, 16176, 40,
44, 16168, 4, 2212, 2212, 4, 16168, 44 };
const uint16_t filter_8tap_64p_183[264] = {
16264, 16264, 1164, 2244, 1164, 16264, 16264, 0,
16268, 16256, 1136, 2240, 1188, 16272, 16260, 0,
16272, 16248, 1108, 2240, 1216, 16280, 16256, 0,
16276, 16240, 1080, 2236, 1240, 16292, 16252, 0,
16280, 16232, 1056, 2236, 1268, 16300, 16248, 0,
16284, 16224, 1028, 2232, 1292, 16312, 16244, 0,
16288, 16216, 1000, 2228, 1320, 16324, 16240, 0,
16292, 16212, 976, 2224, 1344, 16336, 16236, 0,
16296, 16204, 948, 2220, 1372, 16348, 16232, 0,
16300, 16200, 920, 2212, 1396, 16360, 16228, 4,
16304, 16196, 896, 2204, 1424, 16372, 16224, 4,
16308, 16188, 868, 2200, 1448, 0, 16220, 4,
16312, 16184, 844, 2192, 1472, 12, 16216, 4,
16316, 16180, 816, 2184, 1500, 28, 16212, 4,
16320, 16176, 792, 2172, 1524, 40, 16208, 4,
16324, 16172, 764, 2164, 1548, 56, 16204, 0,
16328, 16172, 740, 2156, 1572, 72, 16200, 0,
16328, 16168, 712, 2144, 1596, 88, 16196, 0,
16332, 16164, 688, 2132, 1620, 100, 16192, 0,
16336, 16164, 664, 2120, 1644, 120, 16192, 0,
16340, 16160, 640, 2108, 1668, 136, 16188, 0,
16344, 16160, 616, 2096, 1688, 152, 16184, 0,
16344, 16160, 592, 2080, 1712, 168, 16180, 0,
16348, 16156, 568, 2068, 1736, 188, 16176, 16380,
16352, 16156, 544, 2052, 1756, 204, 16176, 16380,
16352, 16156, 520, 2036, 1780, 224, 16172, 16380,
16356, 16156, 496, 2024, 1800, 244, 16172, 16380,
16360, 16156, 472, 2008, 1820, 260, 16168, 16376,
16360, 16156, 452, 1988, 1840, 280, 16164, 16376,
16364, 16156, 428, 1972, 1860, 300, 16164, 16376,
16364, 16156, 408, 1956, 1880, 320, 16164, 16372,
16368, 16160, 384, 1936, 1900, 344, 16160, 16372,
16368, 16160, 364, 1920, 1920, 364, 16160, 16368 };
const uint16_t *get_filter_3tap_16p(struct fixed31_32 ratio) const uint16_t *get_filter_3tap_16p(struct fixed31_32 ratio)
{ {
if (ratio.value < dal_fixed31_32_one.value) if (ratio.value < dal_fixed31_32_one.value)
...@@ -499,3 +1059,51 @@ const uint16_t *get_filter_4tap_64p(struct fixed31_32 ratio) ...@@ -499,3 +1059,51 @@ const uint16_t *get_filter_4tap_64p(struct fixed31_32 ratio)
else else
return filter_4tap_64p_183; return filter_4tap_64p_183;
} }
const uint16_t *get_filter_5tap_64p(struct fixed31_32 ratio)
{
if (ratio.value < dal_fixed31_32_one.value)
return filter_5tap_64p_upscale;
else if (ratio.value < dal_fixed31_32_from_fraction(4, 3).value)
return filter_5tap_64p_117;
else if (ratio.value < dal_fixed31_32_from_fraction(5, 3).value)
return filter_5tap_64p_150;
else
return filter_5tap_64p_183;
}
const uint16_t *get_filter_6tap_64p(struct fixed31_32 ratio)
{
if (ratio.value < dal_fixed31_32_one.value)
return filter_6tap_64p_upscale;
else if (ratio.value < dal_fixed31_32_from_fraction(4, 3).value)
return filter_6tap_64p_117;
else if (ratio.value < dal_fixed31_32_from_fraction(5, 3).value)
return filter_6tap_64p_150;
else
return filter_6tap_64p_183;
}
const uint16_t *get_filter_7tap_64p(struct fixed31_32 ratio)
{
if (ratio.value < dal_fixed31_32_one.value)
return filter_7tap_64p_upscale;
else if (ratio.value < dal_fixed31_32_from_fraction(4, 3).value)
return filter_7tap_64p_117;
else if (ratio.value < dal_fixed31_32_from_fraction(5, 3).value)
return filter_7tap_64p_150;
else
return filter_7tap_64p_183;
}
const uint16_t *get_filter_8tap_64p(struct fixed31_32 ratio)
{
if (ratio.value < dal_fixed31_32_one.value)
return filter_8tap_64p_upscale;
else if (ratio.value < dal_fixed31_32_from_fraction(4, 3).value)
return filter_8tap_64p_117;
else if (ratio.value < dal_fixed31_32_from_fraction(5, 3).value)
return filter_8tap_64p_150;
else
return filter_8tap_64p_183;
}
...@@ -186,5 +186,9 @@ const uint16_t *get_filter_3tap_16p(struct fixed31_32 ratio); ...@@ -186,5 +186,9 @@ const uint16_t *get_filter_3tap_16p(struct fixed31_32 ratio);
const uint16_t *get_filter_3tap_64p(struct fixed31_32 ratio); const uint16_t *get_filter_3tap_64p(struct fixed31_32 ratio);
const uint16_t *get_filter_4tap_16p(struct fixed31_32 ratio); const uint16_t *get_filter_4tap_16p(struct fixed31_32 ratio);
const uint16_t *get_filter_4tap_64p(struct fixed31_32 ratio); const uint16_t *get_filter_4tap_64p(struct fixed31_32 ratio);
const uint16_t *get_filter_5tap_64p(struct fixed31_32 ratio);
const uint16_t *get_filter_6tap_64p(struct fixed31_32 ratio);
const uint16_t *get_filter_7tap_64p(struct fixed31_32 ratio);
const uint16_t *get_filter_8tap_64p(struct fixed31_32 ratio);
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment