Commit ffb42e64 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Sam Ravnborg

drm/tiny/repaper: Make driver OF-independent

There is one OF call in the driver that limits its area of use.
Replace it to generic device_get_match_data() and get rid of OF dependency.

While here, cast SPI driver data to certain enumerator type.

Cc: Noralf Trønnes <noralf@tronnes.org>
Cc: dri-devel@lists.freedesktop.org
Cc: David Airlie <airlied@linux.ie>
Cc: Daniel Vetter <daniel@ffwll.ch>
Cc: David Lechner <david@lechnology.com>
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: default avatarSam Ravnborg <sam@ravnborg.org>
Signed-off-by: default avatarSam Ravnborg <sam@ravnborg.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20200131204923.48928-1-andriy.shevchenko@linux.intel.com
parent cdb702a6
...@@ -17,7 +17,7 @@ ...@@ -17,7 +17,7 @@
#include <linux/dma-buf.h> #include <linux/dma-buf.h>
#include <linux/gpio/consumer.h> #include <linux/gpio/consumer.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/of_device.h> #include <linux/property.h>
#include <linux/sched/clock.h> #include <linux/sched/clock.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/thermal.h> #include <linux/thermal.h>
...@@ -39,6 +39,7 @@ ...@@ -39,6 +39,7 @@
#define REPAPER_RID_G2_COG_ID 0x12 #define REPAPER_RID_G2_COG_ID 0x12
enum repaper_model { enum repaper_model {
/* 0 is reserved to avoid clashing with NULL */
E1144CS021 = 1, E1144CS021 = 1,
E1190CS021, E1190CS021,
E2200CS021, E2200CS021,
...@@ -986,21 +987,21 @@ static int repaper_probe(struct spi_device *spi) ...@@ -986,21 +987,21 @@ static int repaper_probe(struct spi_device *spi)
{ {
const struct drm_display_mode *mode; const struct drm_display_mode *mode;
const struct spi_device_id *spi_id; const struct spi_device_id *spi_id;
const struct of_device_id *match;
struct device *dev = &spi->dev; struct device *dev = &spi->dev;
enum repaper_model model; enum repaper_model model;
const char *thermal_zone; const char *thermal_zone;
struct repaper_epd *epd; struct repaper_epd *epd;
size_t line_buffer_size; size_t line_buffer_size;
struct drm_device *drm; struct drm_device *drm;
const void *match;
int ret; int ret;
match = of_match_device(repaper_of_match, dev); match = device_get_match_data(dev);
if (match) { if (match) {
model = (enum repaper_model)match->data; model = (enum repaper_model)match;
} else { } else {
spi_id = spi_get_device_id(spi); spi_id = spi_get_device_id(spi);
model = spi_id->driver_data; model = (enum repaper_model)spi_id->driver_data;
} }
/* The SPI device is used to allocate dma memory */ /* The SPI device is used to allocate dma memory */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment