OMAP display subsystem - does it work?
Tony Lindgren
tony at atomide.com
Fri Dec 20 11:10:27 EST 2013
* Russell King - ARM Linux <linux at arm.linux.org.uk> [131220 03:28]:
>
> > BTW, I'm seeing MMC errors with my LDP here though, does that work
> > for you?
>
> I see no errors there.
OK thanks that's good to hear. I'm seeing them even after changing the
MMC card, need to check that again though. I'm almost certain it worked
just fine a month ago or so when I was playing with it.. Maybe some dirt
in the contacts or something.
> Okay, while digging through the changes, I found this - this is the old
> code. gpio + 15 is the backlight enable GPIO.
>
> static int ldp_twl_gpio_setup(struct device *dev, unsigned gpio, unsigned ngpio)
> {
> - ldp_panel_data.gpios[0] = gpio + 7;
> - ldp_panel_data.gpio_invert[0] = true;
>
> - ldp_panel_data.gpios[1] = gpio + 15;
> - ldp_panel_data.gpio_invert[1] = true;
>
> return 0;
> }
>
> ...
>
> -static int generic_dpi_panel_power_on(struct omap_dss_device *dssdev)
> -{
> ...
> - for (i = 0; i < panel_data->num_gpios; ++i) {
> - gpio_set_value_cansleep(panel_data->gpios[i],
> - panel_data->gpio_invert[i] ? 0 : 1);
> - }
>
> -static void generic_dpi_panel_power_off(struct omap_dss_device *dssdev)
> -{
> ...
> - for (i = panel_data->num_gpios - 1; i >= 0; --i) {
> - gpio_set_value_cansleep(panel_data->gpios[i],
> - panel_data->gpio_invert[i] ? 1 : 0);
> - }
>
> -static int generic_dpi_panel_probe(struct omap_dss_device *dssdev)
> -{
> - for (i = 0; i < panel_data->num_gpios; ++i) {
> - r = devm_gpio_request_one(dssdev->dev, panel_data->gpios[i],
> - panel_data->gpio_invert[i] ?
> - GPIOF_OUT_INIT_HIGH : GPIOF_OUT_INIT_LOW,
> - "panel gpio");
> - if (r)
> - return r;
> - }
>
> So, when gpio_invert[] is set, the signal is active low for "on". What
> does the new code do?
>
> static int ldp_twl_gpio_setup(struct device *dev, unsigned gpio, unsigned ngpio)
> {
> + /* LCD enable GPIO */
> + ldp_lcd_pdata.enable_gpio = gpio + 7;
>
> + /* Backlight enable GPIO */
> + ldp_lcd_pdata.backlight_gpio = gpio + 15;
> ...
>
> static int panel_dpi_enable(struct omap_dss_device *dssdev)
> {
> ...
> if (gpio_is_valid(ddata->backlight_gpio))
> gpio_set_value_cansleep(ddata->backlight_gpio, 1);
>
> ...
> static void panel_dpi_disable(struct omap_dss_device *dssdev)
> {
> ...
> if (gpio_is_valid(ddata->backlight_gpio))
> gpio_set_value_cansleep(ddata->backlight_gpio, 0);
>
> ...
> static int panel_dpi_probe(struct platform_device *pdev)
> {
> ...
> if (gpio_is_valid(ddata->backlight_gpio)) {
> r = devm_gpio_request_one(&pdev->dev, ddata->backlight_gpio,
> GPIOF_OUT_INIT_LOW, "panel backlight");
>
> which is fixed at active-high for "on".
>
> Would you like to revise whether this works for you... I suspect that
> you're missing configuration which means that the backlight_gpio is
> not valid, and hence it's being left in same default state (maybe by
> the boot loader?)
Nope, my LCD if off from the bootloader and gets enabled by the kernel.
I think the old gpio_invert was inverting the value unnecessarily or
something, the new code does the right thing without a need for the
gpio_invert flags.
Regards,
Tony
More information about the linux-arm-kernel
mailing list