.enabled_at_boot = 1,
 };
 
+static struct gpiod_lookup_table shannon_display_gpio_table = {
+       .dev_id = "sa11x0-fb",
+       .table = {
+               GPIO_LOOKUP("gpio", 22, "shannon-lcden", GPIO_ACTIVE_HIGH),
+               { },
+       },
+};
+
 static void __init shannon_init(void)
 {
        sa11x0_register_fixed_regulator(0, &shannon_cf_vcc_pdata,
        sa11x0_register_pcmcia(0, &shannon_pcmcia0_gpio_table);
        sa11x0_register_pcmcia(1, &shannon_pcmcia1_gpio_table);
        sa11x0_ppc_configure_mcp();
+       gpiod_add_lookup_table(&shannon_display_gpio_table);
        sa11x0_register_lcd(&shannon_lcd_info);
        sa11x0_register_mtd(&shannon_flash_data, &shannon_flash_resource, 1);
        sa11x0_register_mcp(&shannon_mcp_data);
 
 #include <linux/init.h>
 #include <linux/ioport.h>
 #include <linux/cpufreq.h>
-#include <linux/gpio.h>
+#include <linux/gpio/consumer.h>
 #include <linux/platform_device.h>
 #include <linux/dma-mapping.h>
 #include <linux/mutex.h>
        writel_relaxed(fbi->dbar2, fbi->base + DBAR2);
        writel_relaxed(fbi->reg_lccr0 | LCCR0_LEN, fbi->base + LCCR0);
 
-       if (machine_is_shannon())
-               gpio_set_value(SHANNON_GPIO_DISP_EN, 1);
+       if (fbi->shannon_lcden)
+               gpiod_set_value(fbi->shannon_lcden, 1);
 
        dev_dbg(fbi->dev, "DBAR1: 0x%08x\n", readl_relaxed(fbi->base + DBAR1));
        dev_dbg(fbi->dev, "DBAR2: 0x%08x\n", readl_relaxed(fbi->base + DBAR2));
 
        dev_dbg(fbi->dev, "Disabling LCD controller\n");
 
-       if (machine_is_shannon())
-               gpio_set_value(SHANNON_GPIO_DISP_EN, 0);
+       if (fbi->shannon_lcden)
+               gpiod_set_value(fbi->shannon_lcden, 0);
 
        set_current_state(TASK_UNINTERRUPTIBLE);
        add_wait_queue(&fbi->ctrlr_wait, &wait);
                return ret;
        }
 
-       if (machine_is_shannon()) {
-               ret = devm_gpio_request_one(&pdev->dev, SHANNON_GPIO_DISP_EN,
-                       GPIOF_OUT_INIT_LOW, "display enable");
-               if (ret)
-                       return ret;
-       }
+       fbi->shannon_lcden = gpiod_get_optional(&pdev->dev, "shannon-lcden",
+                                               GPIOD_OUT_LOW);
+       if (IS_ERR(fbi->shannon_lcden))
+               return PTR_ERR(fbi->shannon_lcden);
 
        /* Initialize video memory */
        ret = sa1100fb_map_video_memory(fbi);