mirror of
https://xff.cz/git/u-boot/
synced 2025-09-25 04:21:18 +02:00
panel: Expand the backlight support
At present the panel can be turned on but not off, and the brightness cannot be controlled at run-time. Add a new API function to both the panel and backlight uclasses to handle this. Enhance the PWM backlight driver to deal with custom levels properly and allow the backlight to be turned on and off. Update the test to cover thes new features. Signed-off-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
@@ -45,6 +45,35 @@ static int dm_test_panel(struct unit_test_state *uts)
|
||||
ut_asserteq(1, sandbox_gpio_get_value(gpio, 1));
|
||||
ut_asserteq(true, regulator_get_enable(reg));
|
||||
|
||||
ut_assertok(panel_set_backlight(dev, 40));
|
||||
ut_assertok(sandbox_pwm_get_config(pwm, 0, &period_ns, &duty_ns,
|
||||
&enable, &polarity));
|
||||
ut_asserteq(64 * 1000 / 256, duty_ns);
|
||||
|
||||
ut_assertok(panel_set_backlight(dev, BACKLIGHT_MAX));
|
||||
ut_assertok(sandbox_pwm_get_config(pwm, 0, &period_ns, &duty_ns,
|
||||
&enable, &polarity));
|
||||
ut_asserteq(255 * 1000 / 256, duty_ns);
|
||||
|
||||
ut_assertok(panel_set_backlight(dev, BACKLIGHT_MIN));
|
||||
ut_assertok(sandbox_pwm_get_config(pwm, 0, &period_ns, &duty_ns,
|
||||
&enable, &polarity));
|
||||
ut_asserteq(0 * 1000 / 256, duty_ns);
|
||||
ut_asserteq(1, sandbox_gpio_get_value(gpio, 1));
|
||||
|
||||
ut_assertok(panel_set_backlight(dev, BACKLIGHT_DEFAULT));
|
||||
ut_assertok(sandbox_pwm_get_config(pwm, 0, &period_ns, &duty_ns,
|
||||
&enable, &polarity));
|
||||
ut_asserteq(true, enable);
|
||||
ut_asserteq(170 * 1000 / 256, duty_ns);
|
||||
|
||||
ut_assertok(panel_set_backlight(dev, BACKLIGHT_OFF));
|
||||
ut_assertok(sandbox_pwm_get_config(pwm, 0, &period_ns, &duty_ns,
|
||||
&enable, &polarity));
|
||||
ut_asserteq(0 * 1000 / 256, duty_ns);
|
||||
ut_asserteq(0, sandbox_gpio_get_value(gpio, 1));
|
||||
ut_asserteq(false, regulator_get_enable(reg));
|
||||
|
||||
return 0;
|
||||
}
|
||||
DM_TEST(dm_test_panel, DM_TESTF_SCAN_PDATA | DM_TESTF_SCAN_FDT);
|
||||
|
Reference in New Issue
Block a user