• Home
  • Raw
  • Download

Lines Matching refs:lcd

36 	int (*adj_mode)(struct tdo24m *lcd, int mode);
178 static int tdo24m_writes(struct tdo24m *lcd, const uint32_t *array) in tdo24m_writes() argument
180 struct spi_transfer *x = &lcd->xfer; in tdo24m_writes()
186 if (!lcd->color_invert && *p == CMD0(0x21)) in tdo24m_writes()
194 lcd->buf[0] = (data >> 8) & 0xff; in tdo24m_writes()
195 lcd->buf[1] = data & 0xff; in tdo24m_writes()
198 lcd->buf[0] = (data >> 16) & 0xff; in tdo24m_writes()
199 lcd->buf[1] = (data >> 8) & 0xff; in tdo24m_writes()
200 lcd->buf[2] = data & 0xff; in tdo24m_writes()
203 lcd->buf[0] = (data >> 24) & 0xff; in tdo24m_writes()
204 lcd->buf[1] = (data >> 16) & 0xff; in tdo24m_writes()
205 lcd->buf[2] = (data >> 8) & 0xff; in tdo24m_writes()
206 lcd->buf[3] = data & 0xff; in tdo24m_writes()
212 err = spi_sync(lcd->spi_dev, &lcd->msg); in tdo24m_writes()
220 static int tdo24m_adj_mode(struct tdo24m *lcd, int mode) in tdo24m_adj_mode() argument
224 tdo24m_writes(lcd, lcd_vga_pass_through_tdo24m); in tdo24m_adj_mode()
225 tdo24m_writes(lcd, lcd_panel_config); in tdo24m_adj_mode()
226 tdo24m_writes(lcd, lcd_vga_transfer_tdo24m); in tdo24m_adj_mode()
229 tdo24m_writes(lcd, lcd_qvga_pass_through_tdo24m); in tdo24m_adj_mode()
230 tdo24m_writes(lcd, lcd_panel_config); in tdo24m_adj_mode()
231 tdo24m_writes(lcd, lcd_qvga_transfer); in tdo24m_adj_mode()
237 lcd->mode = mode; in tdo24m_adj_mode()
241 static int tdo35s_adj_mode(struct tdo24m *lcd, int mode) in tdo35s_adj_mode() argument
245 tdo24m_writes(lcd, lcd_vga_pass_through_tdo35s); in tdo35s_adj_mode()
246 tdo24m_writes(lcd, lcd_panel_config); in tdo35s_adj_mode()
247 tdo24m_writes(lcd, lcd_vga_transfer_tdo35s); in tdo35s_adj_mode()
250 tdo24m_writes(lcd, lcd_qvga_pass_through_tdo35s); in tdo35s_adj_mode()
251 tdo24m_writes(lcd, lcd_panel_config); in tdo35s_adj_mode()
252 tdo24m_writes(lcd, lcd_qvga_transfer); in tdo35s_adj_mode()
258 lcd->mode = mode; in tdo35s_adj_mode()
262 static int tdo24m_power_on(struct tdo24m *lcd) in tdo24m_power_on() argument
266 err = tdo24m_writes(lcd, lcd_panel_on); in tdo24m_power_on()
270 err = tdo24m_writes(lcd, lcd_panel_reset); in tdo24m_power_on()
274 err = lcd->adj_mode(lcd, lcd->mode); in tdo24m_power_on()
279 static int tdo24m_power_off(struct tdo24m *lcd) in tdo24m_power_off() argument
281 return tdo24m_writes(lcd, lcd_panel_off); in tdo24m_power_off()
284 static int tdo24m_power(struct tdo24m *lcd, int power) in tdo24m_power() argument
288 if (POWER_IS_ON(power) && !POWER_IS_ON(lcd->power)) in tdo24m_power()
289 ret = tdo24m_power_on(lcd); in tdo24m_power()
290 else if (!POWER_IS_ON(power) && POWER_IS_ON(lcd->power)) in tdo24m_power()
291 ret = tdo24m_power_off(lcd); in tdo24m_power()
294 lcd->power = power; in tdo24m_power()
302 struct tdo24m *lcd = lcd_get_data(ld); in tdo24m_set_power() local
304 return tdo24m_power(lcd, power); in tdo24m_set_power()
309 struct tdo24m *lcd = lcd_get_data(ld); in tdo24m_get_power() local
311 return lcd->power; in tdo24m_get_power()
316 struct tdo24m *lcd = lcd_get_data(ld); in tdo24m_set_mode() local
322 if (lcd->mode == mode) in tdo24m_set_mode()
325 return lcd->adj_mode(lcd, mode); in tdo24m_set_mode()
336 struct tdo24m *lcd; in tdo24m_probe() local
355 lcd = devm_kzalloc(&spi->dev, sizeof(struct tdo24m), GFP_KERNEL); in tdo24m_probe()
356 if (!lcd) in tdo24m_probe()
359 lcd->spi_dev = spi; in tdo24m_probe()
360 lcd->power = FB_BLANK_POWERDOWN; in tdo24m_probe()
361 lcd->mode = MODE_VGA; /* default to VGA */ in tdo24m_probe()
363 lcd->buf = devm_kzalloc(&spi->dev, TDO24M_SPI_BUFF_SIZE, GFP_KERNEL); in tdo24m_probe()
364 if (lcd->buf == NULL) in tdo24m_probe()
367 m = &lcd->msg; in tdo24m_probe()
368 x = &lcd->xfer; in tdo24m_probe()
373 x->tx_buf = &lcd->buf[0]; in tdo24m_probe()
378 lcd->color_invert = 1; in tdo24m_probe()
379 lcd->adj_mode = tdo24m_adj_mode; in tdo24m_probe()
382 lcd->adj_mode = tdo35s_adj_mode; in tdo24m_probe()
383 lcd->color_invert = 0; in tdo24m_probe()
390 lcd->lcd_dev = devm_lcd_device_register(&spi->dev, "tdo24m", &spi->dev, in tdo24m_probe()
391 lcd, &tdo24m_ops); in tdo24m_probe()
392 if (IS_ERR(lcd->lcd_dev)) in tdo24m_probe()
393 return PTR_ERR(lcd->lcd_dev); in tdo24m_probe()
395 spi_set_drvdata(spi, lcd); in tdo24m_probe()
396 err = tdo24m_power(lcd, FB_BLANK_UNBLANK); in tdo24m_probe()
405 struct tdo24m *lcd = spi_get_drvdata(spi); in tdo24m_remove() local
407 tdo24m_power(lcd, FB_BLANK_POWERDOWN); in tdo24m_remove()
414 struct tdo24m *lcd = dev_get_drvdata(dev); in tdo24m_suspend() local
416 return tdo24m_power(lcd, FB_BLANK_POWERDOWN); in tdo24m_suspend()
421 struct tdo24m *lcd = dev_get_drvdata(dev); in tdo24m_resume() local
423 return tdo24m_power(lcd, FB_BLANK_UNBLANK); in tdo24m_resume()
432 struct tdo24m *lcd = spi_get_drvdata(spi); in tdo24m_shutdown() local
434 tdo24m_power(lcd, FB_BLANK_POWERDOWN); in tdo24m_shutdown()