mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-20 20:59:34 +07:00
drm/amd/display: Remove unused color and power modules
Signed-off-by: Harry Wentland <harry.wentland@amd.com> Acked-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
649aa6f4fc
commit
84773406bb
File diff suppressed because it is too large
Load Diff
@ -1,210 +0,0 @@
|
||||
/*
|
||||
* Copyright 2016 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#include "dm_services.h"
|
||||
#include "dc.h"
|
||||
#include "mod_color.h"
|
||||
#include "color_helper.h"
|
||||
|
||||
const struct gamut_space_entry predefined_gamuts[] = {
|
||||
/* x_red y_red x_gr y_gr x_blue y_blue a0 a1 a2 a3 gamma */
|
||||
[gamut_type_bt709] = {6400, 3300, 3000, 6000, 1500, 600, 180000, 4500, 99, 99, 2200},
|
||||
[gamut_type_bt601] = {6400, 3300, 2900, 6000, 1500, 600, 180000, 4500, 99, 99, 2200},
|
||||
[gamut_type_adobe_rgb] = {6400, 3300, 2100, 7100, 1500, 600, 180000, 4500, 99, 99, 2200},
|
||||
[gamut_type_srgb] = {6400, 3300, 3000, 6000, 1500, 600, 31308, 12920, 55, 55, 2400},
|
||||
[gamut_type_bt2020] = {7080, 2920, 1700, 7970, 1310, 460, 180000, 4500, 99, 99, 2200}
|
||||
};
|
||||
|
||||
const struct white_point_coodinates_entry predefined_white_points[] = {
|
||||
[white_point_type_5000k_horizon] = {5000, 3473, 3561},
|
||||
[white_point_type_6500k_noon] = {6500, 3127, 3290},
|
||||
[white_point_type_7500k_north_sky] = {7500, 3022, 3129},
|
||||
[white_point_type_9300k] = {9300, 2866, 2950}
|
||||
};
|
||||
|
||||
const unsigned int white_point_entries = 91;
|
||||
|
||||
const struct white_point_coodinates_entry white_point_temps[] = {
|
||||
/*001*/{1000, 6499, 3474},
|
||||
/*002*/{1100, 6361, 3594},
|
||||
/*003*/{1200, 6226, 3703},
|
||||
/*004*/{1300, 6095, 3801},
|
||||
/*005*/{1400, 5966, 3887},
|
||||
/*006*/{1500, 5841, 3962},
|
||||
/*007*/{1600, 5720, 4025},
|
||||
/*008*/{1700, 5601, 4076},
|
||||
/*009*/{1800, 5486, 4118},
|
||||
/*010*/{1900, 5375, 4150},
|
||||
/*011*/{2000, 5267, 4173},
|
||||
/*012*/{2100, 5162, 4188},
|
||||
/*013*/{2200, 5062, 4196},
|
||||
/*014*/{2300, 4965, 4198},
|
||||
/*015*/{2400, 4872, 4194},
|
||||
/*016*/{2500, 4782, 4186},
|
||||
/*017*/{2600, 4696, 4173},
|
||||
/*018*/{2700, 4614, 4158},
|
||||
/*019*/{2800, 4535, 4139},
|
||||
/*020*/{2900, 4460, 4118},
|
||||
/*021*/{3000, 4388, 4095},
|
||||
/*022*/{3100, 4320, 4070},
|
||||
/*023*/{3200, 4254, 4044},
|
||||
/*024*/{3300, 4192, 4018},
|
||||
/*025*/{3400, 4132, 3990},
|
||||
/*026*/{3500, 4075, 3962},
|
||||
/*027*/{3600, 4021, 3934},
|
||||
/*028*/{3700, 3969, 3905},
|
||||
/*029*/{3800, 3919, 3877},
|
||||
/*030*/{3900, 3872, 3849},
|
||||
/*031*/{4000, 3827, 3820},
|
||||
/*032*/{4100, 3784, 3793},
|
||||
/*033*/{4200, 3743, 3765},
|
||||
/*034*/{4300, 3704, 3738},
|
||||
/*035*/{4400, 3666, 3711},
|
||||
/*036*/{4500, 3631, 3685},
|
||||
/*037*/{4600, 3596, 3659},
|
||||
/*038*/{4700, 3563, 3634},
|
||||
/*039*/{4800, 3532, 3609},
|
||||
/*040*/{4900, 3502, 3585},
|
||||
/*041*/{5000, 3473, 3561},
|
||||
/*042*/{5100, 3446, 3538},
|
||||
/*043*/{5200, 3419, 3516},
|
||||
/*044*/{5300, 3394, 3494},
|
||||
/*045*/{5400, 3369, 3472},
|
||||
/*046*/{5500, 3346, 3451},
|
||||
/*047*/{5600, 3323, 3431},
|
||||
/*048*/{5700, 3302, 3411},
|
||||
/*049*/{5800, 3281, 3392},
|
||||
/*050*/{5900, 3261, 3373},
|
||||
/*051*/{6000, 3242, 3355},
|
||||
/*052*/{6100, 3223, 3337},
|
||||
/*053*/{6200, 3205, 3319},
|
||||
/*054*/{6300, 3188, 3302},
|
||||
/*055*/{6400, 3161, 3296},
|
||||
/*056*/{6500, 3127, 3290}, /* This is the real white point sRGB */
|
||||
/*057*/{6600, 3126, 3264},
|
||||
/*058*/{6700, 3125, 3238},
|
||||
/*059*/{6800, 3110, 3224},
|
||||
/*060*/{6900, 3097, 3209},
|
||||
/*061*/{7000, 3083, 3195},
|
||||
/*062*/{7100, 3070, 3181},
|
||||
/*063*/{7200, 3058, 3168},
|
||||
/*064*/{7300, 3045, 3154},
|
||||
/*065*/{7400, 3034, 3142},
|
||||
/*066*/{7500, 3022, 3129},
|
||||
/*067*/{7600, 3011, 3117},
|
||||
/*068*/{7700, 3000, 3105},
|
||||
/*069*/{7800, 2990, 3094},
|
||||
/*070*/{7900, 2980, 3082},
|
||||
/*071*/{8000, 2970, 3071},
|
||||
/*072*/{8100, 2961, 3061},
|
||||
/*073*/{8200, 2952, 3050},
|
||||
/*074*/{8300, 2943, 3040},
|
||||
/*075*/{8400, 2934, 3030},
|
||||
/*076*/{8500, 2926, 3020},
|
||||
/*077*/{8600, 2917, 3011},
|
||||
/*078*/{8700, 2910, 3001},
|
||||
/*079*/{8800, 2902, 2992},
|
||||
/*080*/{8900, 2894, 2983},
|
||||
/*081*/{9000, 2887, 2975},
|
||||
/*082*/{9100, 2880, 2966},
|
||||
/*083*/{9200, 2873, 2958},
|
||||
/*084*/{9300, 2866, 2950},
|
||||
/*085*/{9400, 2860, 2942},
|
||||
/*086*/{9500, 2853, 2934},
|
||||
/*087*/{9600, 2847, 2927},
|
||||
/*088*/{9700, 2841, 2919},
|
||||
/*089*/{9800, 2835, 2912},
|
||||
/*090*/{9900, 2829, 2905},
|
||||
/*091*/{10000, 2824, 2898}
|
||||
};
|
||||
|
||||
bool mod_color_find_predefined_gamut(
|
||||
struct gamut_space_coordinates *out_gamut,
|
||||
enum predefined_gamut_type type)
|
||||
{
|
||||
out_gamut->redX = predefined_gamuts[type].redX;
|
||||
out_gamut->redY = predefined_gamuts[type].redY;
|
||||
out_gamut->greenX = predefined_gamuts[type].greenX;
|
||||
out_gamut->greenY = predefined_gamuts[type].greenY;
|
||||
out_gamut->blueX = predefined_gamuts[type].blueX;
|
||||
out_gamut->blueY = predefined_gamuts[type].blueY;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_color_find_predefined_white_point(
|
||||
struct white_point_coodinates *out_white_point,
|
||||
enum predefined_white_point_type type)
|
||||
{
|
||||
out_white_point->whiteX = predefined_white_points[type].whiteX;
|
||||
out_white_point->whiteY = predefined_white_points[type].whiteY;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_color_find_white_point_from_temperature(
|
||||
struct white_point_coodinates *out_white_point,
|
||||
unsigned int temperature)
|
||||
{
|
||||
int i;
|
||||
unsigned int found = false;
|
||||
struct white_point_coodinates_entry temp_white_point =
|
||||
white_point_temps[55];
|
||||
|
||||
if (temperature < 1000 || temperature > 10000)
|
||||
return false;
|
||||
|
||||
for (i = 0; i < white_point_entries; i++) {
|
||||
if (temperature == white_point_temps[i].temperature) {
|
||||
temp_white_point = white_point_temps[i];
|
||||
found = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
out_white_point->whiteX = temp_white_point.whiteX;
|
||||
out_white_point->whiteY = temp_white_point.whiteY;
|
||||
|
||||
return found;
|
||||
}
|
||||
|
||||
bool mod_color_find_temperature_from_white_point(
|
||||
struct white_point_coodinates *in_white_point,
|
||||
unsigned int *out_temperature)
|
||||
{
|
||||
unsigned int i;
|
||||
*out_temperature = 6500;
|
||||
|
||||
for (i = 0; i < white_point_entries; i++) {
|
||||
if (in_white_point->whiteX == white_point_temps[i].whiteX &&
|
||||
in_white_point->whiteY == white_point_temps[i].whiteY) {
|
||||
*out_temperature = white_point_temps[i].temperature;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
@ -1,62 +0,0 @@
|
||||
/*
|
||||
* Copyright 2016 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef COLOR_MOD_COLOR_HELPER_H_
|
||||
#define COLOR_MOD_COLOR_HELPER_H_
|
||||
|
||||
enum predefined_gamut_type {
|
||||
gamut_type_bt709,
|
||||
gamut_type_bt601,
|
||||
gamut_type_adobe_rgb,
|
||||
gamut_type_srgb,
|
||||
gamut_type_bt2020,
|
||||
gamut_type_unknown,
|
||||
};
|
||||
|
||||
enum predefined_white_point_type {
|
||||
white_point_type_5000k_horizon,
|
||||
white_point_type_6500k_noon,
|
||||
white_point_type_7500k_north_sky,
|
||||
white_point_type_9300k,
|
||||
white_point_type_unknown,
|
||||
};
|
||||
|
||||
bool mod_color_find_predefined_gamut(
|
||||
struct gamut_space_coordinates *out_gamut,
|
||||
enum predefined_gamut_type type);
|
||||
|
||||
bool mod_color_find_predefined_white_point(
|
||||
struct white_point_coodinates *out_white_point,
|
||||
enum predefined_white_point_type type);
|
||||
|
||||
bool mod_color_find_white_point_from_temperature(
|
||||
struct white_point_coodinates *out_white_point,
|
||||
unsigned int temperature);
|
||||
|
||||
bool mod_color_find_temperature_from_white_point(
|
||||
struct white_point_coodinates *in_white_point,
|
||||
unsigned int *out_temperature);
|
||||
|
||||
#endif /* COLOR_MOD_COLOR_HELPER_H_ */
|
@ -1,282 +0,0 @@
|
||||
/*
|
||||
* Copyright 2016 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
#ifndef MOD_COLOR_H_
|
||||
#define MOD_COLOR_H_
|
||||
|
||||
#include "dm_services.h"
|
||||
#include "color_helper.h"
|
||||
|
||||
enum color_transfer_func {
|
||||
transfer_func_unknown,
|
||||
transfer_func_srgb,
|
||||
transfer_func_bt709,
|
||||
transfer_func_pq2084,
|
||||
transfer_func_pq2084_interim,
|
||||
transfer_func_linear_0_1,
|
||||
transfer_func_linear_0_125,
|
||||
transfer_func_dolbyvision,
|
||||
transfer_func_gamma_22,
|
||||
transfer_func_gamma_26
|
||||
};
|
||||
|
||||
enum color_color_space {
|
||||
color_space_unsupported,
|
||||
color_space_srgb,
|
||||
color_space_bt601,
|
||||
color_space_bt709,
|
||||
color_space_xv_ycc_bt601,
|
||||
color_space_xv_ycc_bt709,
|
||||
color_space_xr_rgb,
|
||||
color_space_bt2020,
|
||||
color_space_adobe,
|
||||
color_space_dci_p3,
|
||||
color_space_sc_rgb_ms_ref,
|
||||
color_space_display_native,
|
||||
color_space_app_ctrl,
|
||||
color_space_dolby_vision,
|
||||
color_space_custom_coordinates
|
||||
};
|
||||
|
||||
enum color_white_point_type {
|
||||
color_white_point_type_unknown,
|
||||
color_white_point_type_5000k_horizon,
|
||||
color_white_point_type_6500k_noon,
|
||||
color_white_point_type_7500k_north_sky,
|
||||
color_white_point_type_9300k,
|
||||
color_white_point_type_custom_coordinates
|
||||
};
|
||||
|
||||
enum colorimetry_support_flag {
|
||||
xv_ycc_bt601 = 0x01,
|
||||
xv_ycc_bt709 = 0x02,
|
||||
s_ycc_601 = 0x04,
|
||||
adobe_ycc_601 = 0x08,
|
||||
adobe_rgb = 0x10,
|
||||
bt_2020_c_ycc = 0x20,
|
||||
bt_2020_ycc = 0x40,
|
||||
bt_2020_rgb = 0x80
|
||||
};
|
||||
|
||||
enum hdr_tf_support_flag {
|
||||
traditional_gamma_sdr = 0x01,
|
||||
traditional_gamma_hdr = 0x02,
|
||||
smpte_st2084 = 0x04
|
||||
};
|
||||
|
||||
struct mod_color {
|
||||
int dummy;
|
||||
};
|
||||
|
||||
struct color_space_coordinates {
|
||||
unsigned int redX;
|
||||
unsigned int redY;
|
||||
unsigned int greenX;
|
||||
unsigned int greenY;
|
||||
unsigned int blueX;
|
||||
unsigned int blueY;
|
||||
unsigned int whiteX;
|
||||
unsigned int whiteY;
|
||||
};
|
||||
|
||||
struct gamut_space_coordinates {
|
||||
unsigned int redX;
|
||||
unsigned int redY;
|
||||
unsigned int greenX;
|
||||
unsigned int greenY;
|
||||
unsigned int blueX;
|
||||
unsigned int blueY;
|
||||
};
|
||||
|
||||
struct gamut_space_entry {
|
||||
unsigned int redX;
|
||||
unsigned int redY;
|
||||
unsigned int greenX;
|
||||
unsigned int greenY;
|
||||
unsigned int blueX;
|
||||
unsigned int blueY;
|
||||
|
||||
int a0;
|
||||
int a1;
|
||||
int a2;
|
||||
int a3;
|
||||
int gamma;
|
||||
};
|
||||
|
||||
struct white_point_coodinates {
|
||||
unsigned int whiteX;
|
||||
unsigned int whiteY;
|
||||
};
|
||||
|
||||
struct white_point_coodinates_entry {
|
||||
unsigned int temperature;
|
||||
unsigned int whiteX;
|
||||
unsigned int whiteY;
|
||||
};
|
||||
|
||||
struct color_range {
|
||||
int current;
|
||||
int min;
|
||||
int max;
|
||||
};
|
||||
|
||||
struct color_gamut_data {
|
||||
enum color_color_space color_space;
|
||||
enum color_white_point_type white_point;
|
||||
struct color_space_coordinates gamut;
|
||||
};
|
||||
|
||||
struct color_edid_caps {
|
||||
unsigned int colorimetry_caps;
|
||||
unsigned int hdr_caps;
|
||||
};
|
||||
|
||||
struct mod_color *mod_color_create(struct dc *dc);
|
||||
|
||||
void mod_color_destroy(struct mod_color *mod_color);
|
||||
|
||||
bool mod_color_add_sink(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink, struct color_edid_caps *edid_caps);
|
||||
|
||||
bool mod_color_remove_sink(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink);
|
||||
|
||||
bool mod_color_update_gamut_to_stream(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams);
|
||||
|
||||
bool mod_color_set_white_point(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
struct white_point_coodinates *white_point);
|
||||
|
||||
bool mod_color_adjust_source_gamut(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
struct color_gamut_data *input_gamut_data);
|
||||
|
||||
bool mod_color_adjust_destination_gamut(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
struct color_gamut_data *input_gamut_data);
|
||||
|
||||
bool mod_color_adjust_source_gamut_and_tf(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
struct color_gamut_data *input_gamut_data,
|
||||
enum color_transfer_func input_transfer_func);
|
||||
|
||||
bool mod_color_get_user_enable(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
bool *user_enable);
|
||||
|
||||
bool mod_color_set_mastering_info(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
const struct dc_hdr_static_metadata *mastering_info);
|
||||
|
||||
bool mod_color_get_mastering_info(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct dc_hdr_static_metadata *mastering_info);
|
||||
|
||||
bool mod_color_set_user_enable(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
bool user_enable);
|
||||
|
||||
bool mod_color_get_custom_color_temperature(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
int *color_temperature);
|
||||
|
||||
bool mod_color_set_custom_color_temperature(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
int color_temperature);
|
||||
|
||||
bool mod_color_get_color_saturation(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct color_range *color_saturation);
|
||||
|
||||
bool mod_color_get_color_contrast(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct color_range *color_contrast);
|
||||
|
||||
bool mod_color_get_color_brightness(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct color_range *color_brightness);
|
||||
|
||||
bool mod_color_get_color_hue(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct color_range *color_hue);
|
||||
|
||||
bool mod_color_get_source_gamut(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
struct color_space_coordinates *source_gamut);
|
||||
|
||||
bool mod_color_notify_mode_change(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams);
|
||||
|
||||
bool mod_color_set_brightness(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
int brightness_value);
|
||||
|
||||
bool mod_color_set_contrast(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
int contrast_value);
|
||||
|
||||
bool mod_color_set_hue(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
int hue_value);
|
||||
|
||||
bool mod_color_set_saturation(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
int saturation_value);
|
||||
|
||||
bool mod_color_set_input_gamma_correction(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
struct dc_gamma *gamma);
|
||||
|
||||
bool mod_color_persist_user_preferred_quantization_range(
|
||||
struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
enum dc_quantization_range quantization_range);
|
||||
|
||||
bool mod_color_get_preferred_quantization_range(struct mod_color *mod_color,
|
||||
const struct dc_sink *sink,
|
||||
const struct dc_crtc_timing *timing,
|
||||
enum dc_quantization_range *quantization_range);
|
||||
|
||||
bool mod_color_is_rgb_full_range_supported_for_timing(
|
||||
const struct dc_sink *sink,
|
||||
const struct dc_crtc_timing *timing);
|
||||
|
||||
bool mod_color_is_rgb_limited_range_supported_for_timing(
|
||||
const struct dc_sink *sink,
|
||||
const struct dc_crtc_timing *timing);
|
||||
|
||||
bool mod_color_set_regamma(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams);
|
||||
|
||||
bool mod_color_set_degamma(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
enum color_transfer_func transfer_function);
|
||||
|
||||
bool mod_color_update_gamut_info(struct mod_color *mod_color,
|
||||
const struct dc_stream **streams, int num_streams);
|
||||
|
||||
#endif /* MOD_COLOR_H_ */
|
@ -1,112 +0,0 @@
|
||||
/*
|
||||
* Copyright 2016 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef MODULES_INC_MOD_POWER_H_
|
||||
#define MODULES_INC_MOD_POWER_H_
|
||||
|
||||
#include "dm_services.h"
|
||||
|
||||
struct mod_power {
|
||||
int dummy;
|
||||
};
|
||||
|
||||
/* VariBright related commands */
|
||||
enum varibright_command {
|
||||
VariBright_Cmd__SetVBLevel = 0,
|
||||
VariBright_Cmd__UserEnable,
|
||||
VariBright_Cmd__PreDisplayConfigChange,
|
||||
VariBright_Cmd__PostDisplayConfigChange,
|
||||
VariBright_Cmd__SuspendABM,
|
||||
VariBright_Cmd__ResumeABM,
|
||||
|
||||
VariBright_Cmd__Unknown,
|
||||
};
|
||||
|
||||
/* VariBright settings structure */
|
||||
struct varibright_info {
|
||||
enum varibright_command cmd;
|
||||
|
||||
unsigned int level;
|
||||
bool enable;
|
||||
bool activate;
|
||||
};
|
||||
|
||||
enum dmcu_block_psr_reason {
|
||||
/* This is a bitfield mask */
|
||||
dmcu_block_psr_reason_invalid = 0x0,
|
||||
dmcu_block_psr_reason_vsync_int = 0x1,
|
||||
dmcu_block_psr_reason_shared_primary = 0x2,
|
||||
dmcu_block_psr_reason_unsupported_link_rate = 0x4
|
||||
};
|
||||
|
||||
struct mod_power *mod_power_create(struct dc *dc);
|
||||
|
||||
void mod_power_destroy(struct mod_power *mod_power);
|
||||
|
||||
bool mod_power_add_sink(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink);
|
||||
|
||||
bool mod_power_remove_sink(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink);
|
||||
|
||||
bool mod_power_set_backlight(struct mod_power *mod_power,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
unsigned int backlight_8bit);
|
||||
|
||||
bool mod_power_get_backlight(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink,
|
||||
unsigned int *backlight_8bit);
|
||||
|
||||
void mod_power_initialize_backlight_caps
|
||||
(struct mod_power *mod_power);
|
||||
|
||||
unsigned int mod_power_backlight_level_percentage_to_signal
|
||||
(struct mod_power *mod_power, unsigned int percentage);
|
||||
|
||||
unsigned int mod_power_backlight_level_signal_to_percentage
|
||||
(struct mod_power *mod_power, unsigned int signalLevel8bit);
|
||||
|
||||
bool mod_power_get_panel_backlight_boundaries
|
||||
(struct mod_power *mod_power,
|
||||
unsigned int *min_backlight,
|
||||
unsigned int *max_backlight,
|
||||
unsigned int *output_ac_level_percentage,
|
||||
unsigned int *output_dc_level_percentage);
|
||||
|
||||
bool mod_power_set_smooth_brightness(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink, bool enable_brightness);
|
||||
|
||||
bool mod_power_notify_mode_change(struct mod_power *mod_power,
|
||||
const struct dc_stream *stream);
|
||||
|
||||
bool mod_power_varibright_control(struct mod_power *mod_power,
|
||||
struct varibright_info *input_varibright_info);
|
||||
|
||||
bool mod_power_block_psr(bool block_enable, enum dmcu_block_psr_reason reason);
|
||||
|
||||
bool mod_power_set_psr_enable(struct mod_power *mod_power,
|
||||
bool psr_enable);
|
||||
|
||||
#endif /* MODULES_INC_MOD_POWER_H_ */
|
@ -1,784 +0,0 @@
|
||||
/*
|
||||
* Copyright 2016 Advanced Micro Devices, Inc.
|
||||
*
|
||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
||||
* copy of this software and associated documentation files (the "Software"),
|
||||
* to deal in the Software without restriction, including without limitation
|
||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||
* and/or sell copies of the Software, and to permit persons to whom the
|
||||
* Software is furnished to do so, subject to the following conditions:
|
||||
*
|
||||
* The above copyright notice and this permission notice shall be included in
|
||||
* all copies or substantial portions of the Software.
|
||||
*
|
||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
||||
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
||||
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
||||
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||
* OTHER DEALINGS IN THE SOFTWARE.
|
||||
*
|
||||
* Authors: AMD
|
||||
*
|
||||
*/
|
||||
|
||||
#include "mod_power.h"
|
||||
#include "dm_services.h"
|
||||
#include "dc.h"
|
||||
#include "core_types.h"
|
||||
#include "core_dc.h"
|
||||
|
||||
#define MOD_POWER_MAX_CONCURRENT_SINKS 32
|
||||
#define SMOOTH_BRIGHTNESS_ADJUSTMENT_TIME_IN_MS 500
|
||||
|
||||
struct sink_caps {
|
||||
const struct dc_sink *sink;
|
||||
};
|
||||
|
||||
struct backlight_state {
|
||||
unsigned int backlight;
|
||||
unsigned int frame_ramp;
|
||||
bool smooth_brightness_enabled;
|
||||
};
|
||||
|
||||
struct core_power {
|
||||
struct mod_power public;
|
||||
struct dc *dc;
|
||||
int num_sinks;
|
||||
struct sink_caps *caps;
|
||||
struct backlight_state *state;
|
||||
};
|
||||
|
||||
union dmcu_abm_set_bl_params {
|
||||
struct {
|
||||
unsigned int gradual_change : 1; /* [0:0] */
|
||||
unsigned int reserved : 15; /* [15:1] */
|
||||
unsigned int frame_ramp : 16; /* [31:16] */
|
||||
} bits;
|
||||
unsigned int u32All;
|
||||
};
|
||||
|
||||
/* Backlight cached properties */
|
||||
static unsigned int backlight_8bit_lut_array[101];
|
||||
static unsigned int ac_level_percentage;
|
||||
static unsigned int dc_level_percentage;
|
||||
static bool backlight_caps_valid;
|
||||
/* we use lazy initialization of backlight capabilities cache */
|
||||
static bool backlight_caps_initialized;
|
||||
/* AC/DC levels initialized later in separate context */
|
||||
static bool backlight_def_levels_valid;
|
||||
|
||||
/* ABM cached properties */
|
||||
static unsigned int abm_level;
|
||||
static bool abm_user_enable;
|
||||
static bool abm_active;
|
||||
|
||||
/*PSR cached properties*/
|
||||
static unsigned int block_psr;
|
||||
|
||||
/* Defines default backlight curve F(x) = A(x*x) + Bx + C.
|
||||
*
|
||||
* Backlight curve should always satisfy F(0) = min, F(100) = max,
|
||||
* so polynom coefficients are:
|
||||
* A is 0.0255 - B/100 - min/10000 - (255-max)/10000 = (max - min)/10000 - B/100
|
||||
* B is adjustable factor to modify the curve.
|
||||
* Bigger B results in less concave curve. B range is [0..(max-min)/100]
|
||||
* C is backlight minimum
|
||||
*/
|
||||
static const unsigned int backlight_curve_coeff_a_factor = 10000;
|
||||
static const unsigned int backlight_curve_coeff_b = 100;
|
||||
static const unsigned int backlight_curve_coeff_b_factor = 100;
|
||||
|
||||
/* Minimum and maximum backlight input signal levels */
|
||||
static const unsigned int default_min_backlight = 12;
|
||||
static const unsigned int default_max_backlight = 255;
|
||||
|
||||
/* Other backlight constants */
|
||||
static const unsigned int absolute_backlight_max = 255;
|
||||
|
||||
#define MOD_POWER_TO_CORE(mod_power)\
|
||||
container_of(mod_power, struct core_power, public)
|
||||
|
||||
static bool check_dc_support(const struct dc *dc)
|
||||
{
|
||||
if (dc->stream_funcs.set_backlight == NULL)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/* Given a specific dc_sink* this function finds its equivalent
|
||||
* on the dc_sink array and returns the corresponding index
|
||||
*/
|
||||
static unsigned int sink_index_from_sink(struct core_power *core_power,
|
||||
const struct dc_sink *sink)
|
||||
{
|
||||
unsigned int index = 0;
|
||||
|
||||
for (index = 0; index < core_power->num_sinks; index++)
|
||||
if (core_power->caps[index].sink == sink)
|
||||
return index;
|
||||
|
||||
/* Could not find sink requested */
|
||||
ASSERT(false);
|
||||
return index;
|
||||
}
|
||||
|
||||
static unsigned int convertBL8to17(unsigned int backlight_8bit)
|
||||
{
|
||||
unsigned int temp_ulong = backlight_8bit * 0x10101;
|
||||
unsigned char temp_uchar =
|
||||
(unsigned char)(((temp_ulong & 0x80) >> 7) & 1);
|
||||
|
||||
temp_ulong = (temp_ulong >> 8) + temp_uchar;
|
||||
|
||||
return temp_ulong;
|
||||
}
|
||||
|
||||
static uint16_t convertBL8to16(unsigned int backlight_8bit)
|
||||
{
|
||||
return (uint16_t)((backlight_8bit * 0x10101) >> 8);
|
||||
}
|
||||
|
||||
/*This is used when OS wants to retrieve the current BL.
|
||||
* We return the 8bit value to OS.
|
||||
*/
|
||||
static unsigned int convertBL17to8(unsigned int backlight_17bit)
|
||||
{
|
||||
if (backlight_17bit & 0x10000)
|
||||
return default_max_backlight;
|
||||
else
|
||||
return (backlight_17bit >> 8);
|
||||
}
|
||||
|
||||
struct mod_power *mod_power_create(struct dc *dc)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
dm_alloc(sizeof(struct core_power));
|
||||
|
||||
struct core_dc *core_dc = DC_TO_CORE(dc);
|
||||
|
||||
int i = 0;
|
||||
|
||||
if (core_power == NULL)
|
||||
goto fail_alloc_context;
|
||||
|
||||
core_power->caps = dm_alloc(sizeof(struct sink_caps) *
|
||||
MOD_POWER_MAX_CONCURRENT_SINKS);
|
||||
|
||||
if (core_power->caps == NULL)
|
||||
goto fail_alloc_caps;
|
||||
|
||||
for (i = 0; i < MOD_POWER_MAX_CONCURRENT_SINKS; i++)
|
||||
core_power->caps[i].sink = NULL;
|
||||
|
||||
core_power->state = dm_alloc(sizeof(struct backlight_state) *
|
||||
MOD_POWER_MAX_CONCURRENT_SINKS);
|
||||
|
||||
if (core_power->state == NULL)
|
||||
goto fail_alloc_state;
|
||||
|
||||
core_power->num_sinks = 0;
|
||||
backlight_caps_valid = false;
|
||||
|
||||
if (dc == NULL)
|
||||
goto fail_construct;
|
||||
|
||||
core_power->dc = dc;
|
||||
|
||||
if (!check_dc_support(dc))
|
||||
goto fail_construct;
|
||||
|
||||
abm_user_enable = false;
|
||||
abm_active = false;
|
||||
|
||||
return &core_power->public;
|
||||
|
||||
fail_construct:
|
||||
dm_free(core_power->state);
|
||||
|
||||
fail_alloc_state:
|
||||
dm_free(core_power->caps);
|
||||
|
||||
fail_alloc_caps:
|
||||
dm_free(core_power);
|
||||
|
||||
fail_alloc_context:
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
void mod_power_destroy(struct mod_power *mod_power)
|
||||
{
|
||||
if (mod_power != NULL) {
|
||||
int i;
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
dm_free(core_power->state);
|
||||
|
||||
for (i = 0; i < core_power->num_sinks; i++)
|
||||
dc_sink_release(core_power->caps[i].sink);
|
||||
|
||||
dm_free(core_power->caps);
|
||||
|
||||
dm_free(core_power);
|
||||
}
|
||||
}
|
||||
|
||||
bool mod_power_add_sink(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink)
|
||||
{
|
||||
if (sink->sink_signal == SIGNAL_TYPE_VIRTUAL)
|
||||
return false;
|
||||
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
struct core_dc *core_dc = DC_TO_CORE(core_power->dc);
|
||||
|
||||
if (core_power->num_sinks < MOD_POWER_MAX_CONCURRENT_SINKS) {
|
||||
dc_sink_retain(sink);
|
||||
core_power->caps[core_power->num_sinks].sink = sink;
|
||||
core_power->state[core_power->num_sinks].
|
||||
smooth_brightness_enabled = false;
|
||||
core_power->state[core_power->num_sinks].
|
||||
backlight = 100;
|
||||
core_power->num_sinks++;
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool mod_power_remove_sink(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink)
|
||||
{
|
||||
int i = 0, j = 0;
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
for (i = 0; i < core_power->num_sinks; i++) {
|
||||
if (core_power->caps[i].sink == sink) {
|
||||
/* To remove this sink, shift everything after down */
|
||||
for (j = i; j < core_power->num_sinks - 1; j++) {
|
||||
core_power->caps[j].sink =
|
||||
core_power->caps[j + 1].sink;
|
||||
|
||||
memcpy(&core_power->state[j],
|
||||
&core_power->state[j + 1],
|
||||
sizeof(struct backlight_state));
|
||||
}
|
||||
core_power->num_sinks--;
|
||||
dc_sink_release(sink);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool mod_power_set_backlight(struct mod_power *mod_power,
|
||||
const struct dc_stream **streams, int num_streams,
|
||||
unsigned int backlight_8bit)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
unsigned int frame_ramp = 0;
|
||||
|
||||
unsigned int stream_index, sink_index, vsync_rate_hz;
|
||||
|
||||
union dmcu_abm_set_bl_params params;
|
||||
|
||||
for (stream_index = 0; stream_index < num_streams; stream_index++) {
|
||||
if (streams[stream_index]->sink->sink_signal == SIGNAL_TYPE_VIRTUAL) {
|
||||
core_power->state[sink_index].backlight = 0;
|
||||
core_power->state[sink_index].frame_ramp = 0;
|
||||
core_power->state[sink_index].smooth_brightness_enabled = false;
|
||||
continue;
|
||||
}
|
||||
|
||||
sink_index = sink_index_from_sink(core_power,
|
||||
streams[stream_index]->sink);
|
||||
|
||||
vsync_rate_hz = div64_u64(div64_u64((streams[stream_index]->
|
||||
timing.pix_clk_khz * 1000),
|
||||
streams[stream_index]->timing.v_total),
|
||||
streams[stream_index]->timing.h_total);
|
||||
|
||||
core_power->state[sink_index].backlight = backlight_8bit;
|
||||
|
||||
if (core_power->state[sink_index].smooth_brightness_enabled)
|
||||
frame_ramp = ((vsync_rate_hz *
|
||||
SMOOTH_BRIGHTNESS_ADJUSTMENT_TIME_IN_MS) + 500)
|
||||
/ 1000;
|
||||
else
|
||||
frame_ramp = 0;
|
||||
|
||||
core_power->state[sink_index].frame_ramp = frame_ramp;
|
||||
}
|
||||
|
||||
params.u32All = 0;
|
||||
params.bits.gradual_change = (frame_ramp > 0);
|
||||
params.bits.frame_ramp = frame_ramp;
|
||||
|
||||
core_power->dc->stream_funcs.set_backlight
|
||||
(core_power->dc, backlight_8bit, params.u32All, streams[0]);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_power_get_backlight(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink,
|
||||
unsigned int *backlight_8bit)
|
||||
{
|
||||
if (sink->sink_signal == SIGNAL_TYPE_VIRTUAL)
|
||||
return false;
|
||||
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
unsigned int sink_index = sink_index_from_sink(core_power, sink);
|
||||
|
||||
*backlight_8bit = core_power->state[sink_index].backlight;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/* hard coded to default backlight curve. */
|
||||
void mod_power_initialize_backlight_caps(struct mod_power
|
||||
*mod_power)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
struct core_dc *core_dc = DC_TO_CORE(core_power->dc);
|
||||
unsigned int i;
|
||||
|
||||
backlight_caps_initialized = true;
|
||||
|
||||
struct dm_acpi_atif_backlight_caps *pExtCaps = NULL;
|
||||
bool customCurvePresent = false;
|
||||
bool customMinMaxPresent = false;
|
||||
bool customDefLevelsPresent = false;
|
||||
|
||||
/* Allocate memory for ATIF output
|
||||
* (do not want to use 256 bytes on the stack)
|
||||
*/
|
||||
pExtCaps = (struct dm_acpi_atif_backlight_caps *)
|
||||
(dm_alloc(sizeof(struct dm_acpi_atif_backlight_caps)));
|
||||
if (pExtCaps == NULL)
|
||||
return;
|
||||
|
||||
/* Retrieve ACPI extended brightness caps */
|
||||
if (dm_query_extended_brightness_caps
|
||||
(core_dc->ctx, AcpiDisplayType_LCD1, pExtCaps)) {
|
||||
ac_level_percentage = pExtCaps->acLevelPercentage;
|
||||
dc_level_percentage = pExtCaps->dcLevelPercentage;
|
||||
customMinMaxPresent = true;
|
||||
customDefLevelsPresent = true;
|
||||
customCurvePresent = (pExtCaps->numOfDataPoints > 0);
|
||||
|
||||
ASSERT(pExtCaps->numOfDataPoints <= 99);
|
||||
} else {
|
||||
dm_free(pExtCaps);
|
||||
return;
|
||||
}
|
||||
|
||||
if (customMinMaxPresent)
|
||||
backlight_8bit_lut_array[0] = pExtCaps->minInputSignal;
|
||||
else
|
||||
backlight_8bit_lut_array[0] = default_min_backlight;
|
||||
|
||||
if (customMinMaxPresent)
|
||||
backlight_8bit_lut_array[100] = pExtCaps->maxInputSignal;
|
||||
else
|
||||
backlight_8bit_lut_array[100] = default_max_backlight;
|
||||
|
||||
ASSERT(backlight_8bit_lut_array[100] <= absolute_backlight_max);
|
||||
ASSERT(backlight_8bit_lut_array[0] <=
|
||||
backlight_8bit_lut_array[100]);
|
||||
|
||||
/* Just to make sure we use valid values */
|
||||
if (backlight_8bit_lut_array[100] > absolute_backlight_max)
|
||||
backlight_8bit_lut_array[100] = absolute_backlight_max;
|
||||
if (backlight_8bit_lut_array[0] > backlight_8bit_lut_array[100]) {
|
||||
unsigned int swap;
|
||||
|
||||
swap = backlight_8bit_lut_array[0];
|
||||
backlight_8bit_lut_array[0] = backlight_8bit_lut_array[100];
|
||||
backlight_8bit_lut_array[100] = swap;
|
||||
}
|
||||
|
||||
/* Build backlight translation table for custom curve */
|
||||
if (customCurvePresent) {
|
||||
unsigned int index = 1;
|
||||
unsigned int numOfDataPoints =
|
||||
(pExtCaps->numOfDataPoints <= 99 ?
|
||||
pExtCaps->numOfDataPoints : 99);
|
||||
|
||||
/* Filling translation table from data points -
|
||||
* between every two provided data points we
|
||||
* lineary interpolate missing values
|
||||
*/
|
||||
for (i = 0; i < numOfDataPoints; i++) {
|
||||
/* Clamp signal level between min and max
|
||||
* (since min and max might come other
|
||||
* soruce like registry)
|
||||
*/
|
||||
unsigned int luminance =
|
||||
pExtCaps->dataPoints[i].luminance;
|
||||
unsigned int signalLevel =
|
||||
pExtCaps->dataPoints[i].signalLevel;
|
||||
|
||||
if (signalLevel < backlight_8bit_lut_array[0])
|
||||
signalLevel = backlight_8bit_lut_array[0];
|
||||
if (signalLevel > backlight_8bit_lut_array[100])
|
||||
signalLevel = backlight_8bit_lut_array[100];
|
||||
|
||||
/* Lineary interpolate missing values */
|
||||
if (index < luminance) {
|
||||
unsigned int baseValue =
|
||||
backlight_8bit_lut_array[index-1];
|
||||
unsigned int deltaSignal =
|
||||
signalLevel - baseValue;
|
||||
unsigned int deltaLuma =
|
||||
luminance - index + 1;
|
||||
unsigned int step = deltaSignal;
|
||||
|
||||
for (; index < luminance; index++) {
|
||||
backlight_8bit_lut_array[index] =
|
||||
baseValue + (step / deltaLuma);
|
||||
step += deltaSignal;
|
||||
}
|
||||
}
|
||||
|
||||
/* Now [index == luminance],
|
||||
* so we can add data point to the translation table
|
||||
*/
|
||||
backlight_8bit_lut_array[index++] = signalLevel;
|
||||
}
|
||||
|
||||
/* Complete the final segment of interpolation -
|
||||
* between last datapoint and maximum value
|
||||
*/
|
||||
if (index < 100) {
|
||||
unsigned int baseValue =
|
||||
backlight_8bit_lut_array[index-1];
|
||||
unsigned int deltaSignal =
|
||||
backlight_8bit_lut_array[100] -
|
||||
baseValue;
|
||||
unsigned int deltaLuma = 100 - index + 1;
|
||||
unsigned int step = deltaSignal;
|
||||
|
||||
for (; index < 100; index++) {
|
||||
backlight_8bit_lut_array[index] =
|
||||
baseValue + (step / deltaLuma);
|
||||
step += deltaSignal;
|
||||
}
|
||||
}
|
||||
/* Build backlight translation table based on default curve */
|
||||
} else {
|
||||
unsigned int delta =
|
||||
backlight_8bit_lut_array[100] -
|
||||
backlight_8bit_lut_array[0];
|
||||
unsigned int coeffC = backlight_8bit_lut_array[0];
|
||||
unsigned int coeffB =
|
||||
(backlight_curve_coeff_b < delta ?
|
||||
backlight_curve_coeff_b : delta);
|
||||
unsigned int coeffA = delta - coeffB; /* coeffB is B*100 */
|
||||
|
||||
for (i = 1; i < 100; i++) {
|
||||
backlight_8bit_lut_array[i] =
|
||||
(coeffA * i * i) /
|
||||
backlight_curve_coeff_a_factor +
|
||||
(coeffB * i) /
|
||||
backlight_curve_coeff_b_factor +
|
||||
coeffC;
|
||||
}
|
||||
}
|
||||
|
||||
if (pExtCaps != NULL)
|
||||
dm_free(pExtCaps);
|
||||
|
||||
/* Successfully initialized */
|
||||
backlight_caps_valid = true;
|
||||
backlight_def_levels_valid = customDefLevelsPresent;
|
||||
}
|
||||
|
||||
unsigned int mod_power_backlight_level_percentage_to_signal(
|
||||
struct mod_power *mod_power, unsigned int percentage)
|
||||
{
|
||||
/* Do lazy initialization of backlight capabilities*/
|
||||
if (!backlight_caps_initialized)
|
||||
mod_power_initialize_backlight_caps(mod_power);
|
||||
|
||||
/* Since the translation table is indexed by percentage,
|
||||
* we simply return backlight value at given percent
|
||||
*/
|
||||
if (backlight_caps_valid && percentage <= 100)
|
||||
return backlight_8bit_lut_array[percentage];
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
unsigned int mod_power_backlight_level_signal_to_percentage(
|
||||
struct mod_power *mod_power,
|
||||
unsigned int signalLevel8bit)
|
||||
{
|
||||
unsigned int invalid_backlight = (unsigned int)(-1);
|
||||
/* Do lazy initialization of backlight capabilities */
|
||||
if (!backlight_caps_initialized)
|
||||
mod_power_initialize_backlight_caps(mod_power);
|
||||
|
||||
/* If customer curve cannot convert to differentiated value near min
|
||||
* it is important to report 0 for min signal to pass setting "Dimmed"
|
||||
* setting in HCK brightness2 tests.
|
||||
*/
|
||||
if (signalLevel8bit <= backlight_8bit_lut_array[0])
|
||||
return 0;
|
||||
|
||||
/* Since the translation table is indexed by percentage
|
||||
* we need to do a binary search over the array
|
||||
* Another option would be to guess entry based on linear distribution
|
||||
* and then do linear search in correct direction
|
||||
*/
|
||||
if (backlight_caps_valid && signalLevel8bit <=
|
||||
absolute_backlight_max) {
|
||||
unsigned int min = 0;
|
||||
unsigned int max = 100;
|
||||
unsigned int mid = invalid_backlight;
|
||||
|
||||
while (max >= min) {
|
||||
mid = (min + max) / 2; /* floor of half range */
|
||||
|
||||
if (backlight_8bit_lut_array[mid] < signalLevel8bit)
|
||||
min = mid + 1;
|
||||
else if (backlight_8bit_lut_array[mid] >
|
||||
signalLevel8bit)
|
||||
max = mid - 1;
|
||||
else
|
||||
break;
|
||||
|
||||
if (max == 0 || max == 1)
|
||||
return invalid_backlight;
|
||||
}
|
||||
return mid;
|
||||
}
|
||||
|
||||
return invalid_backlight;
|
||||
}
|
||||
|
||||
|
||||
bool mod_power_get_panel_backlight_boundaries(
|
||||
struct mod_power *mod_power,
|
||||
unsigned int *min_backlight,
|
||||
unsigned int *max_backlight,
|
||||
unsigned int *output_ac_level_percentage,
|
||||
unsigned int *output_dc_level_percentage)
|
||||
{
|
||||
/* Do lazy initialization of backlight capabilities */
|
||||
if (!backlight_caps_initialized)
|
||||
mod_power_initialize_backlight_caps(mod_power);
|
||||
|
||||
/* If cache was successfully updated,
|
||||
* copy the values to output structure and return success
|
||||
*/
|
||||
if (backlight_caps_valid) {
|
||||
*min_backlight = backlight_8bit_lut_array[0];
|
||||
*max_backlight = backlight_8bit_lut_array[100];
|
||||
|
||||
*output_ac_level_percentage = ac_level_percentage;
|
||||
*output_dc_level_percentage = dc_level_percentage;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool mod_power_set_smooth_brightness(struct mod_power *mod_power,
|
||||
const struct dc_sink *sink, bool enable_brightness)
|
||||
{
|
||||
if (sink->sink_signal == SIGNAL_TYPE_VIRTUAL)
|
||||
return false;
|
||||
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
unsigned int sink_index = sink_index_from_sink(core_power, sink);
|
||||
|
||||
core_power->state[sink_index].smooth_brightness_enabled
|
||||
= enable_brightness;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_power_notify_mode_change(struct mod_power *mod_power,
|
||||
const struct dc_stream *stream)
|
||||
{
|
||||
if (stream->sink->sink_signal == SIGNAL_TYPE_VIRTUAL)
|
||||
return false;
|
||||
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
unsigned int sink_index = sink_index_from_sink(core_power,
|
||||
stream->sink);
|
||||
unsigned int frame_ramp = core_power->state[sink_index].frame_ramp;
|
||||
union dmcu_abm_set_bl_params params;
|
||||
|
||||
params.u32All = 0;
|
||||
params.bits.gradual_change = (frame_ramp > 0);
|
||||
params.bits.frame_ramp = frame_ramp;
|
||||
|
||||
core_power->dc->stream_funcs.set_backlight
|
||||
(core_power->dc,
|
||||
core_power->state[sink_index].backlight,
|
||||
params.u32All, stream);
|
||||
|
||||
core_power->dc->stream_funcs.setup_psr
|
||||
(core_power->dc, stream);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
static bool mod_power_abm_feature_enable(struct mod_power
|
||||
*mod_power, bool enable)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
if (abm_user_enable == enable)
|
||||
return true;
|
||||
|
||||
abm_user_enable = enable;
|
||||
|
||||
if (enable) {
|
||||
if (abm_level != 0 && abm_active)
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, abm_level);
|
||||
} else {
|
||||
if (abm_level != 0 && abm_active) {
|
||||
abm_level = 0;
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, abm_level);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool mod_power_abm_activate(struct mod_power
|
||||
*mod_power, bool activate)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
if (abm_active == activate)
|
||||
return true;
|
||||
|
||||
abm_active = activate;
|
||||
|
||||
if (activate) {
|
||||
if (abm_level != 0 && abm_user_enable)
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, abm_level);
|
||||
} else {
|
||||
if (abm_level != 0 && abm_user_enable) {
|
||||
abm_level = 0;
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, abm_level);
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool mod_power_abm_set_level(struct mod_power *mod_power,
|
||||
unsigned int level)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
if (abm_level == level)
|
||||
return true;
|
||||
|
||||
if (abm_active && abm_user_enable && level == 0)
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, 0);
|
||||
else if (abm_active && abm_user_enable && level != 0)
|
||||
core_power->dc->stream_funcs.set_abm_level
|
||||
(core_power->dc, level);
|
||||
|
||||
abm_level = level;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_power_varibright_control(struct mod_power *mod_power,
|
||||
struct varibright_info *input_varibright_info)
|
||||
{
|
||||
switch (input_varibright_info->cmd) {
|
||||
case VariBright_Cmd__SetVBLevel:
|
||||
{
|
||||
/* Set VariBright user level. */
|
||||
mod_power_abm_set_level(mod_power,
|
||||
input_varibright_info->level);
|
||||
}
|
||||
break;
|
||||
|
||||
case VariBright_Cmd__UserEnable:
|
||||
{
|
||||
/* Set VariBright user enable state. */
|
||||
mod_power_abm_feature_enable(mod_power,
|
||||
input_varibright_info->enable);
|
||||
}
|
||||
break;
|
||||
|
||||
case VariBright_Cmd__PostDisplayConfigChange:
|
||||
{
|
||||
/* Set VariBright user level. */
|
||||
mod_power_abm_set_level(mod_power,
|
||||
input_varibright_info->level);
|
||||
|
||||
/* Set VariBright user enable state. */
|
||||
mod_power_abm_feature_enable(mod_power,
|
||||
input_varibright_info->enable);
|
||||
|
||||
/* Set VariBright activate based on power state. */
|
||||
mod_power_abm_activate(mod_power,
|
||||
input_varibright_info->activate);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
{
|
||||
return false;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool mod_power_block_psr(bool block_enable, enum dmcu_block_psr_reason reason)
|
||||
{
|
||||
if (block_enable)
|
||||
block_psr |= reason;
|
||||
else
|
||||
block_psr &= ~reason;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
bool mod_power_set_psr_enable(struct mod_power *mod_power,
|
||||
bool psr_enable)
|
||||
{
|
||||
struct core_power *core_power =
|
||||
MOD_POWER_TO_CORE(mod_power);
|
||||
|
||||
if (block_psr == 0)
|
||||
return core_power->dc->stream_funcs.set_psr_enable
|
||||
(core_power->dc, psr_enable);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user