static int l4f00242t03_lcd_power_set(struct lcd_device *ld, int power)
{
	struct l4f00242t03_priv *priv = lcd_get_data(ld);
	struct spi_device *spi = priv->spi;

	const u16 slpout = 0x11;
	const u16 dison = 0x29;

	const u16 slpin = 0x10;
	const u16 disoff = 0x28;

	if (power <= FB_BLANK_NORMAL) {
		if (priv->lcd_state <= FB_BLANK_NORMAL) {
			/* Do nothing, the LCD is running */
		} else if (priv->lcd_state < FB_BLANK_POWERDOWN) {
			dev_dbg(&spi->dev, "Resuming LCD\n");

			spi_write(spi, (const u8 *)&slpout, sizeof(u16));
			msleep(60);
			spi_write(spi, (const u8 *)&dison, sizeof(u16));
		} else {
			/* priv->lcd_state == FB_BLANK_POWERDOWN */
			l4f00242t03_lcd_init(spi);
			priv->lcd_state = FB_BLANK_VSYNC_SUSPEND;
			l4f00242t03_lcd_power_set(priv->ld, power);
		}
	} else if (power < FB_BLANK_POWERDOWN) {
		if (priv->lcd_state <= FB_BLANK_NORMAL) {
			/* Send the display in standby */
			dev_dbg(&spi->dev, "Standby the LCD\n");

			spi_write(spi, (const u8 *)&disoff, sizeof(u16));
			msleep(60);
			spi_write(spi, (const u8 *)&slpin, sizeof(u16));
		} else if (priv->lcd_state < FB_BLANK_POWERDOWN) {
			/* Do nothing, the LCD is already in standby */
		} else {
			/* priv->lcd_state == FB_BLANK_POWERDOWN */
			l4f00242t03_lcd_init(spi);
			priv->lcd_state = FB_BLANK_UNBLANK;
			l4f00242t03_lcd_power_set(ld, power);
		}
	} else {
		/* power == FB_BLANK_POWERDOWN */
		if (priv->lcd_state != FB_BLANK_POWERDOWN) {
			/* Clear the screen before shutting down */
			spi_write(spi, (const u8 *)&disoff, sizeof(u16));
			msleep(60);
			l4f00242t03_lcd_powerdown(spi);
		}
	}

	priv->lcd_state = power;

	return 0;
}
static void l4f00242t03_shutdown(struct spi_device *spi)
{
	struct l4f00242t03_priv *priv = dev_get_drvdata(&spi->dev);

	if (priv)
		l4f00242t03_lcd_power_set(priv->ld, FB_BLANK_POWERDOWN);

}
Example #3
0
static int __devexit l4f00242t03_remove(struct spi_device *spi)
{
    struct l4f00242t03_priv *priv = dev_get_drvdata(&spi->dev);

    l4f00242t03_lcd_power_set(priv->ld, FB_BLANK_POWERDOWN);
    lcd_device_unregister(priv->ld);

    dev_set_drvdata(&spi->dev, NULL);

    regulator_put(priv->io_reg);
    regulator_put(priv->core_reg);

    return 0;
}
static int __devexit l4f00242t03_remove(struct spi_device *spi)
{
	struct l4f00242t03_priv *priv = dev_get_drvdata(&spi->dev);
	struct l4f00242t03_pdata *pdata = priv->spi->dev.platform_data;

	l4f00242t03_lcd_power_set(priv->ld, FB_BLANK_POWERDOWN);
	lcd_device_unregister(priv->ld);

	dev_set_drvdata(&spi->dev, NULL);

	gpio_free(pdata->data_enable_gpio);
	gpio_free(pdata->reset_gpio);

	regulator_put(priv->io_reg);
	regulator_put(priv->core_reg);

	kfree(priv);

	return 0;
}
static int __devinit l4f00242t03_probe(struct spi_device *spi)
{
	struct l4f00242t03_priv *priv;
	struct l4f00242t03_pdata *pdata = spi->dev.platform_data;
	int ret;

	if (pdata == NULL) {
		dev_err(&spi->dev, "Uninitialized platform data.\n");
		return -EINVAL;
	}

	priv = kzalloc(sizeof(struct l4f00242t03_priv), GFP_KERNEL);

	if (priv == NULL) {
		dev_err(&spi->dev, "No memory for this device.\n");
		return -ENOMEM;
	}

	dev_set_drvdata(&spi->dev, priv);
	spi->bits_per_word = 9;
	spi_setup(spi);

	priv->spi = spi;

	ret = gpio_request_one(pdata->reset_gpio, GPIOF_OUT_INIT_HIGH,
						"lcd l4f00242t03 reset");
	if (ret) {
		dev_err(&spi->dev,
			"Unable to get the lcd l4f00242t03 reset gpio.\n");
		goto err;
	}

	ret = gpio_request_one(pdata->data_enable_gpio, GPIOF_OUT_INIT_LOW,
						"lcd l4f00242t03 data enable");
	if (ret) {
		dev_err(&spi->dev,
			"Unable to get the lcd l4f00242t03 data en gpio.\n");
		goto err2;
	}

	priv->io_reg = regulator_get(&spi->dev, "vdd");
	if (IS_ERR(priv->io_reg)) {
		ret = PTR_ERR(priv->io_reg);
		dev_err(&spi->dev, "%s: Unable to get the IO regulator\n",
		       __func__);
		goto err3;
	}

	priv->core_reg = regulator_get(&spi->dev, "vcore");
	if (IS_ERR(priv->core_reg)) {
		ret = PTR_ERR(priv->core_reg);
		dev_err(&spi->dev, "%s: Unable to get the core regulator\n",
		       __func__);
		goto err4;
	}

	priv->ld = lcd_device_register("l4f00242t03",
					&spi->dev, priv, &l4f_ops);
	if (IS_ERR(priv->ld)) {
		ret = PTR_ERR(priv->ld);
		goto err5;
	}

	/* Init the LCD */
	l4f00242t03_lcd_init(spi);
	priv->lcd_state = FB_BLANK_VSYNC_SUSPEND;
	l4f00242t03_lcd_power_set(priv->ld, FB_BLANK_UNBLANK);

	dev_info(&spi->dev, "Epson l4f00242t03 lcd probed.\n");

	return 0;

err5:
	regulator_put(priv->core_reg);
err4:
	regulator_put(priv->io_reg);
err3:
	gpio_free(pdata->data_enable_gpio);
err2:
	gpio_free(pdata->reset_gpio);
err:
	kfree(priv);

	return ret;
}
Example #6
0
static int __devinit l4f00242t03_probe(struct spi_device *spi)
{
    struct l4f00242t03_priv *priv;
    struct l4f00242t03_pdata *pdata = spi->dev.platform_data;
    int ret;

    if (pdata == NULL) {
        dev_err(&spi->dev, "Uninitialized platform data.\n");
        return -EINVAL;
    }

    priv = kzalloc(sizeof(struct l4f00242t03_priv), GFP_KERNEL);

    if (priv == NULL) {
        dev_err(&spi->dev, "No memory for this device.\n");
        ret = -ENOMEM;
        goto err;
    }

    dev_set_drvdata(&spi->dev, priv);
    spi->bits_per_word = 9;
    spi_setup(spi);

    priv->spi = spi;

    ret = gpio_request(pdata->reset_gpio, "lcd l4f00242t03 reset");
    if (ret) {
        dev_err(&spi->dev,
                "Unable to get the lcd l4f00242t03 reset gpio.\n");
        return ret;
    }

    ret = gpio_direction_output(pdata->reset_gpio, 1);
    if (ret)
        goto err2;

    ret = gpio_request(pdata->data_enable_gpio,
                       "lcd l4f00242t03 data enable");
    if (ret) {
        dev_err(&spi->dev,
                "Unable to get the lcd l4f00242t03 data en gpio.\n");
        return ret;
    }

    ret = gpio_direction_output(pdata->data_enable_gpio, 0);
    if (ret)
        goto err3;

    if (pdata->io_supply) {
        priv->io_reg = regulator_get(NULL, pdata->io_supply);

        if (IS_ERR(priv->io_reg)) {
            pr_err("%s: Unable to get the IO regulator\n",
                   __func__);
            goto err3;
        }
    }

    if (pdata->core_supply) {
        priv->core_reg = regulator_get(NULL, pdata->core_supply);

        if (IS_ERR(priv->core_reg)) {
            pr_err("%s: Unable to get the core regulator\n",
                   __func__);
            goto err4;
        }
    }

    priv->ld = lcd_device_register("l4f00242t03",
                                   &spi->dev, priv, &l4f_ops);
    if (IS_ERR(priv->ld)) {
        ret = PTR_ERR(priv->ld);
        goto err5;
    }

    /* Init the LCD */
    l4f00242t03_reset(pdata->reset_gpio);
    l4f00242t03_lcd_init(spi);
    l4f00242t03_lcd_power_set(priv->ld, 1);

    dev_info(&spi->dev, "Epson l4f00242t03 lcd probed.\n");

    return 0;

err5:
    if (priv->core_reg)
        regulator_put(priv->core_reg);
err4:
    if (priv->io_reg)
        regulator_put(priv->io_reg);
err3:
    gpio_free(pdata->data_enable_gpio);
err2:
    gpio_free(pdata->reset_gpio);
err:
    kfree(priv);

    return ret;
}