From mboxrd@z Thu Jan 1 00:00:00 1970 From: Krzysztof Kozlowski Date: Sun, 02 Sep 2018 15:22:31 +0000 Subject: [PATCH v2 1/2] backlight: Remove s6e63m0 driver Message-Id: <20180902152232.5802-1-krzk@kernel.org> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Donghwa Lee , Lee Jones , Daniel Thompson , Jingoo Han , Bartlomiej Zolnierkiewicz , Krzysztof Kozlowski , Jonathan Corbet , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org Cc: Marek Szyprowski The driver for S6E63M0 AMOLED LCD panel is not used. It does not support DeviceTree and respective possible users (S5Pv210 Aquila and Goni boards) are DeviceTree-only. Suggested-by: Marek Szyprowski Cc: Marek Szyprowski Cc: Inki Dae Signed-off-by: Krzysztof Kozlowski Acked-by: Jingoo Han Acked-by: Daniel Thompson --- Changes since v1: 1. Remove sysfs ABI documentation file. 2. Add Jingoo's and Daniel's acks. --- Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 | 27 - drivers/video/backlight/Kconfig | 8 - drivers/video/backlight/Makefile | 1 - drivers/video/backlight/s6e63m0.c | 857 ---------------------- drivers/video/backlight/s6e63m0_gamma.h | 266 ------- 5 files changed, 1159 deletions(-) delete mode 100644 Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 delete mode 100644 drivers/video/backlight/s6e63m0.c delete mode 100644 drivers/video/backlight/s6e63m0_gamma.h diff --git a/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 b/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 deleted file mode 100644 index ae0a2d3dcc07..000000000000 --- a/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 +++ /dev/null @@ -1,27 +0,0 @@ -sysfs interface for the S6E63M0 AMOLED LCD panel driver -------------------------------------------------------- - -What: /sys/class/lcd//gamma_mode -Date: May, 2010 -KernelVersion: v2.6.35 -Contact: dri-devel@lists.freedesktop.org -Description: - (RW) Read or write the gamma mode. Following three modes are - supported: - 0 - gamma value 2.2, - 1 - gamma value 1.9 and - 2 - gamma value 1.7. - - -What: /sys/class/lcd//gamma_table -Date: May, 2010 -KernelVersion: v2.6.35 -Contact: dri-devel@lists.freedesktop.org -Description: - (RO) Displays the size of the gamma table i.e. the number of - gamma modes available. - -This is a backlight lcd driver. These interfaces are an extension to the API -documented in Documentation/ABI/testing/sysfs-class-lcd and in -Documentation/ABI/stable/sysfs-class-backlight (under -/sys/class/backlight//). diff --git a/drivers/video/backlight/Kconfig b/drivers/video/backlight/Kconfig index 2919e2334052..2373c3cec0c3 100644 --- a/drivers/video/backlight/Kconfig +++ b/drivers/video/backlight/Kconfig @@ -111,14 +111,6 @@ config LCD_HP700 If you have an HP Jornada 700 series handheld (710/720/728) say Y to enable LCD control driver. -config LCD_S6E63M0 - tristate "S6E63M0 AMOLED LCD Driver" - depends on SPI && BACKLIGHT_CLASS_DEVICE - default n - help - If you have an S6E63M0 LCD Panel, say Y to enable its - LCD control driver. - config LCD_LD9040 tristate "LD9040 AMOLED LCD Driver" depends on SPI && BACKLIGHT_CLASS_DEVICE diff --git a/drivers/video/backlight/Makefile b/drivers/video/backlight/Makefile index 0dcc2c745c03..c7a46392a76f 100644 --- a/drivers/video/backlight/Makefile +++ b/drivers/video/backlight/Makefile @@ -15,7 +15,6 @@ obj-$(CONFIG_LCD_LMS501KF03) += lms501kf03.o obj-$(CONFIG_LCD_LTV350QV) += ltv350qv.o obj-$(CONFIG_LCD_OTM3225A) += otm3225a.o obj-$(CONFIG_LCD_PLATFORM) += platform_lcd.o -obj-$(CONFIG_LCD_S6E63M0) += s6e63m0.o obj-$(CONFIG_LCD_TDO24M) += tdo24m.o obj-$(CONFIG_LCD_TOSA) += tosa_lcd.o obj-$(CONFIG_LCD_VGG2432A4) += vgg2432a4.o diff --git a/drivers/video/backlight/s6e63m0.c b/drivers/video/backlight/s6e63m0.c deleted file mode 100644 index 3c4a22a3063a..000000000000 --- a/drivers/video/backlight/s6e63m0.c +++ /dev/null @@ -1,857 +0,0 @@ -/* - * S6E63M0 AMOLED LCD panel driver. - * - * Author: InKi Dae - * - * Derived from drivers/video/omap/lcd-apollon.c - * - * This program is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License as published by the - * Free Software Foundation; either version 2 of the License, or (at your - * option) any later version. - */ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "s6e63m0_gamma.h" - -#define SLEEPMSEC 0x1000 -#define ENDDEF 0x2000 -#define DEFMASK 0xFF00 -#define COMMAND_ONLY 0xFE -#define DATA_ONLY 0xFF - -#define MIN_BRIGHTNESS 0 -#define MAX_BRIGHTNESS 10 - -struct s6e63m0 { - struct device *dev; - struct spi_device *spi; - unsigned int power; - unsigned int current_brightness; - unsigned int gamma_mode; - unsigned int gamma_table_count; - struct lcd_device *ld; - struct backlight_device *bd; - struct lcd_platform_data *lcd_pd; -}; - -static const unsigned short seq_panel_condition_set[] = { - 0xF8, 0x01, - DATA_ONLY, 0x27, - DATA_ONLY, 0x27, - DATA_ONLY, 0x07, - DATA_ONLY, 0x07, - DATA_ONLY, 0x54, - DATA_ONLY, 0x9f, - DATA_ONLY, 0x63, - DATA_ONLY, 0x86, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x33, - DATA_ONLY, 0x0d, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_display_condition_set[] = { - 0xf2, 0x02, - DATA_ONLY, 0x03, - DATA_ONLY, 0x1c, - DATA_ONLY, 0x10, - DATA_ONLY, 0x10, - - 0xf7, 0x03, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_gamma_setting[] = { - 0xfa, 0x00, - DATA_ONLY, 0x18, - DATA_ONLY, 0x08, - DATA_ONLY, 0x24, - DATA_ONLY, 0x64, - DATA_ONLY, 0x56, - DATA_ONLY, 0x33, - DATA_ONLY, 0xb6, - DATA_ONLY, 0xba, - DATA_ONLY, 0xa8, - DATA_ONLY, 0xac, - DATA_ONLY, 0xb1, - DATA_ONLY, 0x9d, - DATA_ONLY, 0xc1, - DATA_ONLY, 0xc1, - DATA_ONLY, 0xb7, - DATA_ONLY, 0x00, - DATA_ONLY, 0x9c, - DATA_ONLY, 0x00, - DATA_ONLY, 0x9f, - DATA_ONLY, 0x00, - DATA_ONLY, 0xd6, - - 0xfa, 0x01, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_etc_condition_set[] = { - 0xf6, 0x00, - DATA_ONLY, 0x8c, - DATA_ONLY, 0x07, - - 0xb3, 0xc, - - 0xb5, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xb6, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xb7, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xb8, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xb9, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xba, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xc1, 0x4d, - DATA_ONLY, 0x96, - DATA_ONLY, 0x1d, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x01, - DATA_ONLY, 0xdf, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x03, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x03, - DATA_ONLY, 0x06, - DATA_ONLY, 0x09, - DATA_ONLY, 0x0d, - DATA_ONLY, 0x0f, - DATA_ONLY, 0x12, - DATA_ONLY, 0x15, - DATA_ONLY, 0x18, - - 0xb2, 0x10, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0b, - DATA_ONLY, 0x05, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_acl_on[] = { - /* ACL on */ - 0xc0, 0x01, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_acl_off[] = { - /* ACL off */ - 0xc0, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_elvss_on[] = { - /* ELVSS on */ - 0xb1, 0x0b, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_elvss_off[] = { - /* ELVSS off */ - 0xb1, 0x0a, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_stand_by_off[] = { - 0x11, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_stand_by_on[] = { - 0x10, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_display_on[] = { - 0x29, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - - -static int s6e63m0_spi_write_byte(struct s6e63m0 *lcd, int addr, int data) -{ - u16 buf[1]; - struct spi_message msg; - - struct spi_transfer xfer = { - .len = 2, - .tx_buf = buf, - }; - - buf[0] = (addr << 8) | data; - - spi_message_init(&msg); - spi_message_add_tail(&xfer, &msg); - - return spi_sync(lcd->spi, &msg); -} - -static int s6e63m0_spi_write(struct s6e63m0 *lcd, unsigned char address, - unsigned char command) -{ - int ret = 0; - - if (address != DATA_ONLY) - ret = s6e63m0_spi_write_byte(lcd, 0x0, address); - if (command != COMMAND_ONLY) - ret = s6e63m0_spi_write_byte(lcd, 0x1, command); - - return ret; -} - -static int s6e63m0_panel_send_sequence(struct s6e63m0 *lcd, - const unsigned short *wbuf) -{ - int ret = 0, i = 0; - - while ((wbuf[i] & DEFMASK) != ENDDEF) { - if ((wbuf[i] & DEFMASK) != SLEEPMSEC) { - ret = s6e63m0_spi_write(lcd, wbuf[i], wbuf[i+1]); - if (ret) - break; - } else { - msleep(wbuf[i+1]); - } - i += 2; - } - - return ret; -} - -static int _s6e63m0_gamma_ctl(struct s6e63m0 *lcd, const unsigned int *gamma) -{ - unsigned int i = 0; - int ret = 0; - - /* disable gamma table updating. */ - ret = s6e63m0_spi_write(lcd, 0xfa, 0x00); - if (ret) { - dev_err(lcd->dev, "failed to disable gamma table updating.\n"); - goto gamma_err; - } - - for (i = 0 ; i < GAMMA_TABLE_COUNT; i++) { - ret = s6e63m0_spi_write(lcd, DATA_ONLY, gamma[i]); - if (ret) { - dev_err(lcd->dev, "failed to set gamma table.\n"); - goto gamma_err; - } - } - - /* update gamma table. */ - ret = s6e63m0_spi_write(lcd, 0xfa, 0x01); - if (ret) - dev_err(lcd->dev, "failed to update gamma table.\n"); - -gamma_err: - return ret; -} - -static int s6e63m0_gamma_ctl(struct s6e63m0 *lcd, int gamma) -{ - int ret = 0; - - ret = _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[gamma]); - - return ret; -} - - -static int s6e63m0_ldi_init(struct s6e63m0 *lcd) -{ - int ret, i; - const unsigned short *init_seq[] = { - seq_panel_condition_set, - seq_display_condition_set, - seq_gamma_setting, - seq_etc_condition_set, - seq_acl_on, - seq_elvss_on, - }; - - for (i = 0; i < ARRAY_SIZE(init_seq); i++) { - ret = s6e63m0_panel_send_sequence(lcd, init_seq[i]); - if (ret) - break; - } - - return ret; -} - -static int s6e63m0_ldi_enable(struct s6e63m0 *lcd) -{ - int ret = 0, i; - const unsigned short *enable_seq[] = { - seq_stand_by_off, - seq_display_on, - }; - - for (i = 0; i < ARRAY_SIZE(enable_seq); i++) { - ret = s6e63m0_panel_send_sequence(lcd, enable_seq[i]); - if (ret) - break; - } - - return ret; -} - -static int s6e63m0_ldi_disable(struct s6e63m0 *lcd) -{ - int ret; - - ret = s6e63m0_panel_send_sequence(lcd, seq_stand_by_on); - - return ret; -} - -static int s6e63m0_power_is_on(int power) -{ - return power <= FB_BLANK_NORMAL; -} - -static int s6e63m0_power_on(struct s6e63m0 *lcd) -{ - int ret = 0; - struct lcd_platform_data *pd; - struct backlight_device *bd; - - pd = lcd->lcd_pd; - bd = lcd->bd; - - if (!pd->power_on) { - dev_err(lcd->dev, "power_on is NULL.\n"); - return -EINVAL; - } - - pd->power_on(lcd->ld, 1); - msleep(pd->power_on_delay); - - if (!pd->reset) { - dev_err(lcd->dev, "reset is NULL.\n"); - return -EINVAL; - } - - pd->reset(lcd->ld); - msleep(pd->reset_delay); - - ret = s6e63m0_ldi_init(lcd); - if (ret) { - dev_err(lcd->dev, "failed to initialize ldi.\n"); - return ret; - } - - ret = s6e63m0_ldi_enable(lcd); - if (ret) { - dev_err(lcd->dev, "failed to enable ldi.\n"); - return ret; - } - - /* set brightness to current value after power on or resume. */ - ret = s6e63m0_gamma_ctl(lcd, bd->props.brightness); - if (ret) { - dev_err(lcd->dev, "lcd gamma setting failed.\n"); - return ret; - } - - return 0; -} - -static int s6e63m0_power_off(struct s6e63m0 *lcd) -{ - int ret; - struct lcd_platform_data *pd; - - pd = lcd->lcd_pd; - - ret = s6e63m0_ldi_disable(lcd); - if (ret) { - dev_err(lcd->dev, "lcd setting failed.\n"); - return -EIO; - } - - msleep(pd->power_off_delay); - - pd->power_on(lcd->ld, 0); - - return 0; -} - -static int s6e63m0_power(struct s6e63m0 *lcd, int power) -{ - int ret = 0; - - if (s6e63m0_power_is_on(power) && !s6e63m0_power_is_on(lcd->power)) - ret = s6e63m0_power_on(lcd); - else if (!s6e63m0_power_is_on(power) && s6e63m0_power_is_on(lcd->power)) - ret = s6e63m0_power_off(lcd); - - if (!ret) - lcd->power = power; - - return ret; -} - -static int s6e63m0_set_power(struct lcd_device *ld, int power) -{ - struct s6e63m0 *lcd = lcd_get_data(ld); - - if (power != FB_BLANK_UNBLANK && power != FB_BLANK_POWERDOWN && - power != FB_BLANK_NORMAL) { - dev_err(lcd->dev, "power value should be 0, 1 or 4.\n"); - return -EINVAL; - } - - return s6e63m0_power(lcd, power); -} - -static int s6e63m0_get_power(struct lcd_device *ld) -{ - struct s6e63m0 *lcd = lcd_get_data(ld); - - return lcd->power; -} - -static int s6e63m0_set_brightness(struct backlight_device *bd) -{ - int ret = 0, brightness = bd->props.brightness; - struct s6e63m0 *lcd = bl_get_data(bd); - - if (brightness < MIN_BRIGHTNESS || - brightness > bd->props.max_brightness) { - dev_err(&bd->dev, "lcd brightness should be %d to %d.\n", - MIN_BRIGHTNESS, MAX_BRIGHTNESS); - return -EINVAL; - } - - ret = s6e63m0_gamma_ctl(lcd, bd->props.brightness); - if (ret) { - dev_err(&bd->dev, "lcd brightness setting failed.\n"); - return -EIO; - } - - return ret; -} - -static struct lcd_ops s6e63m0_lcd_ops = { - .set_power = s6e63m0_set_power, - .get_power = s6e63m0_get_power, -}; - -static const struct backlight_ops s6e63m0_backlight_ops = { - .update_status = s6e63m0_set_brightness, -}; - -static ssize_t s6e63m0_sysfs_show_gamma_mode(struct device *dev, - struct device_attribute *attr, char *buf) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - char temp[10]; - - switch (lcd->gamma_mode) { - case 0: - sprintf(temp, "2.2 mode\n"); - strcat(buf, temp); - break; - case 1: - sprintf(temp, "1.9 mode\n"); - strcat(buf, temp); - break; - case 2: - sprintf(temp, "1.7 mode\n"); - strcat(buf, temp); - break; - default: - dev_info(dev, "gamma mode could be 0:2.2, 1:1.9 or 2:1.7)n"); - break; - } - - return strlen(buf); -} - -static ssize_t s6e63m0_sysfs_store_gamma_mode(struct device *dev, - struct device_attribute *attr, - const char *buf, size_t len) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - struct backlight_device *bd = NULL; - int brightness, rc; - - rc = kstrtouint(buf, 0, &lcd->gamma_mode); - if (rc < 0) - return rc; - - bd = lcd->bd; - - brightness = bd->props.brightness; - - switch (lcd->gamma_mode) { - case 0: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[brightness]); - break; - case 1: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_19_table[brightness]); - break; - case 2: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_17_table[brightness]); - break; - default: - dev_info(dev, "gamma mode could be 0:2.2, 1:1.9 or 2:1.7\n"); - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[brightness]); - break; - } - return len; -} - -static DEVICE_ATTR(gamma_mode, 0644, - s6e63m0_sysfs_show_gamma_mode, s6e63m0_sysfs_store_gamma_mode); - -static ssize_t s6e63m0_sysfs_show_gamma_table(struct device *dev, - struct device_attribute *attr, char *buf) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - char temp[3]; - - sprintf(temp, "%u\n", lcd->gamma_table_count); - strcpy(buf, temp); - - return strlen(buf); -} -static DEVICE_ATTR(gamma_table, 0444, - s6e63m0_sysfs_show_gamma_table, NULL); - -static int s6e63m0_probe(struct spi_device *spi) -{ - int ret = 0; - struct s6e63m0 *lcd = NULL; - struct lcd_device *ld = NULL; - struct backlight_device *bd = NULL; - struct backlight_properties props; - - lcd = devm_kzalloc(&spi->dev, sizeof(struct s6e63m0), GFP_KERNEL); - if (!lcd) - return -ENOMEM; - - /* s6e63m0 lcd panel uses 3-wire 9bits SPI Mode. */ - spi->bits_per_word = 9; - - ret = spi_setup(spi); - if (ret < 0) { - dev_err(&spi->dev, "spi setup failed.\n"); - return ret; - } - - lcd->spi = spi; - lcd->dev = &spi->dev; - - lcd->lcd_pd = dev_get_platdata(&spi->dev); - if (!lcd->lcd_pd) { - dev_err(&spi->dev, "platform data is NULL.\n"); - return -EINVAL; - } - - ld = devm_lcd_device_register(&spi->dev, "s6e63m0", &spi->dev, lcd, - &s6e63m0_lcd_ops); - if (IS_ERR(ld)) - return PTR_ERR(ld); - - lcd->ld = ld; - - memset(&props, 0, sizeof(struct backlight_properties)); - props.type = BACKLIGHT_RAW; - props.max_brightness = MAX_BRIGHTNESS; - - bd = devm_backlight_device_register(&spi->dev, "s6e63m0bl-bl", - &spi->dev, lcd, &s6e63m0_backlight_ops, - &props); - if (IS_ERR(bd)) - return PTR_ERR(bd); - - bd->props.brightness = MAX_BRIGHTNESS; - lcd->bd = bd; - - /* - * it gets gamma table count available so it gets user - * know that. - */ - lcd->gamma_table_count - sizeof(gamma_table) / (MAX_GAMMA_LEVEL * sizeof(int *)); - - ret = device_create_file(&(spi->dev), &dev_attr_gamma_mode); - if (ret < 0) - dev_err(&(spi->dev), "failed to add sysfs entries\n"); - - ret = device_create_file(&(spi->dev), &dev_attr_gamma_table); - if (ret < 0) - dev_err(&(spi->dev), "failed to add sysfs entries\n"); - - /* - * if lcd panel was on from bootloader like u-boot then - * do not lcd on. - */ - if (!lcd->lcd_pd->lcd_enabled) { - /* - * if lcd panel was off from bootloader then - * current lcd status is powerdown and then - * it enables lcd panel. - */ - lcd->power = FB_BLANK_POWERDOWN; - - s6e63m0_power(lcd, FB_BLANK_UNBLANK); - } else { - lcd->power = FB_BLANK_UNBLANK; - } - - spi_set_drvdata(spi, lcd); - - dev_info(&spi->dev, "s6e63m0 panel driver has been probed.\n"); - - return 0; -} - -static int s6e63m0_remove(struct spi_device *spi) -{ - struct s6e63m0 *lcd = spi_get_drvdata(spi); - - s6e63m0_power(lcd, FB_BLANK_POWERDOWN); - device_remove_file(&spi->dev, &dev_attr_gamma_table); - device_remove_file(&spi->dev, &dev_attr_gamma_mode); - - return 0; -} - -#ifdef CONFIG_PM_SLEEP -static int s6e63m0_suspend(struct device *dev) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - - dev_dbg(dev, "lcd->power = %d\n", lcd->power); - - /* - * when lcd panel is suspend, lcd panel becomes off - * regardless of status. - */ - return s6e63m0_power(lcd, FB_BLANK_POWERDOWN); -} - -static int s6e63m0_resume(struct device *dev) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - - lcd->power = FB_BLANK_POWERDOWN; - - return s6e63m0_power(lcd, FB_BLANK_UNBLANK); -} -#endif - -static SIMPLE_DEV_PM_OPS(s6e63m0_pm_ops, s6e63m0_suspend, s6e63m0_resume); - -/* Power down all displays on reboot, poweroff or halt. */ -static void s6e63m0_shutdown(struct spi_device *spi) -{ - struct s6e63m0 *lcd = spi_get_drvdata(spi); - - s6e63m0_power(lcd, FB_BLANK_POWERDOWN); -} - -static struct spi_driver s6e63m0_driver = { - .driver = { - .name = "s6e63m0", - .pm = &s6e63m0_pm_ops, - }, - .probe = s6e63m0_probe, - .remove = s6e63m0_remove, - .shutdown = s6e63m0_shutdown, -}; - -module_spi_driver(s6e63m0_driver); - -MODULE_AUTHOR("InKi Dae "); -MODULE_DESCRIPTION("S6E63M0 LCD Driver"); -MODULE_LICENSE("GPL"); - diff --git a/drivers/video/backlight/s6e63m0_gamma.h b/drivers/video/backlight/s6e63m0_gamma.h deleted file mode 100644 index 2c44bdb0696b..000000000000 --- a/drivers/video/backlight/s6e63m0_gamma.h +++ /dev/null @@ -1,266 +0,0 @@ -/* linux/drivers/video/samsung/s6e63m0_brightness.h - * - * Gamma level definitions. - * - * Copyright (c) 2009 Samsung Electronics - * InKi Dae - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation. -*/ - -#ifndef _S6E63M0_BRIGHTNESS_H -#define _S6E63M0_BRIGHTNESS_H - -#define MAX_GAMMA_LEVEL 11 -#define GAMMA_TABLE_COUNT 21 - -/* gamma value: 2.2 */ -static const unsigned int s6e63m0_22_300[] = { - 0x18, 0x08, 0x24, 0x5f, 0x50, 0x2d, 0xB6, - 0xB9, 0xA7, 0xAd, 0xB1, 0x9f, 0xbe, 0xC0, - 0xB5, 0x00, 0xa0, 0x00, 0xa4, 0x00, 0xdb -}; - -static const unsigned int s6e63m0_22_280[] = { - 0x18, 0x08, 0x24, 0x64, 0x56, 0x33, 0xB6, - 0xBA, 0xA8, 0xAC, 0xB1, 0x9D, 0xC1, 0xC1, - 0xB7, 0x00, 0x9C, 0x00, 0x9F, 0x00, 0xD6 -}; - -static const unsigned int s6e63m0_22_260[] = { - 0x18, 0x08, 0x24, 0x66, 0x58, 0x34, 0xB6, - 0xBA, 0xA7, 0xAF, 0xB3, 0xA0, 0xC1, 0xC2, - 0xB7, 0x00, 0x97, 0x00, 0x9A, 0x00, 0xD1 - -}; - -static const unsigned int s6e63m0_22_240[] = { - 0x18, 0x08, 0x24, 0x62, 0x54, 0x30, 0xB9, - 0xBB, 0xA9, 0xB0, 0xB3, 0xA1, 0xC1, 0xC3, - 0xB7, 0x00, 0x91, 0x00, 0x95, 0x00, 0xDA - -}; -static const unsigned int s6e63m0_22_220[] = { - 0x18, 0x08, 0x24, 0x63, 0x53, 0x31, 0xB8, - 0xBC, 0xA9, 0xB0, 0xB5, 0xA2, 0xC4, 0xC4, - 0xB8, 0x00, 0x8B, 0x00, 0x8E, 0x00, 0xC2 -}; - -static const unsigned int s6e63m0_22_200[] = { - 0x18, 0x08, 0x24, 0x66, 0x55, 0x34, 0xBA, - 0xBD, 0xAB, 0xB1, 0xB5, 0xA3, 0xC5, 0xC6, - 0xB9, 0x00, 0x85, 0x00, 0x88, 0x00, 0xBA -}; - -static const unsigned int s6e63m0_22_170[] = { - 0x18, 0x08, 0x24, 0x69, 0x54, 0x37, 0xBB, - 0xBE, 0xAC, 0xB4, 0xB7, 0xA6, 0xC7, 0xC8, - 0xBC, 0x00, 0x7B, 0x00, 0x7E, 0x00, 0xAB -}; - -static const unsigned int s6e63m0_22_140[] = { - 0x18, 0x08, 0x24, 0x6C, 0x54, 0x3A, 0xBC, - 0xBF, 0xAC, 0xB7, 0xBB, 0xA9, 0xC9, 0xC9, - 0xBE, 0x00, 0x71, 0x00, 0x73, 0x00, 0x9E -}; - -static const unsigned int s6e63m0_22_110[] = { - 0x18, 0x08, 0x24, 0x70, 0x51, 0x3E, 0xBF, - 0xC1, 0xAF, 0xB9, 0xBC, 0xAB, 0xCC, 0xCC, - 0xC2, 0x00, 0x65, 0x00, 0x67, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_22_90[] = { - 0x18, 0x08, 0x24, 0x73, 0x4A, 0x3D, 0xC0, - 0xC2, 0xB1, 0xBB, 0xBE, 0xAC, 0xCE, 0xCF, - 0xC5, 0x00, 0x5D, 0x00, 0x5E, 0x00, 0x82 -}; - -static const unsigned int s6e63m0_22_30[] = { - 0x18, 0x08, 0x24, 0x78, 0xEC, 0x3D, 0xC8, - 0xC2, 0xB6, 0xC4, 0xC7, 0xB6, 0xD5, 0xD7, - 0xCC, 0x00, 0x39, 0x00, 0x36, 0x00, 0x51 -}; - -/* gamma value: 1.9 */ -static const unsigned int s6e63m0_19_300[] = { - 0x18, 0x08, 0x24, 0x61, 0x5F, 0x39, 0xBA, - 0xBD, 0xAD, 0xB1, 0xB6, 0xA5, 0xC4, 0xC5, - 0xBC, 0x00, 0xA0, 0x00, 0xA4, 0x00, 0xDB -}; - -static const unsigned int s6e63m0_19_280[] = { - 0x18, 0x08, 0x24, 0x61, 0x60, 0x39, 0xBB, - 0xBE, 0xAD, 0xB2, 0xB6, 0xA6, 0xC5, 0xC7, - 0xBD, 0x00, 0x9B, 0x00, 0x9E, 0x00, 0xD5 -}; - -static const unsigned int s6e63m0_19_260[] = { - 0x18, 0x08, 0x24, 0x63, 0x61, 0x3B, 0xBA, - 0xBE, 0xAC, 0xB3, 0xB8, 0xA7, 0xC6, 0xC8, - 0xBD, 0x00, 0x96, 0x00, 0x98, 0x00, 0xCF -}; - -static const unsigned int s6e63m0_19_240[] = { - 0x18, 0x08, 0x24, 0x67, 0x64, 0x3F, 0xBB, - 0xBE, 0xAD, 0xB3, 0xB9, 0xA7, 0xC8, 0xC9, - 0xBE, 0x00, 0x90, 0x00, 0x92, 0x00, 0xC8 -}; - -static const unsigned int s6e63m0_19_220[] = { - 0x18, 0x08, 0x24, 0x68, 0x64, 0x40, 0xBC, - 0xBF, 0xAF, 0xB4, 0xBA, 0xA9, 0xC8, 0xCA, - 0xBE, 0x00, 0x8B, 0x00, 0x8C, 0x00, 0xC0 -}; - -static const unsigned int s6e63m0_19_200[] = { - 0x18, 0x08, 0x24, 0x68, 0x64, 0x3F, 0xBE, - 0xC0, 0xB0, 0xB6, 0xBB, 0xAB, 0xC8, 0xCB, - 0xBF, 0x00, 0x85, 0x00, 0x86, 0x00, 0xB8 -}; - -static const unsigned int s6e63m0_19_170[] = { - 0x18, 0x08, 0x24, 0x69, 0x64, 0x40, 0xBF, - 0xC1, 0xB0, 0xB9, 0xBE, 0xAD, 0xCB, 0xCD, - 0xC2, 0x00, 0x7A, 0x00, 0x7B, 0x00, 0xAA -}; - -static const unsigned int s6e63m0_19_140[] = { - 0x18, 0x08, 0x24, 0x6E, 0x65, 0x45, 0xC0, - 0xC3, 0xB2, 0xBA, 0xBE, 0xAE, 0xCD, 0xD0, - 0xC4, 0x00, 0x70, 0x00, 0x70, 0x00, 0x9C -}; - -static const unsigned int s6e63m0_19_110[] = { - 0x18, 0x08, 0x24, 0x6F, 0x65, 0x46, 0xC2, - 0xC4, 0xB3, 0xBF, 0xC2, 0xB2, 0xCF, 0xD1, - 0xC6, 0x00, 0x64, 0x00, 0x64, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_19_90[] = { - 0x18, 0x08, 0x24, 0x74, 0x60, 0x4A, 0xC3, - 0xC6, 0xB5, 0xBF, 0xC3, 0xB2, 0xD2, 0xD3, - 0xC8, 0x00, 0x5B, 0x00, 0x5B, 0x00, 0x81 -}; - -static const unsigned int s6e63m0_19_30[] = { - 0x18, 0x08, 0x24, 0x84, 0x45, 0x4F, 0xCA, - 0xCB, 0xBC, 0xC9, 0xCB, 0xBC, 0xDA, 0xDA, - 0xD0, 0x00, 0x35, 0x00, 0x34, 0x00, 0x4E -}; - -/* gamma value: 1.7 */ -static const unsigned int s6e63m0_17_300[] = { - 0x18, 0x08, 0x24, 0x70, 0x70, 0x4F, 0xBF, - 0xC2, 0xB2, 0xB8, 0xBC, 0xAC, 0xCB, 0xCD, - 0xC3, 0x00, 0xA0, 0x00, 0xA4, 0x00, 0xDB -}; - -static const unsigned int s6e63m0_17_280[] = { - 0x18, 0x08, 0x24, 0x71, 0x71, 0x50, 0xBF, - 0xC2, 0xB2, 0xBA, 0xBE, 0xAE, 0xCB, 0xCD, - 0xC3, 0x00, 0x9C, 0x00, 0x9F, 0x00, 0xD6 -}; - -static const unsigned int s6e63m0_17_260[] = { - 0x18, 0x08, 0x24, 0x72, 0x72, 0x50, 0xC0, - 0xC3, 0xB4, 0xB9, 0xBE, 0xAE, 0xCC, 0xCF, - 0xC4, 0x00, 0x97, 0x00, 0x9A, 0x00, 0xD1 -}; - -static const unsigned int s6e63m0_17_240[] = { - 0x18, 0x08, 0x24, 0x71, 0x72, 0x4F, 0xC2, - 0xC4, 0xB5, 0xBB, 0xBF, 0xB0, 0xCC, 0xCF, - 0xC3, 0x00, 0x91, 0x00, 0x95, 0x00, 0xCA -}; - -static const unsigned int s6e63m0_17_220[] = { - 0x18, 0x08, 0x24, 0x71, 0x73, 0x4F, 0xC2, - 0xC5, 0xB5, 0xBD, 0xC0, 0xB2, 0xCD, 0xD1, - 0xC5, 0x00, 0x8B, 0x00, 0x8E, 0x00, 0xC2 -}; - -static const unsigned int s6e63m0_17_200[] = { - 0x18, 0x08, 0x24, 0x72, 0x75, 0x51, 0xC2, - 0xC6, 0xB5, 0xBF, 0xC1, 0xB3, 0xCE, 0xD1, - 0xC6, 0x00, 0x85, 0x00, 0x88, 0x00, 0xBA -}; - -static const unsigned int s6e63m0_17_170[] = { - 0x18, 0x08, 0x24, 0x75, 0x77, 0x54, 0xC3, - 0xC7, 0xB7, 0xC0, 0xC3, 0xB4, 0xD1, 0xD3, - 0xC9, 0x00, 0x7B, 0x00, 0x7E, 0x00, 0xAB -}; - -static const unsigned int s6e63m0_17_140[] = { - 0x18, 0x08, 0x24, 0x7B, 0x77, 0x58, 0xC3, - 0xC8, 0xB8, 0xC2, 0xC6, 0xB6, 0xD3, 0xD4, - 0xCA, 0x00, 0x71, 0x00, 0x73, 0x00, 0x9E -}; - -static const unsigned int s6e63m0_17_110[] = { - 0x18, 0x08, 0x24, 0x81, 0x7B, 0x5D, 0xC6, - 0xCA, 0xBB, 0xC3, 0xC7, 0xB8, 0xD6, 0xD8, - 0xCD, 0x00, 0x65, 0x00, 0x67, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_17_90[] = { - 0x18, 0x08, 0x24, 0x82, 0x7A, 0x5B, 0xC8, - 0xCB, 0xBD, 0xC5, 0xCA, 0xBA, 0xD6, 0xD8, - 0xCE, 0x00, 0x5D, 0x00, 0x5E, 0x00, 0x82 -}; - -static const unsigned int s6e63m0_17_30[] = { - 0x18, 0x08, 0x24, 0x8F, 0x73, 0x63, 0xD1, - 0xD0, 0xC5, 0xCC, 0xD1, 0xC2, 0xDE, 0xE0, - 0xD6, 0x00, 0x39, 0x00, 0x36, 0x00, 0x51 -}; - -struct s6e63m0_gamma { - unsigned int *gamma_22_table[MAX_GAMMA_LEVEL]; - unsigned int *gamma_19_table[MAX_GAMMA_LEVEL]; - unsigned int *gamma_17_table[MAX_GAMMA_LEVEL]; -}; - -static struct s6e63m0_gamma gamma_table = { - .gamma_22_table[0] = (unsigned int *)&s6e63m0_22_30, - .gamma_22_table[1] = (unsigned int *)&s6e63m0_22_90, - .gamma_22_table[2] = (unsigned int *)&s6e63m0_22_110, - .gamma_22_table[3] = (unsigned int *)&s6e63m0_22_140, - .gamma_22_table[4] = (unsigned int *)&s6e63m0_22_170, - .gamma_22_table[5] = (unsigned int *)&s6e63m0_22_200, - .gamma_22_table[6] = (unsigned int *)&s6e63m0_22_220, - .gamma_22_table[7] = (unsigned int *)&s6e63m0_22_240, - .gamma_22_table[8] = (unsigned int *)&s6e63m0_22_260, - .gamma_22_table[9] = (unsigned int *)&s6e63m0_22_280, - .gamma_22_table[10] = (unsigned int *)&s6e63m0_22_300, - - .gamma_19_table[0] = (unsigned int *)&s6e63m0_19_30, - .gamma_19_table[1] = (unsigned int *)&s6e63m0_19_90, - .gamma_19_table[2] = (unsigned int *)&s6e63m0_19_110, - .gamma_19_table[3] = (unsigned int *)&s6e63m0_19_140, - .gamma_19_table[4] = (unsigned int *)&s6e63m0_19_170, - .gamma_19_table[5] = (unsigned int *)&s6e63m0_19_200, - .gamma_19_table[6] = (unsigned int *)&s6e63m0_19_220, - .gamma_19_table[7] = (unsigned int *)&s6e63m0_19_240, - .gamma_19_table[8] = (unsigned int *)&s6e63m0_19_260, - .gamma_19_table[9] = (unsigned int *)&s6e63m0_19_280, - .gamma_19_table[10] = (unsigned int *)&s6e63m0_19_300, - - .gamma_17_table[0] = (unsigned int *)&s6e63m0_17_30, - .gamma_17_table[1] = (unsigned int *)&s6e63m0_17_90, - .gamma_17_table[2] = (unsigned int *)&s6e63m0_17_110, - .gamma_17_table[3] = (unsigned int *)&s6e63m0_17_140, - .gamma_17_table[4] = (unsigned int *)&s6e63m0_17_170, - .gamma_17_table[5] = (unsigned int *)&s6e63m0_17_200, - .gamma_17_table[6] = (unsigned int *)&s6e63m0_17_220, - .gamma_17_table[7] = (unsigned int *)&s6e63m0_17_240, - .gamma_17_table[8] = (unsigned int *)&s6e63m0_17_260, - .gamma_17_table[9] = (unsigned int *)&s6e63m0_17_280, - .gamma_17_table[10] = (unsigned int *)&s6e63m0_17_300, -}; - -#endif - -- 2.14.1 From mboxrd@z Thu Jan 1 00:00:00 1970 From: Krzysztof Kozlowski Subject: [PATCH v2 1/2] backlight: Remove s6e63m0 driver Date: Sun, 2 Sep 2018 17:22:31 +0200 Message-ID: <20180902152232.5802-1-krzk@kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by gabe.freedesktop.org (Postfix) with ESMTPS id 666E06E046 for ; Sun, 2 Sep 2018 15:23:01 +0000 (UTC) List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: Donghwa Lee , Lee Jones , Daniel Thompson , Jingoo Han , Bartlomiej Zolnierkiewicz , Krzysztof Kozlowski , Jonathan Corbet , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org Cc: Marek Szyprowski List-Id: dri-devel@lists.freedesktop.org VGhlIGRyaXZlciBmb3IgUzZFNjNNMCBBTU9MRUQgTENEIHBhbmVsIGlzIG5vdCB1c2VkLiAgSXQg ZG9lcyBub3QKc3VwcG9ydCBEZXZpY2VUcmVlIGFuZCByZXNwZWN0aXZlIHBvc3NpYmxlIHVzZXJz IChTNVB2MjEwIEFxdWlsYSBhbmQKR29uaSBib2FyZHMpIGFyZSBEZXZpY2VUcmVlLW9ubHkuCgpT dWdnZXN0ZWQtYnk6IE1hcmVrIFN6eXByb3dza2kgPG0uc3p5cHJvd3NraUBzYW1zdW5nLmNvbT4K Q2M6IE1hcmVrIFN6eXByb3dza2kgPG0uc3p5cHJvd3NraUBzYW1zdW5nLmNvbT4KQ2M6IElua2kg RGFlIDxpbmtpLmRhZUBzYW1zdW5nLmNvbT4KU2lnbmVkLW9mZi1ieTogS3J6eXN6dG9mIEtvemxv d3NraSA8a3J6a0BrZXJuZWwub3JnPgpBY2tlZC1ieTogSmluZ29vIEhhbiA8amluZ29vaGFuMUBn bWFpbC5jb20+CkFja2VkLWJ5OiBEYW5pZWwgVGhvbXBzb24gPGRhbmllbC50aG9tcHNvbkBsaW5h cm8ub3JnPgoKLS0tCgpDaGFuZ2VzIHNpbmNlIHYxOgoxLiBSZW1vdmUgc3lzZnMgQUJJIGRvY3Vt ZW50YXRpb24gZmlsZS4KMi4gQWRkIEppbmdvbydzIGFuZCBEYW5pZWwncyBhY2tzLgotLS0KIERv Y3VtZW50YXRpb24vQUJJL3Rlc3Rpbmcvc3lzZnMtY2xhc3MtbGNkLXM2ZTYzbTAgfCAgMjcgLQog ZHJpdmVycy92aWRlby9iYWNrbGlnaHQvS2NvbmZpZyAgICAgICAgICAgICAgICAgICB8ICAgOCAt CiBkcml2ZXJzL3ZpZGVvL2JhY2tsaWdodC9NYWtlZmlsZSAgICAgICAgICAgICAgICAgIHwgICAx IC0KIGRyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L3M2ZTYzbTAuYyAgICAgICAgICAgICAgICAgfCA4 NTcgLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogZHJpdmVycy92aWRlby9iYWNrbGlnaHQvczZlNjNt MF9nYW1tYS5oICAgICAgICAgICB8IDI2NiAtLS0tLS0tCiA1IGZpbGVzIGNoYW5nZWQsIDExNTkg ZGVsZXRpb25zKC0pCiBkZWxldGUgbW9kZSAxMDA2NDQgRG9jdW1lbnRhdGlvbi9BQkkvdGVzdGlu Zy9zeXNmcy1jbGFzcy1sY2QtczZlNjNtMAogZGVsZXRlIG1vZGUgMTAwNjQ0IGRyaXZlcnMvdmlk ZW8vYmFja2xpZ2h0L3M2ZTYzbTAuYwogZGVsZXRlIG1vZGUgMTAwNjQ0IGRyaXZlcnMvdmlkZW8v YmFja2xpZ2h0L3M2ZTYzbTBfZ2FtbWEuaAoKZGlmZiAtLWdpdCBhL0RvY3VtZW50YXRpb24vQUJJ L3Rlc3Rpbmcvc3lzZnMtY2xhc3MtbGNkLXM2ZTYzbTAgYi9Eb2N1bWVudGF0aW9uL0FCSS90ZXN0 aW5nL3N5c2ZzLWNsYXNzLWxjZC1zNmU2M20wCmRlbGV0ZWQgZmlsZSBtb2RlIDEwMDY0NAppbmRl eCBhZTBhMmQzZGNjMDcuLjAwMDAwMDAwMDAwMAotLS0gYS9Eb2N1bWVudGF0aW9uL0FCSS90ZXN0 aW5nL3N5c2ZzLWNsYXNzLWxjZC1zNmU2M20wCisrKyAvZGV2L251bGwKQEAgLTEsMjcgKzAsMCBA QAotc3lzZnMgaW50ZXJmYWNlIGZvciB0aGUgUzZFNjNNMCBBTU9MRUQgTENEIHBhbmVsIGRyaXZl cgotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0t LQotCi1XaGF0OgkJL3N5cy9jbGFzcy9sY2QvPGxjZD4vZ2FtbWFfbW9kZQotRGF0ZToJCU1heSwg MjAxMAotS2VybmVsVmVyc2lvbjoJdjIuNi4zNQotQ29udGFjdDoJZHJpLWRldmVsQGxpc3RzLmZy ZWVkZXNrdG9wLm9yZwotRGVzY3JpcHRpb246Ci0JCShSVykgUmVhZCBvciB3cml0ZSB0aGUgZ2Ft bWEgbW9kZS4gRm9sbG93aW5nIHRocmVlIG1vZGVzIGFyZQotCQlzdXBwb3J0ZWQ6Ci0JCTAgLSBn YW1tYSB2YWx1ZSAyLjIsCi0JCTEgLSBnYW1tYSB2YWx1ZSAxLjkgYW5kCi0JCTIgLSBnYW1tYSB2 YWx1ZSAxLjcuCi0KLQotV2hhdDoJCS9zeXMvY2xhc3MvbGNkLzxsY2Q+L2dhbW1hX3RhYmxlCi1E YXRlOgkJTWF5LCAyMDEwCi1LZXJuZWxWZXJzaW9uOgl2Mi42LjM1Ci1Db250YWN0OglkcmktZGV2 ZWxAbGlzdHMuZnJlZWRlc2t0b3Aub3JnCi1EZXNjcmlwdGlvbjoKLQkJKFJPKSBEaXNwbGF5cyB0 aGUgc2l6ZSBvZiB0aGUgZ2FtbWEgdGFibGUgaS5lLiB0aGUgbnVtYmVyIG9mCi0JCWdhbW1hIG1v ZGVzIGF2YWlsYWJsZS4KLQotVGhpcyBpcyBhIGJhY2tsaWdodCBsY2QgZHJpdmVyLiBUaGVzZSBp bnRlcmZhY2VzIGFyZSBhbiBleHRlbnNpb24gdG8gdGhlIEFQSQotZG9jdW1lbnRlZCBpbiBEb2N1 bWVudGF0aW9uL0FCSS90ZXN0aW5nL3N5c2ZzLWNsYXNzLWxjZCBhbmQgaW4KLURvY3VtZW50YXRp b24vQUJJL3N0YWJsZS9zeXNmcy1jbGFzcy1iYWNrbGlnaHQgKHVuZGVyCi0vc3lzL2NsYXNzL2Jh Y2tsaWdodC88YmFja2xpZ2h0Pi8pLgpkaWZmIC0tZ2l0IGEvZHJpdmVycy92aWRlby9iYWNrbGln aHQvS2NvbmZpZyBiL2RyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L0tjb25maWcKaW5kZXggMjkxOWUy MzM0MDUyLi4yMzczYzNjZWMwYzMgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvdmlkZW8vYmFja2xpZ2h0 L0tjb25maWcKKysrIGIvZHJpdmVycy92aWRlby9iYWNrbGlnaHQvS2NvbmZpZwpAQCAtMTExLDE0 ICsxMTEsNiBAQCBjb25maWcgTENEX0hQNzAwCiAJICBJZiB5b3UgaGF2ZSBhbiBIUCBKb3JuYWRh IDcwMCBzZXJpZXMgaGFuZGhlbGQgKDcxMC83MjAvNzI4KQogCSAgc2F5IFkgdG8gZW5hYmxlIExD RCBjb250cm9sIGRyaXZlci4KIAotY29uZmlnIExDRF9TNkU2M00wCi0JdHJpc3RhdGUgIlM2RTYz TTAgQU1PTEVEIExDRCBEcml2ZXIiCi0JZGVwZW5kcyBvbiBTUEkgJiYgQkFDS0xJR0hUX0NMQVNT X0RFVklDRQotCWRlZmF1bHQgbgotCWhlbHAKLQkgIElmIHlvdSBoYXZlIGFuIFM2RTYzTTAgTENE IFBhbmVsLCBzYXkgWSB0byBlbmFibGUgaXRzCi0JICBMQ0QgY29udHJvbCBkcml2ZXIuCi0KIGNv bmZpZyBMQ0RfTEQ5MDQwCiAJdHJpc3RhdGUgIkxEOTA0MCBBTU9MRUQgTENEIERyaXZlciIKIAlk ZXBlbmRzIG9uIFNQSSAmJiBCQUNLTElHSFRfQ0xBU1NfREVWSUNFCmRpZmYgLS1naXQgYS9kcml2 ZXJzL3ZpZGVvL2JhY2tsaWdodC9NYWtlZmlsZSBiL2RyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L01h a2VmaWxlCmluZGV4IDBkY2MyYzc0NWMwMy4uYzdhNDYzOTJhNzZmIDEwMDY0NAotLS0gYS9kcml2 ZXJzL3ZpZGVvL2JhY2tsaWdodC9NYWtlZmlsZQorKysgYi9kcml2ZXJzL3ZpZGVvL2JhY2tsaWdo dC9NYWtlZmlsZQpAQCAtMTUsNyArMTUsNiBAQCBvYmotJChDT05GSUdfTENEX0xNUzUwMUtGMDMp CQkrPSBsbXM1MDFrZjAzLm8KIG9iai0kKENPTkZJR19MQ0RfTFRWMzUwUVYpCQkrPSBsdHYzNTBx di5vCiBvYmotJChDT05GSUdfTENEX09UTTMyMjVBKQkJKz0gb3RtMzIyNWEubwogb2JqLSQoQ09O RklHX0xDRF9QTEFURk9STSkJCSs9IHBsYXRmb3JtX2xjZC5vCi1vYmotJChDT05GSUdfTENEX1M2 RTYzTTApCQkrPSBzNmU2M20wLm8KIG9iai0kKENPTkZJR19MQ0RfVERPMjRNKQkJKz0gdGRvMjRt Lm8KIG9iai0kKENPTkZJR19MQ0RfVE9TQSkJCQkrPSB0b3NhX2xjZC5vCiBvYmotJChDT05GSUdf TENEX1ZHRzI0MzJBNCkJCSs9IHZnZzI0MzJhNC5vCmRpZmYgLS1naXQgYS9kcml2ZXJzL3ZpZGVv L2JhY2tsaWdodC9zNmU2M20wLmMgYi9kcml2ZXJzL3ZpZGVvL2JhY2tsaWdodC9zNmU2M20wLmMK ZGVsZXRlZCBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDNjNGEyMmEzMDYzYS4uMDAwMDAwMDAwMDAw Ci0tLSBhL2RyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L3M2ZTYzbTAuYworKysgL2Rldi9udWxsCkBA IC0xLDg1NyArMCwwIEBACi0vKgotICogUzZFNjNNMCBBTU9MRUQgTENEIHBhbmVsIGRyaXZlci4K LSAqCi0gKiBBdXRob3I6IEluS2kgRGFlICA8aW5raS5kYWVAc2Ftc3VuZy5jb20+Ci0gKgotICog RGVyaXZlZCBmcm9tIGRyaXZlcnMvdmlkZW8vb21hcC9sY2QtYXBvbGxvbi5jCi0gKgotICogVGhp cyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9v ciBtb2RpZnkgaXQKLSAqIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGlj IExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5IHRoZQotICogRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9u OyBlaXRoZXIgdmVyc2lvbiAyIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91cgotICogb3B0aW9u KSBhbnkgbGF0ZXIgdmVyc2lvbi4KLSAqLwotCi0jaW5jbHVkZSA8bGludXgvYmFja2xpZ2h0Lmg+ Ci0jaW5jbHVkZSA8bGludXgvZGVsYXkuaD4KLSNpbmNsdWRlIDxsaW51eC9mYi5oPgotI2luY2x1 ZGUgPGxpbnV4L2dwaW8uaD4KLSNpbmNsdWRlIDxsaW51eC9pbnRlcnJ1cHQuaD4KLSNpbmNsdWRl IDxsaW51eC9pcnEuaD4KLSNpbmNsdWRlIDxsaW51eC9rZXJuZWwuaD4KLSNpbmNsdWRlIDxsaW51 eC9sY2QuaD4KLSNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4KLSNpbmNsdWRlIDxsaW51eC9zcGkv c3BpLmg+Ci0jaW5jbHVkZSA8bGludXgvd2FpdC5oPgotCi0jaW5jbHVkZSAiczZlNjNtMF9nYW1t YS5oIgotCi0jZGVmaW5lIFNMRUVQTVNFQwkJMHgxMDAwCi0jZGVmaW5lIEVORERFRgkJCTB4MjAw MAotI2RlZmluZQlERUZNQVNLCQkJMHhGRjAwCi0jZGVmaW5lIENPTU1BTkRfT05MWQkJMHhGRQot I2RlZmluZSBEQVRBX09OTFkJCTB4RkYKLQotI2RlZmluZSBNSU5fQlJJR0hUTkVTUwkJMAotI2Rl ZmluZSBNQVhfQlJJR0hUTkVTUwkJMTAKLQotc3RydWN0IHM2ZTYzbTAgewotCXN0cnVjdCBkZXZp Y2UJCQkqZGV2OwotCXN0cnVjdCBzcGlfZGV2aWNlCQkqc3BpOwotCXVuc2lnbmVkIGludAkJCXBv d2VyOwotCXVuc2lnbmVkIGludAkJCWN1cnJlbnRfYnJpZ2h0bmVzczsKLQl1bnNpZ25lZCBpbnQJ CQlnYW1tYV9tb2RlOwotCXVuc2lnbmVkIGludAkJCWdhbW1hX3RhYmxlX2NvdW50OwotCXN0cnVj dCBsY2RfZGV2aWNlCQkqbGQ7Ci0Jc3RydWN0IGJhY2tsaWdodF9kZXZpY2UJCSpiZDsKLQlzdHJ1 Y3QgbGNkX3BsYXRmb3JtX2RhdGEJKmxjZF9wZDsKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25l ZCBzaG9ydCBzZXFfcGFuZWxfY29uZGl0aW9uX3NldFtdID0gewotCTB4RjgsIDB4MDEsCi0JREFU QV9PTkxZLCAweDI3LAotCURBVEFfT05MWSwgMHgyNywKLQlEQVRBX09OTFksIDB4MDcsCi0JREFU QV9PTkxZLCAweDA3LAotCURBVEFfT05MWSwgMHg1NCwKLQlEQVRBX09OTFksIDB4OWYsCi0JREFU QV9PTkxZLCAweDYzLAotCURBVEFfT05MWSwgMHg4NiwKLQlEQVRBX09OTFksIDB4MWEsCi0JREFU QV9PTkxZLCAweDMzLAotCURBVEFfT05MWSwgMHgwZCwKLQlEQVRBX09OTFksIDB4MDAsCi0JREFU QV9PTkxZLCAweDAwLAotCi0JRU5EREVGLCAweDAwMDAKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNp Z25lZCBzaG9ydCBzZXFfZGlzcGxheV9jb25kaXRpb25fc2V0W10gPSB7Ci0JMHhmMiwgMHgwMiwK LQlEQVRBX09OTFksIDB4MDMsCi0JREFUQV9PTkxZLCAweDFjLAotCURBVEFfT05MWSwgMHgxMCwK LQlEQVRBX09OTFksIDB4MTAsCi0KLQkweGY3LCAweDAzLAotCURBVEFfT05MWSwgMHgwMCwKLQlE QVRBX09OTFksIDB4MDAsCi0KLQlFTkRERUYsIDB4MDAwMAotfTsKLQotc3RhdGljIGNvbnN0IHVu c2lnbmVkIHNob3J0IHNlcV9nYW1tYV9zZXR0aW5nW10gPSB7Ci0JMHhmYSwgMHgwMCwKLQlEQVRB X09OTFksIDB4MTgsCi0JREFUQV9PTkxZLCAweDA4LAotCURBVEFfT05MWSwgMHgyNCwKLQlEQVRB X09OTFksIDB4NjQsCi0JREFUQV9PTkxZLCAweDU2LAotCURBVEFfT05MWSwgMHgzMywKLQlEQVRB X09OTFksIDB4YjYsCi0JREFUQV9PTkxZLCAweGJhLAotCURBVEFfT05MWSwgMHhhOCwKLQlEQVRB X09OTFksIDB4YWMsCi0JREFUQV9PTkxZLCAweGIxLAotCURBVEFfT05MWSwgMHg5ZCwKLQlEQVRB X09OTFksIDB4YzEsCi0JREFUQV9PTkxZLCAweGMxLAotCURBVEFfT05MWSwgMHhiNywKLQlEQVRB X09OTFksIDB4MDAsCi0JREFUQV9PTkxZLCAweDljLAotCURBVEFfT05MWSwgMHgwMCwKLQlEQVRB X09OTFksIDB4OWYsCi0JREFUQV9PTkxZLCAweDAwLAotCURBVEFfT05MWSwgMHhkNiwKLQotCTB4 ZmEsIDB4MDEsCi0KLQlFTkRERUYsIDB4MDAwMAotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVk IHNob3J0IHNlcV9ldGNfY29uZGl0aW9uX3NldFtdID0gewotCTB4ZjYsIDB4MDAsCi0JREFUQV9P TkxZLCAweDhjLAotCURBVEFfT05MWSwgMHgwNywKLQotCTB4YjMsIDB4YywKLQotCTB4YjUsIDB4 MmMsCi0JREFUQV9PTkxZLCAweDEyLAotCURBVEFfT05MWSwgMHgwYywKLQlEQVRBX09OTFksIDB4 MGEsCi0JREFUQV9PTkxZLCAweDEwLAotCURBVEFfT05MWSwgMHgwZSwKLQlEQVRBX09OTFksIDB4 MTcsCi0JREFUQV9PTkxZLCAweDEzLAotCURBVEFfT05MWSwgMHgxZiwKLQlEQVRBX09OTFksIDB4 MWEsCi0JREFUQV9PTkxZLCAweDJhLAotCURBVEFfT05MWSwgMHgyNCwKLQlEQVRBX09OTFksIDB4 MWYsCi0JREFUQV9PTkxZLCAweDFiLAotCURBVEFfT05MWSwgMHgxYSwKLQlEQVRBX09OTFksIDB4 MTcsCi0KLQlEQVRBX09OTFksIDB4MmIsCi0JREFUQV9PTkxZLCAweDI2LAotCURBVEFfT05MWSwg MHgyMiwKLQlEQVRBX09OTFksIDB4MjAsCi0JREFUQV9PTkxZLCAweDNhLAotCURBVEFfT05MWSwg MHgzNCwKLQlEQVRBX09OTFksIDB4MzAsCi0JREFUQV9PTkxZLCAweDJjLAotCURBVEFfT05MWSwg MHgyOSwKLQlEQVRBX09OTFksIDB4MjYsCi0JREFUQV9PTkxZLCAweDI1LAotCURBVEFfT05MWSwg MHgyMywKLQlEQVRBX09OTFksIDB4MjEsCi0JREFUQV9PTkxZLCAweDIwLAotCURBVEFfT05MWSwg MHgxZSwKLQlEQVRBX09OTFksIDB4MWUsCi0KLQkweGI2LCAweDAwLAotCURBVEFfT05MWSwgMHgw MCwKLQlEQVRBX09OTFksIDB4MTEsCi0JREFUQV9PTkxZLCAweDIyLAotCURBVEFfT05MWSwgMHgz MywKLQlEQVRBX09OTFksIDB4NDQsCi0JREFUQV9PTkxZLCAweDQ0LAotCURBVEFfT05MWSwgMHg0 NCwKLQotCURBVEFfT05MWSwgMHg1NSwKLQlEQVRBX09OTFksIDB4NTUsCi0JREFUQV9PTkxZLCAw eDY2LAotCURBVEFfT05MWSwgMHg2NiwKLQlEQVRBX09OTFksIDB4NjYsCi0JREFUQV9PTkxZLCAw eDY2LAotCURBVEFfT05MWSwgMHg2NiwKLQlEQVRBX09OTFksIDB4NjYsCi0KLQkweGI3LCAweDJj LAotCURBVEFfT05MWSwgMHgxMiwKLQlEQVRBX09OTFksIDB4MGMsCi0JREFUQV9PTkxZLCAweDBh LAotCURBVEFfT05MWSwgMHgxMCwKLQlEQVRBX09OTFksIDB4MGUsCi0JREFUQV9PTkxZLCAweDE3 LAotCURBVEFfT05MWSwgMHgxMywKLQlEQVRBX09OTFksIDB4MWYsCi0JREFUQV9PTkxZLCAweDFh LAotCURBVEFfT05MWSwgMHgyYSwKLQlEQVRBX09OTFksIDB4MjQsCi0JREFUQV9PTkxZLCAweDFm LAotCURBVEFfT05MWSwgMHgxYiwKLQlEQVRBX09OTFksIDB4MWEsCi0JREFUQV9PTkxZLCAweDE3 LAotCi0JREFUQV9PTkxZLCAweDJiLAotCURBVEFfT05MWSwgMHgyNiwKLQlEQVRBX09OTFksIDB4 MjIsCi0JREFUQV9PTkxZLCAweDIwLAotCURBVEFfT05MWSwgMHgzYSwKLQlEQVRBX09OTFksIDB4 MzQsCi0JREFUQV9PTkxZLCAweDMwLAotCURBVEFfT05MWSwgMHgyYywKLQlEQVRBX09OTFksIDB4 MjksCi0JREFUQV9PTkxZLCAweDI2LAotCURBVEFfT05MWSwgMHgyNSwKLQlEQVRBX09OTFksIDB4 MjMsCi0JREFUQV9PTkxZLCAweDIxLAotCURBVEFfT05MWSwgMHgyMCwKLQlEQVRBX09OTFksIDB4 MWUsCi0JREFUQV9PTkxZLCAweDFlLAotCi0JMHhiOCwgMHgwMCwKLQlEQVRBX09OTFksIDB4MDAs Ci0JREFUQV9PTkxZLCAweDExLAotCURBVEFfT05MWSwgMHgyMiwKLQlEQVRBX09OTFksIDB4MzMs Ci0JREFUQV9PTkxZLCAweDQ0LAotCURBVEFfT05MWSwgMHg0NCwKLQlEQVRBX09OTFksIDB4NDQs Ci0KLQlEQVRBX09OTFksIDB4NTUsCi0JREFUQV9PTkxZLCAweDU1LAotCURBVEFfT05MWSwgMHg2 NiwKLQlEQVRBX09OTFksIDB4NjYsCi0JREFUQV9PTkxZLCAweDY2LAotCURBVEFfT05MWSwgMHg2 NiwKLQlEQVRBX09OTFksIDB4NjYsCi0JREFUQV9PTkxZLCAweDY2LAotCi0JMHhiOSwgMHgyYywK LQlEQVRBX09OTFksIDB4MTIsCi0JREFUQV9PTkxZLCAweDBjLAotCURBVEFfT05MWSwgMHgwYSwK LQlEQVRBX09OTFksIDB4MTAsCi0JREFUQV9PTkxZLCAweDBlLAotCURBVEFfT05MWSwgMHgxNywK LQlEQVRBX09OTFksIDB4MTMsCi0JREFUQV9PTkxZLCAweDFmLAotCURBVEFfT05MWSwgMHgxYSwK LQlEQVRBX09OTFksIDB4MmEsCi0JREFUQV9PTkxZLCAweDI0LAotCURBVEFfT05MWSwgMHgxZiwK LQlEQVRBX09OTFksIDB4MWIsCi0JREFUQV9PTkxZLCAweDFhLAotCURBVEFfT05MWSwgMHgxNywK LQotCURBVEFfT05MWSwgMHgyYiwKLQlEQVRBX09OTFksIDB4MjYsCi0JREFUQV9PTkxZLCAweDIy LAotCURBVEFfT05MWSwgMHgyMCwKLQlEQVRBX09OTFksIDB4M2EsCi0JREFUQV9PTkxZLCAweDM0 LAotCURBVEFfT05MWSwgMHgzMCwKLQlEQVRBX09OTFksIDB4MmMsCi0JREFUQV9PTkxZLCAweDI5 LAotCURBVEFfT05MWSwgMHgyNiwKLQlEQVRBX09OTFksIDB4MjUsCi0JREFUQV9PTkxZLCAweDIz LAotCURBVEFfT05MWSwgMHgyMSwKLQlEQVRBX09OTFksIDB4MjAsCi0JREFUQV9PTkxZLCAweDFl LAotCURBVEFfT05MWSwgMHgxZSwKLQotCTB4YmEsIDB4MDAsCi0JREFUQV9PTkxZLCAweDAwLAot CURBVEFfT05MWSwgMHgxMSwKLQlEQVRBX09OTFksIDB4MjIsCi0JREFUQV9PTkxZLCAweDMzLAot CURBVEFfT05MWSwgMHg0NCwKLQlEQVRBX09OTFksIDB4NDQsCi0JREFUQV9PTkxZLCAweDQ0LAot Ci0JREFUQV9PTkxZLCAweDU1LAotCURBVEFfT05MWSwgMHg1NSwKLQlEQVRBX09OTFksIDB4NjYs Ci0JREFUQV9PTkxZLCAweDY2LAotCURBVEFfT05MWSwgMHg2NiwKLQlEQVRBX09OTFksIDB4NjYs Ci0JREFUQV9PTkxZLCAweDY2LAotCURBVEFfT05MWSwgMHg2NiwKLQotCTB4YzEsIDB4NGQsCi0J REFUQV9PTkxZLCAweDk2LAotCURBVEFfT05MWSwgMHgxZCwKLQlEQVRBX09OTFksIDB4MDAsCi0J REFUQV9PTkxZLCAweDAwLAotCURBVEFfT05MWSwgMHgwMSwKLQlEQVRBX09OTFksIDB4ZGYsCi0J REFUQV9PTkxZLCAweDAwLAotCURBVEFfT05MWSwgMHgwMCwKLQlEQVRBX09OTFksIDB4MDMsCi0J REFUQV9PTkxZLCAweDFmLAotCURBVEFfT05MWSwgMHgwMCwKLQlEQVRBX09OTFksIDB4MDAsCi0J REFUQV9PTkxZLCAweDAwLAotCURBVEFfT05MWSwgMHgwMCwKLQlEQVRBX09OTFksIDB4MDAsCi0J REFUQV9PTkxZLCAweDAwLAotCURBVEFfT05MWSwgMHgwMCwKLQlEQVRBX09OTFksIDB4MDAsCi0J REFUQV9PTkxZLCAweDAzLAotCURBVEFfT05MWSwgMHgwNiwKLQlEQVRBX09OTFksIDB4MDksCi0J REFUQV9PTkxZLCAweDBkLAotCURBVEFfT05MWSwgMHgwZiwKLQlEQVRBX09OTFksIDB4MTIsCi0J REFUQV9PTkxZLCAweDE1LAotCURBVEFfT05MWSwgMHgxOCwKLQotCTB4YjIsIDB4MTAsCi0JREFU QV9PTkxZLCAweDEwLAotCURBVEFfT05MWSwgMHgwYiwKLQlEQVRBX09OTFksIDB4MDUsCi0KLQlF TkRERUYsIDB4MDAwMAotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIHNob3J0IHNlcV9hY2xf b25bXSA9IHsKLQkvKiBBQ0wgb24gKi8KLQkweGMwLCAweDAxLAotCi0JRU5EREVGLCAweDAwMDAK LX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBzaG9ydCBzZXFfYWNsX29mZltdID0gewotCS8q IEFDTCBvZmYgKi8KLQkweGMwLCAweDAwLAotCi0JRU5EREVGLCAweDAwMDAKLX07Ci0KLXN0YXRp YyBjb25zdCB1bnNpZ25lZCBzaG9ydCBzZXFfZWx2c3Nfb25bXSA9IHsKLQkvKiBFTFZTUyBvbiAq LwotCTB4YjEsIDB4MGIsCi0KLQlFTkRERUYsIDB4MDAwMAotfTsKLQotc3RhdGljIGNvbnN0IHVu c2lnbmVkIHNob3J0IHNlcV9lbHZzc19vZmZbXSA9IHsKLQkvKiBFTFZTUyBvZmYgKi8KLQkweGIx LCAweDBhLAotCi0JRU5EREVGLCAweDAwMDAKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBz aG9ydCBzZXFfc3RhbmRfYnlfb2ZmW10gPSB7Ci0JMHgxMSwgQ09NTUFORF9PTkxZLAotCi0JRU5E REVGLCAweDAwMDAKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBzaG9ydCBzZXFfc3RhbmRf Ynlfb25bXSA9IHsKLQkweDEwLCBDT01NQU5EX09OTFksCi0KLQlFTkRERUYsIDB4MDAwMAotfTsK LQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIHNob3J0IHNlcV9kaXNwbGF5X29uW10gPSB7Ci0JMHgy OSwgQ09NTUFORF9PTkxZLAotCi0JRU5EREVGLCAweDAwMDAKLX07Ci0KLQotc3RhdGljIGludCBz NmU2M20wX3NwaV93cml0ZV9ieXRlKHN0cnVjdCBzNmU2M20wICpsY2QsIGludCBhZGRyLCBpbnQg ZGF0YSkKLXsKLQl1MTYgYnVmWzFdOwotCXN0cnVjdCBzcGlfbWVzc2FnZSBtc2c7Ci0KLQlzdHJ1 Y3Qgc3BpX3RyYW5zZmVyIHhmZXIgPSB7Ci0JCS5sZW4JCT0gMiwKLQkJLnR4X2J1ZgkJPSBidWYs Ci0JfTsKLQotCWJ1ZlswXSA9IChhZGRyIDw8IDgpIHwgZGF0YTsKLQotCXNwaV9tZXNzYWdlX2lu aXQoJm1zZyk7Ci0Jc3BpX21lc3NhZ2VfYWRkX3RhaWwoJnhmZXIsICZtc2cpOwotCi0JcmV0dXJu IHNwaV9zeW5jKGxjZC0+c3BpLCAmbXNnKTsKLX0KLQotc3RhdGljIGludCBzNmU2M20wX3NwaV93 cml0ZShzdHJ1Y3QgczZlNjNtMCAqbGNkLCB1bnNpZ25lZCBjaGFyIGFkZHJlc3MsCi0JdW5zaWdu ZWQgY2hhciBjb21tYW5kKQotewotCWludCByZXQgPSAwOwotCi0JaWYgKGFkZHJlc3MgIT0gREFU QV9PTkxZKQotCQlyZXQgPSBzNmU2M20wX3NwaV93cml0ZV9ieXRlKGxjZCwgMHgwLCBhZGRyZXNz KTsKLQlpZiAoY29tbWFuZCAhPSBDT01NQU5EX09OTFkpCi0JCXJldCA9IHM2ZTYzbTBfc3BpX3dy aXRlX2J5dGUobGNkLCAweDEsIGNvbW1hbmQpOwotCi0JcmV0dXJuIHJldDsKLX0KLQotc3RhdGlj IGludCBzNmU2M20wX3BhbmVsX3NlbmRfc2VxdWVuY2Uoc3RydWN0IHM2ZTYzbTAgKmxjZCwKLQlj b25zdCB1bnNpZ25lZCBzaG9ydCAqd2J1ZikKLXsKLQlpbnQgcmV0ID0gMCwgaSA9IDA7Ci0KLQl3 aGlsZSAoKHdidWZbaV0gJiBERUZNQVNLKSAhPSBFTkRERUYpIHsKLQkJaWYgKCh3YnVmW2ldICYg REVGTUFTSykgIT0gU0xFRVBNU0VDKSB7Ci0JCQlyZXQgPSBzNmU2M20wX3NwaV93cml0ZShsY2Qs IHdidWZbaV0sIHdidWZbaSsxXSk7Ci0JCQlpZiAocmV0KQotCQkJCWJyZWFrOwotCQl9IGVsc2Ug ewotCQkJbXNsZWVwKHdidWZbaSsxXSk7Ci0JCX0KLQkJaSArPSAyOwotCX0KLQotCXJldHVybiBy ZXQ7Ci19Ci0KLXN0YXRpYyBpbnQgX3M2ZTYzbTBfZ2FtbWFfY3RsKHN0cnVjdCBzNmU2M20wICps Y2QsIGNvbnN0IHVuc2lnbmVkIGludCAqZ2FtbWEpCi17Ci0JdW5zaWduZWQgaW50IGkgPSAwOwot CWludCByZXQgPSAwOwotCi0JLyogZGlzYWJsZSBnYW1tYSB0YWJsZSB1cGRhdGluZy4gKi8KLQly ZXQgPSBzNmU2M20wX3NwaV93cml0ZShsY2QsIDB4ZmEsIDB4MDApOwotCWlmIChyZXQpIHsKLQkJ ZGV2X2VycihsY2QtPmRldiwgImZhaWxlZCB0byBkaXNhYmxlIGdhbW1hIHRhYmxlIHVwZGF0aW5n LlxuIik7Ci0JCWdvdG8gZ2FtbWFfZXJyOwotCX0KLQotCWZvciAoaSA9IDAgOyBpIDwgR0FNTUFf VEFCTEVfQ09VTlQ7IGkrKykgewotCQlyZXQgPSBzNmU2M20wX3NwaV93cml0ZShsY2QsIERBVEFf T05MWSwgZ2FtbWFbaV0pOwotCQlpZiAocmV0KSB7Ci0JCQlkZXZfZXJyKGxjZC0+ZGV2LCAiZmFp bGVkIHRvIHNldCBnYW1tYSB0YWJsZS5cbiIpOwotCQkJZ290byBnYW1tYV9lcnI7Ci0JCX0KLQl9 Ci0KLQkvKiB1cGRhdGUgZ2FtbWEgdGFibGUuICovCi0JcmV0ID0gczZlNjNtMF9zcGlfd3JpdGUo bGNkLCAweGZhLCAweDAxKTsKLQlpZiAocmV0KQotCQlkZXZfZXJyKGxjZC0+ZGV2LCAiZmFpbGVk IHRvIHVwZGF0ZSBnYW1tYSB0YWJsZS5cbiIpOwotCi1nYW1tYV9lcnI6Ci0JcmV0dXJuIHJldDsK LX0KLQotc3RhdGljIGludCBzNmU2M20wX2dhbW1hX2N0bChzdHJ1Y3QgczZlNjNtMCAqbGNkLCBp bnQgZ2FtbWEpCi17Ci0JaW50IHJldCA9IDA7Ci0KLQlyZXQgPSBfczZlNjNtMF9nYW1tYV9jdGwo bGNkLCBnYW1tYV90YWJsZS5nYW1tYV8yMl90YWJsZVtnYW1tYV0pOwotCi0JcmV0dXJuIHJldDsK LX0KLQotCi1zdGF0aWMgaW50IHM2ZTYzbTBfbGRpX2luaXQoc3RydWN0IHM2ZTYzbTAgKmxjZCkK LXsKLQlpbnQgcmV0LCBpOwotCWNvbnN0IHVuc2lnbmVkIHNob3J0ICppbml0X3NlcVtdID0gewot CQlzZXFfcGFuZWxfY29uZGl0aW9uX3NldCwKLQkJc2VxX2Rpc3BsYXlfY29uZGl0aW9uX3NldCwK LQkJc2VxX2dhbW1hX3NldHRpbmcsCi0JCXNlcV9ldGNfY29uZGl0aW9uX3NldCwKLQkJc2VxX2Fj bF9vbiwKLQkJc2VxX2VsdnNzX29uLAotCX07Ci0KLQlmb3IgKGkgPSAwOyBpIDwgQVJSQVlfU0la RShpbml0X3NlcSk7IGkrKykgewotCQlyZXQgPSBzNmU2M20wX3BhbmVsX3NlbmRfc2VxdWVuY2Uo bGNkLCBpbml0X3NlcVtpXSk7Ci0JCWlmIChyZXQpCi0JCQlicmVhazsKLQl9Ci0KLQlyZXR1cm4g cmV0OwotfQotCi1zdGF0aWMgaW50IHM2ZTYzbTBfbGRpX2VuYWJsZShzdHJ1Y3QgczZlNjNtMCAq bGNkKQotewotCWludCByZXQgPSAwLCBpOwotCWNvbnN0IHVuc2lnbmVkIHNob3J0ICplbmFibGVf c2VxW10gPSB7Ci0JCXNlcV9zdGFuZF9ieV9vZmYsCi0JCXNlcV9kaXNwbGF5X29uLAotCX07Ci0K LQlmb3IgKGkgPSAwOyBpIDwgQVJSQVlfU0laRShlbmFibGVfc2VxKTsgaSsrKSB7Ci0JCXJldCA9 IHM2ZTYzbTBfcGFuZWxfc2VuZF9zZXF1ZW5jZShsY2QsIGVuYWJsZV9zZXFbaV0pOwotCQlpZiAo cmV0KQotCQkJYnJlYWs7Ci0JfQotCi0JcmV0dXJuIHJldDsKLX0KLQotc3RhdGljIGludCBzNmU2 M20wX2xkaV9kaXNhYmxlKHN0cnVjdCBzNmU2M20wICpsY2QpCi17Ci0JaW50IHJldDsKLQotCXJl dCA9IHM2ZTYzbTBfcGFuZWxfc2VuZF9zZXF1ZW5jZShsY2QsIHNlcV9zdGFuZF9ieV9vbik7Ci0K LQlyZXR1cm4gcmV0OwotfQotCi1zdGF0aWMgaW50IHM2ZTYzbTBfcG93ZXJfaXNfb24oaW50IHBv d2VyKQotewotCXJldHVybiBwb3dlciA8PSBGQl9CTEFOS19OT1JNQUw7Ci19Ci0KLXN0YXRpYyBp bnQgczZlNjNtMF9wb3dlcl9vbihzdHJ1Y3QgczZlNjNtMCAqbGNkKQotewotCWludCByZXQgPSAw OwotCXN0cnVjdCBsY2RfcGxhdGZvcm1fZGF0YSAqcGQ7Ci0Jc3RydWN0IGJhY2tsaWdodF9kZXZp Y2UgKmJkOwotCi0JcGQgPSBsY2QtPmxjZF9wZDsKLQliZCA9IGxjZC0+YmQ7Ci0KLQlpZiAoIXBk LT5wb3dlcl9vbikgewotCQlkZXZfZXJyKGxjZC0+ZGV2LCAicG93ZXJfb24gaXMgTlVMTC5cbiIp OwotCQlyZXR1cm4gLUVJTlZBTDsKLQl9Ci0KLQlwZC0+cG93ZXJfb24obGNkLT5sZCwgMSk7Ci0J bXNsZWVwKHBkLT5wb3dlcl9vbl9kZWxheSk7Ci0KLQlpZiAoIXBkLT5yZXNldCkgewotCQlkZXZf ZXJyKGxjZC0+ZGV2LCAicmVzZXQgaXMgTlVMTC5cbiIpOwotCQlyZXR1cm4gLUVJTlZBTDsKLQl9 Ci0KLQlwZC0+cmVzZXQobGNkLT5sZCk7Ci0JbXNsZWVwKHBkLT5yZXNldF9kZWxheSk7Ci0KLQly ZXQgPSBzNmU2M20wX2xkaV9pbml0KGxjZCk7Ci0JaWYgKHJldCkgewotCQlkZXZfZXJyKGxjZC0+ ZGV2LCAiZmFpbGVkIHRvIGluaXRpYWxpemUgbGRpLlxuIik7Ci0JCXJldHVybiByZXQ7Ci0JfQot Ci0JcmV0ID0gczZlNjNtMF9sZGlfZW5hYmxlKGxjZCk7Ci0JaWYgKHJldCkgewotCQlkZXZfZXJy KGxjZC0+ZGV2LCAiZmFpbGVkIHRvIGVuYWJsZSBsZGkuXG4iKTsKLQkJcmV0dXJuIHJldDsKLQl9 Ci0KLQkvKiBzZXQgYnJpZ2h0bmVzcyB0byBjdXJyZW50IHZhbHVlIGFmdGVyIHBvd2VyIG9uIG9y IHJlc3VtZS4gKi8KLQlyZXQgPSBzNmU2M20wX2dhbW1hX2N0bChsY2QsIGJkLT5wcm9wcy5icmln aHRuZXNzKTsKLQlpZiAocmV0KSB7Ci0JCWRldl9lcnIobGNkLT5kZXYsICJsY2QgZ2FtbWEgc2V0 dGluZyBmYWlsZWQuXG4iKTsKLQkJcmV0dXJuIHJldDsKLQl9Ci0KLQlyZXR1cm4gMDsKLX0KLQot c3RhdGljIGludCBzNmU2M20wX3Bvd2VyX29mZihzdHJ1Y3QgczZlNjNtMCAqbGNkKQotewotCWlu dCByZXQ7Ci0Jc3RydWN0IGxjZF9wbGF0Zm9ybV9kYXRhICpwZDsKLQotCXBkID0gbGNkLT5sY2Rf cGQ7Ci0KLQlyZXQgPSBzNmU2M20wX2xkaV9kaXNhYmxlKGxjZCk7Ci0JaWYgKHJldCkgewotCQlk ZXZfZXJyKGxjZC0+ZGV2LCAibGNkIHNldHRpbmcgZmFpbGVkLlxuIik7Ci0JCXJldHVybiAtRUlP OwotCX0KLQotCW1zbGVlcChwZC0+cG93ZXJfb2ZmX2RlbGF5KTsKLQotCXBkLT5wb3dlcl9vbihs Y2QtPmxkLCAwKTsKLQotCXJldHVybiAwOwotfQotCi1zdGF0aWMgaW50IHM2ZTYzbTBfcG93ZXIo c3RydWN0IHM2ZTYzbTAgKmxjZCwgaW50IHBvd2VyKQotewotCWludCByZXQgPSAwOwotCi0JaWYg KHM2ZTYzbTBfcG93ZXJfaXNfb24ocG93ZXIpICYmICFzNmU2M20wX3Bvd2VyX2lzX29uKGxjZC0+ cG93ZXIpKQotCQlyZXQgPSBzNmU2M20wX3Bvd2VyX29uKGxjZCk7Ci0JZWxzZSBpZiAoIXM2ZTYz bTBfcG93ZXJfaXNfb24ocG93ZXIpICYmIHM2ZTYzbTBfcG93ZXJfaXNfb24obGNkLT5wb3dlcikp Ci0JCXJldCA9IHM2ZTYzbTBfcG93ZXJfb2ZmKGxjZCk7Ci0KLQlpZiAoIXJldCkKLQkJbGNkLT5w b3dlciA9IHBvd2VyOwotCi0JcmV0dXJuIHJldDsKLX0KLQotc3RhdGljIGludCBzNmU2M20wX3Nl dF9wb3dlcihzdHJ1Y3QgbGNkX2RldmljZSAqbGQsIGludCBwb3dlcikKLXsKLQlzdHJ1Y3QgczZl NjNtMCAqbGNkID0gbGNkX2dldF9kYXRhKGxkKTsKLQotCWlmIChwb3dlciAhPSBGQl9CTEFOS19V TkJMQU5LICYmIHBvd2VyICE9IEZCX0JMQU5LX1BPV0VSRE9XTiAmJgotCQlwb3dlciAhPSBGQl9C TEFOS19OT1JNQUwpIHsKLQkJZGV2X2VycihsY2QtPmRldiwgInBvd2VyIHZhbHVlIHNob3VsZCBi ZSAwLCAxIG9yIDQuXG4iKTsKLQkJcmV0dXJuIC1FSU5WQUw7Ci0JfQotCi0JcmV0dXJuIHM2ZTYz bTBfcG93ZXIobGNkLCBwb3dlcik7Ci19Ci0KLXN0YXRpYyBpbnQgczZlNjNtMF9nZXRfcG93ZXIo c3RydWN0IGxjZF9kZXZpY2UgKmxkKQotewotCXN0cnVjdCBzNmU2M20wICpsY2QgPSBsY2RfZ2V0 X2RhdGEobGQpOwotCi0JcmV0dXJuIGxjZC0+cG93ZXI7Ci19Ci0KLXN0YXRpYyBpbnQgczZlNjNt MF9zZXRfYnJpZ2h0bmVzcyhzdHJ1Y3QgYmFja2xpZ2h0X2RldmljZSAqYmQpCi17Ci0JaW50IHJl dCA9IDAsIGJyaWdodG5lc3MgPSBiZC0+cHJvcHMuYnJpZ2h0bmVzczsKLQlzdHJ1Y3QgczZlNjNt MCAqbGNkID0gYmxfZ2V0X2RhdGEoYmQpOwotCi0JaWYgKGJyaWdodG5lc3MgPCBNSU5fQlJJR0hU TkVTUyB8fAotCQlicmlnaHRuZXNzID4gYmQtPnByb3BzLm1heF9icmlnaHRuZXNzKSB7Ci0JCWRl dl9lcnIoJmJkLT5kZXYsICJsY2QgYnJpZ2h0bmVzcyBzaG91bGQgYmUgJWQgdG8gJWQuXG4iLAot CQkJTUlOX0JSSUdIVE5FU1MsIE1BWF9CUklHSFRORVNTKTsKLQkJcmV0dXJuIC1FSU5WQUw7Ci0J fQotCi0JcmV0ID0gczZlNjNtMF9nYW1tYV9jdGwobGNkLCBiZC0+cHJvcHMuYnJpZ2h0bmVzcyk7 Ci0JaWYgKHJldCkgewotCQlkZXZfZXJyKCZiZC0+ZGV2LCAibGNkIGJyaWdodG5lc3Mgc2V0dGlu ZyBmYWlsZWQuXG4iKTsKLQkJcmV0dXJuIC1FSU87Ci0JfQotCi0JcmV0dXJuIHJldDsKLX0KLQot c3RhdGljIHN0cnVjdCBsY2Rfb3BzIHM2ZTYzbTBfbGNkX29wcyA9IHsKLQkuc2V0X3Bvd2VyID0g czZlNjNtMF9zZXRfcG93ZXIsCi0JLmdldF9wb3dlciA9IHM2ZTYzbTBfZ2V0X3Bvd2VyLAotfTsK LQotc3RhdGljIGNvbnN0IHN0cnVjdCBiYWNrbGlnaHRfb3BzIHM2ZTYzbTBfYmFja2xpZ2h0X29w cyAgPSB7Ci0JLnVwZGF0ZV9zdGF0dXMgPSBzNmU2M20wX3NldF9icmlnaHRuZXNzLAotfTsKLQot c3RhdGljIHNzaXplX3QgczZlNjNtMF9zeXNmc19zaG93X2dhbW1hX21vZGUoc3RydWN0IGRldmlj ZSAqZGV2LAotCQkJCSAgICAgIHN0cnVjdCBkZXZpY2VfYXR0cmlidXRlICphdHRyLCBjaGFyICpi dWYpCi17Ci0Jc3RydWN0IHM2ZTYzbTAgKmxjZCA9IGRldl9nZXRfZHJ2ZGF0YShkZXYpOwotCWNo YXIgdGVtcFsxMF07Ci0KLQlzd2l0Y2ggKGxjZC0+Z2FtbWFfbW9kZSkgewotCWNhc2UgMDoKLQkJ c3ByaW50Zih0ZW1wLCAiMi4yIG1vZGVcbiIpOwotCQlzdHJjYXQoYnVmLCB0ZW1wKTsKLQkJYnJl YWs7Ci0JY2FzZSAxOgotCQlzcHJpbnRmKHRlbXAsICIxLjkgbW9kZVxuIik7Ci0JCXN0cmNhdChi dWYsIHRlbXApOwotCQlicmVhazsKLQljYXNlIDI6Ci0JCXNwcmludGYodGVtcCwgIjEuNyBtb2Rl XG4iKTsKLQkJc3RyY2F0KGJ1ZiwgdGVtcCk7Ci0JCWJyZWFrOwotCWRlZmF1bHQ6Ci0JCWRldl9p bmZvKGRldiwgImdhbW1hIG1vZGUgY291bGQgYmUgMDoyLjIsIDE6MS45IG9yIDI6MS43KW4iKTsK LQkJYnJlYWs7Ci0JfQotCi0JcmV0dXJuIHN0cmxlbihidWYpOwotfQotCi1zdGF0aWMgc3NpemVf dCBzNmU2M20wX3N5c2ZzX3N0b3JlX2dhbW1hX21vZGUoc3RydWN0IGRldmljZSAqZGV2LAotCQkJ CSAgICAgICBzdHJ1Y3QgZGV2aWNlX2F0dHJpYnV0ZSAqYXR0ciwKLQkJCQkgICAgICAgY29uc3Qg Y2hhciAqYnVmLCBzaXplX3QgbGVuKQotewotCXN0cnVjdCBzNmU2M20wICpsY2QgPSBkZXZfZ2V0 X2RydmRhdGEoZGV2KTsKLQlzdHJ1Y3QgYmFja2xpZ2h0X2RldmljZSAqYmQgPSBOVUxMOwotCWlu dCBicmlnaHRuZXNzLCByYzsKLQotCXJjID0ga3N0cnRvdWludChidWYsIDAsICZsY2QtPmdhbW1h X21vZGUpOwotCWlmIChyYyA8IDApCi0JCXJldHVybiByYzsKLQotCWJkID0gbGNkLT5iZDsKLQot CWJyaWdodG5lc3MgPSBiZC0+cHJvcHMuYnJpZ2h0bmVzczsKLQotCXN3aXRjaCAobGNkLT5nYW1t YV9tb2RlKSB7Ci0JY2FzZSAwOgotCQlfczZlNjNtMF9nYW1tYV9jdGwobGNkLCBnYW1tYV90YWJs ZS5nYW1tYV8yMl90YWJsZVticmlnaHRuZXNzXSk7Ci0JCWJyZWFrOwotCWNhc2UgMToKLQkJX3M2 ZTYzbTBfZ2FtbWFfY3RsKGxjZCwgZ2FtbWFfdGFibGUuZ2FtbWFfMTlfdGFibGVbYnJpZ2h0bmVz c10pOwotCQlicmVhazsKLQljYXNlIDI6Ci0JCV9zNmU2M20wX2dhbW1hX2N0bChsY2QsIGdhbW1h X3RhYmxlLmdhbW1hXzE3X3RhYmxlW2JyaWdodG5lc3NdKTsKLQkJYnJlYWs7Ci0JZGVmYXVsdDoK LQkJZGV2X2luZm8oZGV2LCAiZ2FtbWEgbW9kZSBjb3VsZCBiZSAwOjIuMiwgMToxLjkgb3IgMjox LjdcbiIpOwotCQlfczZlNjNtMF9nYW1tYV9jdGwobGNkLCBnYW1tYV90YWJsZS5nYW1tYV8yMl90 YWJsZVticmlnaHRuZXNzXSk7Ci0JCWJyZWFrOwotCX0KLQlyZXR1cm4gbGVuOwotfQotCi1zdGF0 aWMgREVWSUNFX0FUVFIoZ2FtbWFfbW9kZSwgMDY0NCwKLQkJczZlNjNtMF9zeXNmc19zaG93X2dh bW1hX21vZGUsIHM2ZTYzbTBfc3lzZnNfc3RvcmVfZ2FtbWFfbW9kZSk7Ci0KLXN0YXRpYyBzc2l6 ZV90IHM2ZTYzbTBfc3lzZnNfc2hvd19nYW1tYV90YWJsZShzdHJ1Y3QgZGV2aWNlICpkZXYsCi0J CQkJICAgICAgc3RydWN0IGRldmljZV9hdHRyaWJ1dGUgKmF0dHIsIGNoYXIgKmJ1ZikKLXsKLQlz dHJ1Y3QgczZlNjNtMCAqbGNkID0gZGV2X2dldF9kcnZkYXRhKGRldik7Ci0JY2hhciB0ZW1wWzNd OwotCi0Jc3ByaW50Zih0ZW1wLCAiJXVcbiIsIGxjZC0+Z2FtbWFfdGFibGVfY291bnQpOwotCXN0 cmNweShidWYsIHRlbXApOwotCi0JcmV0dXJuIHN0cmxlbihidWYpOwotfQotc3RhdGljIERFVklD RV9BVFRSKGdhbW1hX3RhYmxlLCAwNDQ0LAotCQlzNmU2M20wX3N5c2ZzX3Nob3dfZ2FtbWFfdGFi bGUsIE5VTEwpOwotCi1zdGF0aWMgaW50IHM2ZTYzbTBfcHJvYmUoc3RydWN0IHNwaV9kZXZpY2Ug KnNwaSkKLXsKLQlpbnQgcmV0ID0gMDsKLQlzdHJ1Y3QgczZlNjNtMCAqbGNkID0gTlVMTDsKLQlz dHJ1Y3QgbGNkX2RldmljZSAqbGQgPSBOVUxMOwotCXN0cnVjdCBiYWNrbGlnaHRfZGV2aWNlICpi ZCA9IE5VTEw7Ci0Jc3RydWN0IGJhY2tsaWdodF9wcm9wZXJ0aWVzIHByb3BzOwotCi0JbGNkID0g ZGV2bV9remFsbG9jKCZzcGktPmRldiwgc2l6ZW9mKHN0cnVjdCBzNmU2M20wKSwgR0ZQX0tFUk5F TCk7Ci0JaWYgKCFsY2QpCi0JCXJldHVybiAtRU5PTUVNOwotCi0JLyogczZlNjNtMCBsY2QgcGFu ZWwgdXNlcyAzLXdpcmUgOWJpdHMgU1BJIE1vZGUuICovCi0Jc3BpLT5iaXRzX3Blcl93b3JkID0g OTsKLQotCXJldCA9IHNwaV9zZXR1cChzcGkpOwotCWlmIChyZXQgPCAwKSB7Ci0JCWRldl9lcnIo JnNwaS0+ZGV2LCAic3BpIHNldHVwIGZhaWxlZC5cbiIpOwotCQlyZXR1cm4gcmV0OwotCX0KLQot CWxjZC0+c3BpID0gc3BpOwotCWxjZC0+ZGV2ID0gJnNwaS0+ZGV2OwotCi0JbGNkLT5sY2RfcGQg PSBkZXZfZ2V0X3BsYXRkYXRhKCZzcGktPmRldik7Ci0JaWYgKCFsY2QtPmxjZF9wZCkgewotCQlk ZXZfZXJyKCZzcGktPmRldiwgInBsYXRmb3JtIGRhdGEgaXMgTlVMTC5cbiIpOwotCQlyZXR1cm4g LUVJTlZBTDsKLQl9Ci0KLQlsZCA9IGRldm1fbGNkX2RldmljZV9yZWdpc3Rlcigmc3BpLT5kZXYs ICJzNmU2M20wIiwgJnNwaS0+ZGV2LCBsY2QsCi0JCQkJJnM2ZTYzbTBfbGNkX29wcyk7Ci0JaWYg KElTX0VSUihsZCkpCi0JCXJldHVybiBQVFJfRVJSKGxkKTsKLQotCWxjZC0+bGQgPSBsZDsKLQot CW1lbXNldCgmcHJvcHMsIDAsIHNpemVvZihzdHJ1Y3QgYmFja2xpZ2h0X3Byb3BlcnRpZXMpKTsK LQlwcm9wcy50eXBlID0gQkFDS0xJR0hUX1JBVzsKLQlwcm9wcy5tYXhfYnJpZ2h0bmVzcyA9IE1B WF9CUklHSFRORVNTOwotCi0JYmQgPSBkZXZtX2JhY2tsaWdodF9kZXZpY2VfcmVnaXN0ZXIoJnNw aS0+ZGV2LCAiczZlNjNtMGJsLWJsIiwKLQkJCQkJJnNwaS0+ZGV2LCBsY2QsICZzNmU2M20wX2Jh Y2tsaWdodF9vcHMsCi0JCQkJCSZwcm9wcyk7Ci0JaWYgKElTX0VSUihiZCkpCi0JCXJldHVybiBQ VFJfRVJSKGJkKTsKLQotCWJkLT5wcm9wcy5icmlnaHRuZXNzID0gTUFYX0JSSUdIVE5FU1M7Ci0J bGNkLT5iZCA9IGJkOwotCi0JLyoKLQkgKiBpdCBnZXRzIGdhbW1hIHRhYmxlIGNvdW50IGF2YWls YWJsZSBzbyBpdCBnZXRzIHVzZXIKLQkgKiBrbm93IHRoYXQuCi0JICovCi0JbGNkLT5nYW1tYV90 YWJsZV9jb3VudCA9Ci0JICAgIHNpemVvZihnYW1tYV90YWJsZSkgLyAoTUFYX0dBTU1BX0xFVkVM ICogc2l6ZW9mKGludCAqKSk7Ci0KLQlyZXQgPSBkZXZpY2VfY3JlYXRlX2ZpbGUoJihzcGktPmRl diksICZkZXZfYXR0cl9nYW1tYV9tb2RlKTsKLQlpZiAocmV0IDwgMCkKLQkJZGV2X2VycigmKHNw aS0+ZGV2KSwgImZhaWxlZCB0byBhZGQgc3lzZnMgZW50cmllc1xuIik7Ci0KLQlyZXQgPSBkZXZp Y2VfY3JlYXRlX2ZpbGUoJihzcGktPmRldiksICZkZXZfYXR0cl9nYW1tYV90YWJsZSk7Ci0JaWYg KHJldCA8IDApCi0JCWRldl9lcnIoJihzcGktPmRldiksICJmYWlsZWQgdG8gYWRkIHN5c2ZzIGVu dHJpZXNcbiIpOwotCi0JLyoKLQkgKiBpZiBsY2QgcGFuZWwgd2FzIG9uIGZyb20gYm9vdGxvYWRl ciBsaWtlIHUtYm9vdCB0aGVuCi0JICogZG8gbm90IGxjZCBvbi4KLQkgKi8KLQlpZiAoIWxjZC0+ bGNkX3BkLT5sY2RfZW5hYmxlZCkgewotCQkvKgotCQkgKiBpZiBsY2QgcGFuZWwgd2FzIG9mZiBm cm9tIGJvb3Rsb2FkZXIgdGhlbgotCQkgKiBjdXJyZW50IGxjZCBzdGF0dXMgaXMgcG93ZXJkb3du IGFuZCB0aGVuCi0JCSAqIGl0IGVuYWJsZXMgbGNkIHBhbmVsLgotCQkgKi8KLQkJbGNkLT5wb3dl ciA9IEZCX0JMQU5LX1BPV0VSRE9XTjsKLQotCQlzNmU2M20wX3Bvd2VyKGxjZCwgRkJfQkxBTktf VU5CTEFOSyk7Ci0JfSBlbHNlIHsKLQkJbGNkLT5wb3dlciA9IEZCX0JMQU5LX1VOQkxBTks7Ci0J fQotCi0Jc3BpX3NldF9kcnZkYXRhKHNwaSwgbGNkKTsKLQotCWRldl9pbmZvKCZzcGktPmRldiwg InM2ZTYzbTAgcGFuZWwgZHJpdmVyIGhhcyBiZWVuIHByb2JlZC5cbiIpOwotCi0JcmV0dXJuIDA7 Ci19Ci0KLXN0YXRpYyBpbnQgczZlNjNtMF9yZW1vdmUoc3RydWN0IHNwaV9kZXZpY2UgKnNwaSkK LXsKLQlzdHJ1Y3QgczZlNjNtMCAqbGNkID0gc3BpX2dldF9kcnZkYXRhKHNwaSk7Ci0KLQlzNmU2 M20wX3Bvd2VyKGxjZCwgRkJfQkxBTktfUE9XRVJET1dOKTsKLQlkZXZpY2VfcmVtb3ZlX2ZpbGUo JnNwaS0+ZGV2LCAmZGV2X2F0dHJfZ2FtbWFfdGFibGUpOwotCWRldmljZV9yZW1vdmVfZmlsZSgm c3BpLT5kZXYsICZkZXZfYXR0cl9nYW1tYV9tb2RlKTsKLQotCXJldHVybiAwOwotfQotCi0jaWZk ZWYgQ09ORklHX1BNX1NMRUVQCi1zdGF0aWMgaW50IHM2ZTYzbTBfc3VzcGVuZChzdHJ1Y3QgZGV2 aWNlICpkZXYpCi17Ci0Jc3RydWN0IHM2ZTYzbTAgKmxjZCA9IGRldl9nZXRfZHJ2ZGF0YShkZXYp OwotCi0JZGV2X2RiZyhkZXYsICJsY2QtPnBvd2VyID0gJWRcbiIsIGxjZC0+cG93ZXIpOwotCi0J LyoKLQkgKiB3aGVuIGxjZCBwYW5lbCBpcyBzdXNwZW5kLCBsY2QgcGFuZWwgYmVjb21lcyBvZmYK LQkgKiByZWdhcmRsZXNzIG9mIHN0YXR1cy4KLQkgKi8KLQlyZXR1cm4gczZlNjNtMF9wb3dlcihs Y2QsIEZCX0JMQU5LX1BPV0VSRE9XTik7Ci19Ci0KLXN0YXRpYyBpbnQgczZlNjNtMF9yZXN1bWUo c3RydWN0IGRldmljZSAqZGV2KQotewotCXN0cnVjdCBzNmU2M20wICpsY2QgPSBkZXZfZ2V0X2Ry dmRhdGEoZGV2KTsKLQotCWxjZC0+cG93ZXIgPSBGQl9CTEFOS19QT1dFUkRPV047Ci0KLQlyZXR1 cm4gczZlNjNtMF9wb3dlcihsY2QsIEZCX0JMQU5LX1VOQkxBTkspOwotfQotI2VuZGlmCi0KLXN0 YXRpYyBTSU1QTEVfREVWX1BNX09QUyhzNmU2M20wX3BtX29wcywgczZlNjNtMF9zdXNwZW5kLCBz NmU2M20wX3Jlc3VtZSk7Ci0KLS8qIFBvd2VyIGRvd24gYWxsIGRpc3BsYXlzIG9uIHJlYm9vdCwg cG93ZXJvZmYgb3IgaGFsdC4gKi8KLXN0YXRpYyB2b2lkIHM2ZTYzbTBfc2h1dGRvd24oc3RydWN0 IHNwaV9kZXZpY2UgKnNwaSkKLXsKLQlzdHJ1Y3QgczZlNjNtMCAqbGNkID0gc3BpX2dldF9kcnZk YXRhKHNwaSk7Ci0KLQlzNmU2M20wX3Bvd2VyKGxjZCwgRkJfQkxBTktfUE9XRVJET1dOKTsKLX0K LQotc3RhdGljIHN0cnVjdCBzcGlfZHJpdmVyIHM2ZTYzbTBfZHJpdmVyID0gewotCS5kcml2ZXIg PSB7Ci0JCS5uYW1lCT0gInM2ZTYzbTAiLAotCQkucG0JPSAmczZlNjNtMF9wbV9vcHMsCi0JfSwK LQkucHJvYmUJCT0gczZlNjNtMF9wcm9iZSwKLQkucmVtb3ZlCQk9IHM2ZTYzbTBfcmVtb3ZlLAot CS5zaHV0ZG93bgk9IHM2ZTYzbTBfc2h1dGRvd24sCi19OwotCi1tb2R1bGVfc3BpX2RyaXZlcihz NmU2M20wX2RyaXZlcik7Ci0KLU1PRFVMRV9BVVRIT1IoIkluS2kgRGFlIDxpbmtpLmRhZUBzYW1z dW5nLmNvbT4iKTsKLU1PRFVMRV9ERVNDUklQVElPTigiUzZFNjNNMCBMQ0QgRHJpdmVyIik7Ci1N T0RVTEVfTElDRU5TRSgiR1BMIik7Ci0KZGlmZiAtLWdpdCBhL2RyaXZlcnMvdmlkZW8vYmFja2xp Z2h0L3M2ZTYzbTBfZ2FtbWEuaCBiL2RyaXZlcnMvdmlkZW8vYmFja2xpZ2h0L3M2ZTYzbTBfZ2Ft bWEuaApkZWxldGVkIGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMmM0NGJkYjA2OTZiLi4wMDAwMDAw MDAwMDAKLS0tIGEvZHJpdmVycy92aWRlby9iYWNrbGlnaHQvczZlNjNtMF9nYW1tYS5oCisrKyAv ZGV2L251bGwKQEAgLTEsMjY2ICswLDAgQEAKLS8qIGxpbnV4L2RyaXZlcnMvdmlkZW8vc2Ftc3Vu Zy9zNmU2M20wX2JyaWdodG5lc3MuaAotICoKLSAqIEdhbW1hIGxldmVsIGRlZmluaXRpb25zLgot ICoKLSAqIENvcHlyaWdodCAoYykgMjAwOSBTYW1zdW5nIEVsZWN0cm9uaWNzCi0gKiBJbktpIERh ZSA8aW5raS5kYWVAc2Ftc3VuZy5jb20+Ci0gKgotICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29m dHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkKLSAqIGl0IHVuZGVy IHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgdmVyc2lvbiAyIGFz Ci0gKiBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbi4KLSovCi0KLSNp Zm5kZWYgX1M2RTYzTTBfQlJJR0hUTkVTU19ICi0jZGVmaW5lIF9TNkU2M00wX0JSSUdIVE5FU1Nf SAotCi0jZGVmaW5lIE1BWF9HQU1NQV9MRVZFTAkJMTEKLSNkZWZpbmUgR0FNTUFfVEFCTEVfQ09V TlQJMjEKLQotLyogZ2FtbWEgdmFsdWU6IDIuMiAqLwotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGlu dCBzNmU2M20wXzIyXzMwMFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NWYsIDB4NTAsIDB4 MmQsIDB4QjYsCi0JMHhCOSwgMHhBNywgMHhBZCwgMHhCMSwgMHg5ZiwgMHhiZSwgMHhDMCwKLQkw eEI1LCAweDAwLCAweGEwLCAweDAwLCAweGE0LCAweDAwLCAweGRiCi19OwotCi1zdGF0aWMgY29u c3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMjJfMjgwW10gPSB7Ci0JMHgxOCwgMHgwOCwgMHgyNCwg MHg2NCwgMHg1NiwgMHgzMywgMHhCNiwKLQkweEJBLCAweEE4LCAweEFDLCAweEIxLCAweDlELCAw eEMxLCAweEMxLAotCTB4QjcsIDB4MDAsIDB4OUMsIDB4MDAsIDB4OUYsIDB4MDAsIDB4RDYKLX07 Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8yMl8yNjBbXSA9IHsKLQkweDE4 LCAweDA4LCAweDI0LCAweDY2LCAweDU4LCAweDM0LCAweEI2LAotCTB4QkEsIDB4QTcsIDB4QUYs IDB4QjMsIDB4QTAsIDB4QzEsIDB4QzIsCi0JMHhCNywgMHgwMCwgMHg5NywgMHgwMCwgMHg5QSwg MHgwMCwgMHhEMQotCi19OwotCi1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMjJf MjQwW10gPSB7Ci0JMHgxOCwgMHgwOCwgMHgyNCwgMHg2MiwgMHg1NCwgMHgzMCwgMHhCOSwKLQkw eEJCLCAweEE5LCAweEIwLCAweEIzLCAweEExLCAweEMxLCAweEMzLAotCTB4QjcsIDB4MDAsIDB4 OTEsIDB4MDAsIDB4OTUsIDB4MDAsIDB4REEKLQotfTsKLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBp bnQgczZlNjNtMF8yMl8yMjBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDYzLCAweDUzLCAw eDMxLCAweEI4LAotCTB4QkMsIDB4QTksIDB4QjAsIDB4QjUsIDB4QTIsIDB4QzQsIDB4QzQsCi0J MHhCOCwgMHgwMCwgMHg4QiwgMHgwMCwgMHg4RSwgMHgwMCwgMHhDMgotfTsKLQotc3RhdGljIGNv bnN0IHVuc2lnbmVkIGludCBzNmU2M20wXzIyXzIwMFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQs IDB4NjYsIDB4NTUsIDB4MzQsIDB4QkEsCi0JMHhCRCwgMHhBQiwgMHhCMSwgMHhCNSwgMHhBMywg MHhDNSwgMHhDNiwKLQkweEI5LCAweDAwLCAweDg1LCAweDAwLCAweDg4LCAweDAwLCAweEJBCi19 OwotCi1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMjJfMTcwW10gPSB7Ci0JMHgx OCwgMHgwOCwgMHgyNCwgMHg2OSwgMHg1NCwgMHgzNywgMHhCQiwKLQkweEJFLCAweEFDLCAweEI0 LCAweEI3LCAweEE2LCAweEM3LCAweEM4LAotCTB4QkMsIDB4MDAsIDB4N0IsIDB4MDAsIDB4N0Us IDB4MDAsIDB4QUIKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8yMl8x NDBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDZDLCAweDU0LCAweDNBLCAweEJDLAotCTB4 QkYsIDB4QUMsIDB4QjcsIDB4QkIsIDB4QTksIDB4QzksIDB4QzksCi0JMHhCRSwgMHgwMCwgMHg3 MSwgMHgwMCwgMHg3MywgMHgwMCwgMHg5RQotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGlu dCBzNmU2M20wXzIyXzExMFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NzAsIDB4NTEsIDB4 M0UsIDB4QkYsCi0JMHhDMSwgMHhBRiwgMHhCOSwgMHhCQywgMHhBQiwgMHhDQywgMHhDQywKLQkw eEMyLCAweDAwLCAweDY1LCAweDAwLCAweDY3LCAweDAwLCAweDhECi19OwotCi1zdGF0aWMgY29u c3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMjJfOTBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAw eDczLCAweDRBLCAweDNELCAweEMwLAotCTB4QzIsIDB4QjEsIDB4QkIsIDB4QkUsIDB4QUMsIDB4 Q0UsIDB4Q0YsCi0JMHhDNSwgMHgwMCwgMHg1RCwgMHgwMCwgMHg1RSwgMHgwMCwgMHg4MgotfTsK LQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGludCBzNmU2M20wXzIyXzMwW10gPSB7Ci0JMHgxOCwg MHgwOCwgMHgyNCwgMHg3OCwgMHhFQywgMHgzRCwgMHhDOCwKLQkweEMyLCAweEI2LCAweEM0LCAw eEM3LCAweEI2LCAweEQ1LCAweEQ3LAotCTB4Q0MsIDB4MDAsIDB4MzksIDB4MDAsIDB4MzYsIDB4 MDAsIDB4NTEKLX07Ci0KLS8qIGdhbW1hIHZhbHVlOiAxLjkgKi8KLXN0YXRpYyBjb25zdCB1bnNp Z25lZCBpbnQgczZlNjNtMF8xOV8zMDBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDYxLCAw eDVGLCAweDM5LCAweEJBLAotCTB4QkQsIDB4QUQsIDB4QjEsIDB4QjYsIDB4QTUsIDB4QzQsIDB4 QzUsCi0JMHhCQywgMHgwMCwgMHhBMCwgMHgwMCwgMHhBNCwgMHgwMCwgMHhEQgotfTsKLQotc3Rh dGljIGNvbnN0IHVuc2lnbmVkIGludCBzNmU2M20wXzE5XzI4MFtdID0gewotCTB4MTgsIDB4MDgs IDB4MjQsIDB4NjEsIDB4NjAsIDB4MzksIDB4QkIsCi0JMHhCRSwgMHhBRCwgMHhCMiwgMHhCNiwg MHhBNiwgMHhDNSwgMHhDNywKLQkweEJELCAweDAwLCAweDlCLCAweDAwLCAweDlFLCAweDAwLCAw eEQ1Ci19OwotCi1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMTlfMjYwW10gPSB7 Ci0JMHgxOCwgMHgwOCwgMHgyNCwgMHg2MywgMHg2MSwgMHgzQiwgMHhCQSwKLQkweEJFLCAweEFD LCAweEIzLCAweEI4LCAweEE3LCAweEM2LCAweEM4LAotCTB4QkQsIDB4MDAsIDB4OTYsIDB4MDAs IDB4OTgsIDB4MDAsIDB4Q0YKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNt MF8xOV8yNDBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDY3LCAweDY0LCAweDNGLCAweEJC LAotCTB4QkUsIDB4QUQsIDB4QjMsIDB4QjksIDB4QTcsIDB4QzgsIDB4QzksCi0JMHhCRSwgMHgw MCwgMHg5MCwgMHgwMCwgMHg5MiwgMHgwMCwgMHhDOAotfTsKLQotc3RhdGljIGNvbnN0IHVuc2ln bmVkIGludCBzNmU2M20wXzE5XzIyMFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NjgsIDB4 NjQsIDB4NDAsIDB4QkMsCi0JMHhCRiwgMHhBRiwgMHhCNCwgMHhCQSwgMHhBOSwgMHhDOCwgMHhD QSwKLQkweEJFLCAweDAwLCAweDhCLCAweDAwLCAweDhDLCAweDAwLCAweEMwCi19OwotCi1zdGF0 aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMTlfMjAwW10gPSB7Ci0JMHgxOCwgMHgwOCwg MHgyNCwgMHg2OCwgMHg2NCwgMHgzRiwgMHhCRSwKLQkweEMwLCAweEIwLCAweEI2LCAweEJCLCAw eEFCLCAweEM4LCAweENCLAotCTB4QkYsIDB4MDAsIDB4ODUsIDB4MDAsIDB4ODYsIDB4MDAsIDB4 QjgKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8xOV8xNzBbXSA9IHsK LQkweDE4LCAweDA4LCAweDI0LCAweDY5LCAweDY0LCAweDQwLCAweEJGLAotCTB4QzEsIDB4QjAs IDB4QjksIDB4QkUsIDB4QUQsIDB4Q0IsIDB4Q0QsCi0JMHhDMiwgMHgwMCwgMHg3QSwgMHgwMCwg MHg3QiwgMHgwMCwgMHhBQQotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGludCBzNmU2M20w XzE5XzE0MFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NkUsIDB4NjUsIDB4NDUsIDB4QzAs Ci0JMHhDMywgMHhCMiwgMHhCQSwgMHhCRSwgMHhBRSwgMHhDRCwgMHhEMCwKLQkweEM0LCAweDAw LCAweDcwLCAweDAwLCAweDcwLCAweDAwLCAweDlDCi19OwotCi1zdGF0aWMgY29uc3QgdW5zaWdu ZWQgaW50IHM2ZTYzbTBfMTlfMTEwW10gPSB7Ci0JMHgxOCwgMHgwOCwgMHgyNCwgMHg2RiwgMHg2 NSwgMHg0NiwgMHhDMiwKLQkweEM0LCAweEIzLCAweEJGLCAweEMyLCAweEIyLCAweENGLCAweEQx LAotCTB4QzYsIDB4MDAsIDB4NjQsIDB4MDAsIDB4NjQsIDB4MDAsIDB4OEQKLX07Ci0KLXN0YXRp YyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8xOV85MFtdID0gewotCTB4MTgsIDB4MDgsIDB4 MjQsIDB4NzQsIDB4NjAsIDB4NEEsIDB4QzMsCi0JMHhDNiwgMHhCNSwgMHhCRiwgMHhDMywgMHhC MiwgMHhEMiwgMHhEMywKLQkweEM4LCAweDAwLCAweDVCLCAweDAwLCAweDVCLCAweDAwLCAweDgx Ci19OwotCi1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMTlfMzBbXSA9IHsKLQkw eDE4LCAweDA4LCAweDI0LCAweDg0LCAweDQ1LCAweDRGLCAweENBLAotCTB4Q0IsIDB4QkMsIDB4 QzksIDB4Q0IsIDB4QkMsIDB4REEsIDB4REEsCi0JMHhEMCwgMHgwMCwgMHgzNSwgMHgwMCwgMHgz NCwgMHgwMCwgMHg0RQotfTsKLQotLyogZ2FtbWEgdmFsdWU6IDEuNyAqLwotc3RhdGljIGNvbnN0 IHVuc2lnbmVkIGludCBzNmU2M20wXzE3XzMwMFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4 NzAsIDB4NzAsIDB4NEYsIDB4QkYsCi0JMHhDMiwgMHhCMiwgMHhCOCwgMHhCQywgMHhBQywgMHhD QiwgMHhDRCwKLQkweEMzLCAweDAwLCAweEEwLCAweDAwLCAweEE0LCAweDAwLCAweERCCi19Owot Ci1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2ZTYzbTBfMTdfMjgwW10gPSB7Ci0JMHgxOCwg MHgwOCwgMHgyNCwgMHg3MSwgMHg3MSwgMHg1MCwgMHhCRiwKLQkweEMyLCAweEIyLCAweEJBLCAw eEJFLCAweEFFLCAweENCLCAweENELAotCTB4QzMsIDB4MDAsIDB4OUMsIDB4MDAsIDB4OUYsIDB4 MDAsIDB4RDYKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8xN18yNjBb XSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDcyLCAweDcyLCAweDUwLCAweEMwLAotCTB4QzMs IDB4QjQsIDB4QjksIDB4QkUsIDB4QUUsIDB4Q0MsIDB4Q0YsCi0JMHhDNCwgMHgwMCwgMHg5Nywg MHgwMCwgMHg5QSwgMHgwMCwgMHhEMQotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGludCBz NmU2M20wXzE3XzI0MFtdID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NzEsIDB4NzIsIDB4NEYs IDB4QzIsCi0JMHhDNCwgMHhCNSwgMHhCQiwgMHhCRiwgMHhCMCwgMHhDQywgMHhDRiwKLQkweEMz LCAweDAwLCAweDkxLCAweDAwLCAweDk1LCAweDAwLCAweENBCi19OwotCi1zdGF0aWMgY29uc3Qg dW5zaWduZWQgaW50IHM2ZTYzbTBfMTdfMjIwW10gPSB7Ci0JMHgxOCwgMHgwOCwgMHgyNCwgMHg3 MSwgMHg3MywgMHg0RiwgMHhDMiwKLQkweEM1LCAweEI1LCAweEJELCAweEMwLCAweEIyLCAweENE LCAweEQxLAotCTB4QzUsIDB4MDAsIDB4OEIsIDB4MDAsIDB4OEUsIDB4MDAsIDB4QzIKLX07Ci0K LXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8xN18yMDBbXSA9IHsKLQkweDE4LCAw eDA4LCAweDI0LCAweDcyLCAweDc1LCAweDUxLCAweEMyLAotCTB4QzYsIDB4QjUsIDB4QkYsIDB4 QzEsIDB4QjMsIDB4Q0UsIDB4RDEsCi0JMHhDNiwgMHgwMCwgMHg4NSwgMHgwMCwgMHg4OCwgMHgw MCwgMHhCQQotfTsKLQotc3RhdGljIGNvbnN0IHVuc2lnbmVkIGludCBzNmU2M20wXzE3XzE3MFtd ID0gewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4NzUsIDB4NzcsIDB4NTQsIDB4QzMsCi0JMHhDNywg MHhCNywgMHhDMCwgMHhDMywgMHhCNCwgMHhEMSwgMHhEMywKLQkweEM5LCAweDAwLCAweDdCLCAw eDAwLCAweDdFLCAweDAwLCAweEFCCi19OwotCi1zdGF0aWMgY29uc3QgdW5zaWduZWQgaW50IHM2 ZTYzbTBfMTdfMTQwW10gPSB7Ci0JMHgxOCwgMHgwOCwgMHgyNCwgMHg3QiwgMHg3NywgMHg1OCwg MHhDMywKLQkweEM4LCAweEI4LCAweEMyLCAweEM2LCAweEI2LCAweEQzLCAweEQ0LAotCTB4Q0Es IDB4MDAsIDB4NzEsIDB4MDAsIDB4NzMsIDB4MDAsIDB4OUUKLX07Ci0KLXN0YXRpYyBjb25zdCB1 bnNpZ25lZCBpbnQgczZlNjNtMF8xN18xMTBbXSA9IHsKLQkweDE4LCAweDA4LCAweDI0LCAweDgx LCAweDdCLCAweDVELCAweEM2LAotCTB4Q0EsIDB4QkIsIDB4QzMsIDB4QzcsIDB4QjgsIDB4RDYs IDB4RDgsCi0JMHhDRCwgMHgwMCwgMHg2NSwgMHgwMCwgMHg2NywgMHgwMCwgMHg4RAotfTsKLQot c3RhdGljIGNvbnN0IHVuc2lnbmVkIGludCBzNmU2M20wXzE3XzkwW10gPSB7Ci0JMHgxOCwgMHgw OCwgMHgyNCwgMHg4MiwgMHg3QSwgMHg1QiwgMHhDOCwKLQkweENCLCAweEJELCAweEM1LCAweENB LCAweEJBLCAweEQ2LCAweEQ4LAotCTB4Q0UsIDB4MDAsIDB4NUQsIDB4MDAsIDB4NUUsIDB4MDAs IDB4ODIKLX07Ci0KLXN0YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgczZlNjNtMF8xN18zMFtdID0g ewotCTB4MTgsIDB4MDgsIDB4MjQsIDB4OEYsIDB4NzMsIDB4NjMsIDB4RDEsCi0JMHhEMCwgMHhD NSwgMHhDQywgMHhEMSwgMHhDMiwgMHhERSwgMHhFMCwKLQkweEQ2LCAweDAwLCAweDM5LCAweDAw LCAweDM2LCAweDAwLCAweDUxCi19OwotCi1zdHJ1Y3QgczZlNjNtMF9nYW1tYSB7Ci0JdW5zaWdu ZWQgaW50ICpnYW1tYV8yMl90YWJsZVtNQVhfR0FNTUFfTEVWRUxdOwotCXVuc2lnbmVkIGludCAq Z2FtbWFfMTlfdGFibGVbTUFYX0dBTU1BX0xFVkVMXTsKLQl1bnNpZ25lZCBpbnQgKmdhbW1hXzE3 X3RhYmxlW01BWF9HQU1NQV9MRVZFTF07Ci19OwotCi1zdGF0aWMgc3RydWN0IHM2ZTYzbTBfZ2Ft bWEgZ2FtbWFfdGFibGUgPSB7Ci0JLmdhbW1hXzIyX3RhYmxlWzBdID0gKHVuc2lnbmVkIGludCAq KSZzNmU2M20wXzIyXzMwLAotCS5nYW1tYV8yMl90YWJsZVsxXSA9ICh1bnNpZ25lZCBpbnQgKikm czZlNjNtMF8yMl85MCwKLQkuZ2FtbWFfMjJfdGFibGVbMl0gPSAodW5zaWduZWQgaW50ICopJnM2 ZTYzbTBfMjJfMTEwLAotCS5nYW1tYV8yMl90YWJsZVszXSA9ICh1bnNpZ25lZCBpbnQgKikmczZl NjNtMF8yMl8xNDAsCi0JLmdhbW1hXzIyX3RhYmxlWzRdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2 M20wXzIyXzE3MCwKLQkuZ2FtbWFfMjJfdGFibGVbNV0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYz bTBfMjJfMjAwLAotCS5nYW1tYV8yMl90YWJsZVs2XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNt MF8yMl8yMjAsCi0JLmdhbW1hXzIyX3RhYmxlWzddID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20w XzIyXzI0MCwKLQkuZ2FtbWFfMjJfdGFibGVbOF0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBf MjJfMjYwLAotCS5nYW1tYV8yMl90YWJsZVs5XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8y Ml8yODAsCi0JLmdhbW1hXzIyX3RhYmxlWzEwXSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8y Ml8zMDAsCi0KLQkuZ2FtbWFfMTlfdGFibGVbMF0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBf MTlfMzAsCi0JLmdhbW1hXzE5X3RhYmxlWzFdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE5 XzkwLAotCS5nYW1tYV8xOV90YWJsZVsyXSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xOV8x MTAsCi0JLmdhbW1hXzE5X3RhYmxlWzNdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE5XzE0 MCwKLQkuZ2FtbWFfMTlfdGFibGVbNF0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTlfMTcw LAotCS5nYW1tYV8xOV90YWJsZVs1XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xOV8yMDAs Ci0JLmdhbW1hXzE5X3RhYmxlWzZdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE5XzIyMCwK LQkuZ2FtbWFfMTlfdGFibGVbN10gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTlfMjQwLAot CS5nYW1tYV8xOV90YWJsZVs4XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xOV8yNjAsCi0J LmdhbW1hXzE5X3RhYmxlWzldID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE5XzI4MCwKLQku Z2FtbWFfMTlfdGFibGVbMTBdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE5XzMwMCwKLQot CS5nYW1tYV8xN190YWJsZVswXSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xN18zMCwKLQku Z2FtbWFfMTdfdGFibGVbMV0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTdfOTAsCi0JLmdh bW1hXzE3X3RhYmxlWzJdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE3XzExMCwKLQkuZ2Ft bWFfMTdfdGFibGVbM10gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTdfMTQwLAotCS5nYW1t YV8xN190YWJsZVs0XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xN18xNzAsCi0JLmdhbW1h XzE3X3RhYmxlWzVdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE3XzIwMCwKLQkuZ2FtbWFf MTdfdGFibGVbNl0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTdfMjIwLAotCS5nYW1tYV8x N190YWJsZVs3XSA9ICh1bnNpZ25lZCBpbnQgKikmczZlNjNtMF8xN18yNDAsCi0JLmdhbW1hXzE3 X3RhYmxlWzhdID0gKHVuc2lnbmVkIGludCAqKSZzNmU2M20wXzE3XzI2MCwKLQkuZ2FtbWFfMTdf dGFibGVbOV0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTdfMjgwLAotCS5nYW1tYV8xN190 YWJsZVsxMF0gPSAodW5zaWduZWQgaW50ICopJnM2ZTYzbTBfMTdfMzAwLAotfTsKLQotI2VuZGlm Ci0KLS0gCjIuMTQuMQoKX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX18KZHJpLWRldmVsIG1haWxpbmcgbGlzdApkcmktZGV2ZWxAbGlzdHMuZnJlZWRlc2t0b3Au b3JnCmh0dHBzOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxtYW4vbGlzdGluZm8vZHJpLWRl dmVsCg== From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-3.1 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,MAILING_LIST_MULTI,SPF_PASS,T_DKIMWL_WL_HIGH,URIBL_BLOCKED, USER_AGENT_GIT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id C7E6CC433F5 for ; Sun, 2 Sep 2018 15:23:03 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 479E320855 for ; Sun, 2 Sep 2018 15:23:03 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=kernel.org header.i=@kernel.org header.b="XwVOxf1K" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 479E320855 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727149AbeIBTjL (ORCPT ); Sun, 2 Sep 2018 15:39:11 -0400 Received: from mail.kernel.org ([198.145.29.99]:37790 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726711AbeIBTjL (ORCPT ); Sun, 2 Sep 2018 15:39:11 -0400 Received: from localhost.localdomain (xdsl-188-155-58-14.adslplus.ch [188.155.58.14]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 560FB20843; Sun, 2 Sep 2018 15:22:58 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1535901780; bh=P7DaSWYUqUKa7ffI7e64FceOhvG1GP/wOrM3Gr4+bvA=; h=From:To:Cc:Subject:Date:From; b=XwVOxf1KlIHgZNNzY1lhlWaDrvqzVczMHnIfudpEzZ4/lD01sDqB9LHv9v0wsRASB FLokAWF+oVTvbBn4hFYz7huPCcr52sDRVFmAG8/Bf8f+AhJeelEBkEqTVpxxR3T9wg ZM2kb7P6Kn/kLfzaikZDT2d7RFrJiE1aRQI8qlhs= From: Krzysztof Kozlowski To: Donghwa Lee , Lee Jones , Daniel Thompson , Jingoo Han , Bartlomiej Zolnierkiewicz , Krzysztof Kozlowski , Jonathan Corbet , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org Cc: Marek Szyprowski , Inki Dae Subject: [PATCH v2 1/2] backlight: Remove s6e63m0 driver Date: Sun, 2 Sep 2018 17:22:31 +0200 Message-Id: <20180902152232.5802-1-krzk@kernel.org> X-Mailer: git-send-email 2.14.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The driver for S6E63M0 AMOLED LCD panel is not used. It does not support DeviceTree and respective possible users (S5Pv210 Aquila and Goni boards) are DeviceTree-only. Suggested-by: Marek Szyprowski Cc: Marek Szyprowski Cc: Inki Dae Signed-off-by: Krzysztof Kozlowski Acked-by: Jingoo Han Acked-by: Daniel Thompson --- Changes since v1: 1. Remove sysfs ABI documentation file. 2. Add Jingoo's and Daniel's acks. --- Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 | 27 - drivers/video/backlight/Kconfig | 8 - drivers/video/backlight/Makefile | 1 - drivers/video/backlight/s6e63m0.c | 857 ---------------------- drivers/video/backlight/s6e63m0_gamma.h | 266 ------- 5 files changed, 1159 deletions(-) delete mode 100644 Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 delete mode 100644 drivers/video/backlight/s6e63m0.c delete mode 100644 drivers/video/backlight/s6e63m0_gamma.h diff --git a/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 b/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 deleted file mode 100644 index ae0a2d3dcc07..000000000000 --- a/Documentation/ABI/testing/sysfs-class-lcd-s6e63m0 +++ /dev/null @@ -1,27 +0,0 @@ -sysfs interface for the S6E63M0 AMOLED LCD panel driver -------------------------------------------------------- - -What: /sys/class/lcd//gamma_mode -Date: May, 2010 -KernelVersion: v2.6.35 -Contact: dri-devel@lists.freedesktop.org -Description: - (RW) Read or write the gamma mode. Following three modes are - supported: - 0 - gamma value 2.2, - 1 - gamma value 1.9 and - 2 - gamma value 1.7. - - -What: /sys/class/lcd//gamma_table -Date: May, 2010 -KernelVersion: v2.6.35 -Contact: dri-devel@lists.freedesktop.org -Description: - (RO) Displays the size of the gamma table i.e. the number of - gamma modes available. - -This is a backlight lcd driver. These interfaces are an extension to the API -documented in Documentation/ABI/testing/sysfs-class-lcd and in -Documentation/ABI/stable/sysfs-class-backlight (under -/sys/class/backlight//). diff --git a/drivers/video/backlight/Kconfig b/drivers/video/backlight/Kconfig index 2919e2334052..2373c3cec0c3 100644 --- a/drivers/video/backlight/Kconfig +++ b/drivers/video/backlight/Kconfig @@ -111,14 +111,6 @@ config LCD_HP700 If you have an HP Jornada 700 series handheld (710/720/728) say Y to enable LCD control driver. -config LCD_S6E63M0 - tristate "S6E63M0 AMOLED LCD Driver" - depends on SPI && BACKLIGHT_CLASS_DEVICE - default n - help - If you have an S6E63M0 LCD Panel, say Y to enable its - LCD control driver. - config LCD_LD9040 tristate "LD9040 AMOLED LCD Driver" depends on SPI && BACKLIGHT_CLASS_DEVICE diff --git a/drivers/video/backlight/Makefile b/drivers/video/backlight/Makefile index 0dcc2c745c03..c7a46392a76f 100644 --- a/drivers/video/backlight/Makefile +++ b/drivers/video/backlight/Makefile @@ -15,7 +15,6 @@ obj-$(CONFIG_LCD_LMS501KF03) += lms501kf03.o obj-$(CONFIG_LCD_LTV350QV) += ltv350qv.o obj-$(CONFIG_LCD_OTM3225A) += otm3225a.o obj-$(CONFIG_LCD_PLATFORM) += platform_lcd.o -obj-$(CONFIG_LCD_S6E63M0) += s6e63m0.o obj-$(CONFIG_LCD_TDO24M) += tdo24m.o obj-$(CONFIG_LCD_TOSA) += tosa_lcd.o obj-$(CONFIG_LCD_VGG2432A4) += vgg2432a4.o diff --git a/drivers/video/backlight/s6e63m0.c b/drivers/video/backlight/s6e63m0.c deleted file mode 100644 index 3c4a22a3063a..000000000000 --- a/drivers/video/backlight/s6e63m0.c +++ /dev/null @@ -1,857 +0,0 @@ -/* - * S6E63M0 AMOLED LCD panel driver. - * - * Author: InKi Dae - * - * Derived from drivers/video/omap/lcd-apollon.c - * - * This program is free software; you can redistribute it and/or modify it - * under the terms of the GNU General Public License as published by the - * Free Software Foundation; either version 2 of the License, or (at your - * option) any later version. - */ - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "s6e63m0_gamma.h" - -#define SLEEPMSEC 0x1000 -#define ENDDEF 0x2000 -#define DEFMASK 0xFF00 -#define COMMAND_ONLY 0xFE -#define DATA_ONLY 0xFF - -#define MIN_BRIGHTNESS 0 -#define MAX_BRIGHTNESS 10 - -struct s6e63m0 { - struct device *dev; - struct spi_device *spi; - unsigned int power; - unsigned int current_brightness; - unsigned int gamma_mode; - unsigned int gamma_table_count; - struct lcd_device *ld; - struct backlight_device *bd; - struct lcd_platform_data *lcd_pd; -}; - -static const unsigned short seq_panel_condition_set[] = { - 0xF8, 0x01, - DATA_ONLY, 0x27, - DATA_ONLY, 0x27, - DATA_ONLY, 0x07, - DATA_ONLY, 0x07, - DATA_ONLY, 0x54, - DATA_ONLY, 0x9f, - DATA_ONLY, 0x63, - DATA_ONLY, 0x86, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x33, - DATA_ONLY, 0x0d, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_display_condition_set[] = { - 0xf2, 0x02, - DATA_ONLY, 0x03, - DATA_ONLY, 0x1c, - DATA_ONLY, 0x10, - DATA_ONLY, 0x10, - - 0xf7, 0x03, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_gamma_setting[] = { - 0xfa, 0x00, - DATA_ONLY, 0x18, - DATA_ONLY, 0x08, - DATA_ONLY, 0x24, - DATA_ONLY, 0x64, - DATA_ONLY, 0x56, - DATA_ONLY, 0x33, - DATA_ONLY, 0xb6, - DATA_ONLY, 0xba, - DATA_ONLY, 0xa8, - DATA_ONLY, 0xac, - DATA_ONLY, 0xb1, - DATA_ONLY, 0x9d, - DATA_ONLY, 0xc1, - DATA_ONLY, 0xc1, - DATA_ONLY, 0xb7, - DATA_ONLY, 0x00, - DATA_ONLY, 0x9c, - DATA_ONLY, 0x00, - DATA_ONLY, 0x9f, - DATA_ONLY, 0x00, - DATA_ONLY, 0xd6, - - 0xfa, 0x01, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_etc_condition_set[] = { - 0xf6, 0x00, - DATA_ONLY, 0x8c, - DATA_ONLY, 0x07, - - 0xb3, 0xc, - - 0xb5, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xb6, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xb7, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xb8, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xb9, 0x2c, - DATA_ONLY, 0x12, - DATA_ONLY, 0x0c, - DATA_ONLY, 0x0a, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0e, - DATA_ONLY, 0x17, - DATA_ONLY, 0x13, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x2a, - DATA_ONLY, 0x24, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x1b, - DATA_ONLY, 0x1a, - DATA_ONLY, 0x17, - - DATA_ONLY, 0x2b, - DATA_ONLY, 0x26, - DATA_ONLY, 0x22, - DATA_ONLY, 0x20, - DATA_ONLY, 0x3a, - DATA_ONLY, 0x34, - DATA_ONLY, 0x30, - DATA_ONLY, 0x2c, - DATA_ONLY, 0x29, - DATA_ONLY, 0x26, - DATA_ONLY, 0x25, - DATA_ONLY, 0x23, - DATA_ONLY, 0x21, - DATA_ONLY, 0x20, - DATA_ONLY, 0x1e, - DATA_ONLY, 0x1e, - - 0xba, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x11, - DATA_ONLY, 0x22, - DATA_ONLY, 0x33, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - DATA_ONLY, 0x44, - - DATA_ONLY, 0x55, - DATA_ONLY, 0x55, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - DATA_ONLY, 0x66, - - 0xc1, 0x4d, - DATA_ONLY, 0x96, - DATA_ONLY, 0x1d, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x01, - DATA_ONLY, 0xdf, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x03, - DATA_ONLY, 0x1f, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x00, - DATA_ONLY, 0x03, - DATA_ONLY, 0x06, - DATA_ONLY, 0x09, - DATA_ONLY, 0x0d, - DATA_ONLY, 0x0f, - DATA_ONLY, 0x12, - DATA_ONLY, 0x15, - DATA_ONLY, 0x18, - - 0xb2, 0x10, - DATA_ONLY, 0x10, - DATA_ONLY, 0x0b, - DATA_ONLY, 0x05, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_acl_on[] = { - /* ACL on */ - 0xc0, 0x01, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_acl_off[] = { - /* ACL off */ - 0xc0, 0x00, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_elvss_on[] = { - /* ELVSS on */ - 0xb1, 0x0b, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_elvss_off[] = { - /* ELVSS off */ - 0xb1, 0x0a, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_stand_by_off[] = { - 0x11, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_stand_by_on[] = { - 0x10, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - -static const unsigned short seq_display_on[] = { - 0x29, COMMAND_ONLY, - - ENDDEF, 0x0000 -}; - - -static int s6e63m0_spi_write_byte(struct s6e63m0 *lcd, int addr, int data) -{ - u16 buf[1]; - struct spi_message msg; - - struct spi_transfer xfer = { - .len = 2, - .tx_buf = buf, - }; - - buf[0] = (addr << 8) | data; - - spi_message_init(&msg); - spi_message_add_tail(&xfer, &msg); - - return spi_sync(lcd->spi, &msg); -} - -static int s6e63m0_spi_write(struct s6e63m0 *lcd, unsigned char address, - unsigned char command) -{ - int ret = 0; - - if (address != DATA_ONLY) - ret = s6e63m0_spi_write_byte(lcd, 0x0, address); - if (command != COMMAND_ONLY) - ret = s6e63m0_spi_write_byte(lcd, 0x1, command); - - return ret; -} - -static int s6e63m0_panel_send_sequence(struct s6e63m0 *lcd, - const unsigned short *wbuf) -{ - int ret = 0, i = 0; - - while ((wbuf[i] & DEFMASK) != ENDDEF) { - if ((wbuf[i] & DEFMASK) != SLEEPMSEC) { - ret = s6e63m0_spi_write(lcd, wbuf[i], wbuf[i+1]); - if (ret) - break; - } else { - msleep(wbuf[i+1]); - } - i += 2; - } - - return ret; -} - -static int _s6e63m0_gamma_ctl(struct s6e63m0 *lcd, const unsigned int *gamma) -{ - unsigned int i = 0; - int ret = 0; - - /* disable gamma table updating. */ - ret = s6e63m0_spi_write(lcd, 0xfa, 0x00); - if (ret) { - dev_err(lcd->dev, "failed to disable gamma table updating.\n"); - goto gamma_err; - } - - for (i = 0 ; i < GAMMA_TABLE_COUNT; i++) { - ret = s6e63m0_spi_write(lcd, DATA_ONLY, gamma[i]); - if (ret) { - dev_err(lcd->dev, "failed to set gamma table.\n"); - goto gamma_err; - } - } - - /* update gamma table. */ - ret = s6e63m0_spi_write(lcd, 0xfa, 0x01); - if (ret) - dev_err(lcd->dev, "failed to update gamma table.\n"); - -gamma_err: - return ret; -} - -static int s6e63m0_gamma_ctl(struct s6e63m0 *lcd, int gamma) -{ - int ret = 0; - - ret = _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[gamma]); - - return ret; -} - - -static int s6e63m0_ldi_init(struct s6e63m0 *lcd) -{ - int ret, i; - const unsigned short *init_seq[] = { - seq_panel_condition_set, - seq_display_condition_set, - seq_gamma_setting, - seq_etc_condition_set, - seq_acl_on, - seq_elvss_on, - }; - - for (i = 0; i < ARRAY_SIZE(init_seq); i++) { - ret = s6e63m0_panel_send_sequence(lcd, init_seq[i]); - if (ret) - break; - } - - return ret; -} - -static int s6e63m0_ldi_enable(struct s6e63m0 *lcd) -{ - int ret = 0, i; - const unsigned short *enable_seq[] = { - seq_stand_by_off, - seq_display_on, - }; - - for (i = 0; i < ARRAY_SIZE(enable_seq); i++) { - ret = s6e63m0_panel_send_sequence(lcd, enable_seq[i]); - if (ret) - break; - } - - return ret; -} - -static int s6e63m0_ldi_disable(struct s6e63m0 *lcd) -{ - int ret; - - ret = s6e63m0_panel_send_sequence(lcd, seq_stand_by_on); - - return ret; -} - -static int s6e63m0_power_is_on(int power) -{ - return power <= FB_BLANK_NORMAL; -} - -static int s6e63m0_power_on(struct s6e63m0 *lcd) -{ - int ret = 0; - struct lcd_platform_data *pd; - struct backlight_device *bd; - - pd = lcd->lcd_pd; - bd = lcd->bd; - - if (!pd->power_on) { - dev_err(lcd->dev, "power_on is NULL.\n"); - return -EINVAL; - } - - pd->power_on(lcd->ld, 1); - msleep(pd->power_on_delay); - - if (!pd->reset) { - dev_err(lcd->dev, "reset is NULL.\n"); - return -EINVAL; - } - - pd->reset(lcd->ld); - msleep(pd->reset_delay); - - ret = s6e63m0_ldi_init(lcd); - if (ret) { - dev_err(lcd->dev, "failed to initialize ldi.\n"); - return ret; - } - - ret = s6e63m0_ldi_enable(lcd); - if (ret) { - dev_err(lcd->dev, "failed to enable ldi.\n"); - return ret; - } - - /* set brightness to current value after power on or resume. */ - ret = s6e63m0_gamma_ctl(lcd, bd->props.brightness); - if (ret) { - dev_err(lcd->dev, "lcd gamma setting failed.\n"); - return ret; - } - - return 0; -} - -static int s6e63m0_power_off(struct s6e63m0 *lcd) -{ - int ret; - struct lcd_platform_data *pd; - - pd = lcd->lcd_pd; - - ret = s6e63m0_ldi_disable(lcd); - if (ret) { - dev_err(lcd->dev, "lcd setting failed.\n"); - return -EIO; - } - - msleep(pd->power_off_delay); - - pd->power_on(lcd->ld, 0); - - return 0; -} - -static int s6e63m0_power(struct s6e63m0 *lcd, int power) -{ - int ret = 0; - - if (s6e63m0_power_is_on(power) && !s6e63m0_power_is_on(lcd->power)) - ret = s6e63m0_power_on(lcd); - else if (!s6e63m0_power_is_on(power) && s6e63m0_power_is_on(lcd->power)) - ret = s6e63m0_power_off(lcd); - - if (!ret) - lcd->power = power; - - return ret; -} - -static int s6e63m0_set_power(struct lcd_device *ld, int power) -{ - struct s6e63m0 *lcd = lcd_get_data(ld); - - if (power != FB_BLANK_UNBLANK && power != FB_BLANK_POWERDOWN && - power != FB_BLANK_NORMAL) { - dev_err(lcd->dev, "power value should be 0, 1 or 4.\n"); - return -EINVAL; - } - - return s6e63m0_power(lcd, power); -} - -static int s6e63m0_get_power(struct lcd_device *ld) -{ - struct s6e63m0 *lcd = lcd_get_data(ld); - - return lcd->power; -} - -static int s6e63m0_set_brightness(struct backlight_device *bd) -{ - int ret = 0, brightness = bd->props.brightness; - struct s6e63m0 *lcd = bl_get_data(bd); - - if (brightness < MIN_BRIGHTNESS || - brightness > bd->props.max_brightness) { - dev_err(&bd->dev, "lcd brightness should be %d to %d.\n", - MIN_BRIGHTNESS, MAX_BRIGHTNESS); - return -EINVAL; - } - - ret = s6e63m0_gamma_ctl(lcd, bd->props.brightness); - if (ret) { - dev_err(&bd->dev, "lcd brightness setting failed.\n"); - return -EIO; - } - - return ret; -} - -static struct lcd_ops s6e63m0_lcd_ops = { - .set_power = s6e63m0_set_power, - .get_power = s6e63m0_get_power, -}; - -static const struct backlight_ops s6e63m0_backlight_ops = { - .update_status = s6e63m0_set_brightness, -}; - -static ssize_t s6e63m0_sysfs_show_gamma_mode(struct device *dev, - struct device_attribute *attr, char *buf) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - char temp[10]; - - switch (lcd->gamma_mode) { - case 0: - sprintf(temp, "2.2 mode\n"); - strcat(buf, temp); - break; - case 1: - sprintf(temp, "1.9 mode\n"); - strcat(buf, temp); - break; - case 2: - sprintf(temp, "1.7 mode\n"); - strcat(buf, temp); - break; - default: - dev_info(dev, "gamma mode could be 0:2.2, 1:1.9 or 2:1.7)n"); - break; - } - - return strlen(buf); -} - -static ssize_t s6e63m0_sysfs_store_gamma_mode(struct device *dev, - struct device_attribute *attr, - const char *buf, size_t len) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - struct backlight_device *bd = NULL; - int brightness, rc; - - rc = kstrtouint(buf, 0, &lcd->gamma_mode); - if (rc < 0) - return rc; - - bd = lcd->bd; - - brightness = bd->props.brightness; - - switch (lcd->gamma_mode) { - case 0: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[brightness]); - break; - case 1: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_19_table[brightness]); - break; - case 2: - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_17_table[brightness]); - break; - default: - dev_info(dev, "gamma mode could be 0:2.2, 1:1.9 or 2:1.7\n"); - _s6e63m0_gamma_ctl(lcd, gamma_table.gamma_22_table[brightness]); - break; - } - return len; -} - -static DEVICE_ATTR(gamma_mode, 0644, - s6e63m0_sysfs_show_gamma_mode, s6e63m0_sysfs_store_gamma_mode); - -static ssize_t s6e63m0_sysfs_show_gamma_table(struct device *dev, - struct device_attribute *attr, char *buf) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - char temp[3]; - - sprintf(temp, "%u\n", lcd->gamma_table_count); - strcpy(buf, temp); - - return strlen(buf); -} -static DEVICE_ATTR(gamma_table, 0444, - s6e63m0_sysfs_show_gamma_table, NULL); - -static int s6e63m0_probe(struct spi_device *spi) -{ - int ret = 0; - struct s6e63m0 *lcd = NULL; - struct lcd_device *ld = NULL; - struct backlight_device *bd = NULL; - struct backlight_properties props; - - lcd = devm_kzalloc(&spi->dev, sizeof(struct s6e63m0), GFP_KERNEL); - if (!lcd) - return -ENOMEM; - - /* s6e63m0 lcd panel uses 3-wire 9bits SPI Mode. */ - spi->bits_per_word = 9; - - ret = spi_setup(spi); - if (ret < 0) { - dev_err(&spi->dev, "spi setup failed.\n"); - return ret; - } - - lcd->spi = spi; - lcd->dev = &spi->dev; - - lcd->lcd_pd = dev_get_platdata(&spi->dev); - if (!lcd->lcd_pd) { - dev_err(&spi->dev, "platform data is NULL.\n"); - return -EINVAL; - } - - ld = devm_lcd_device_register(&spi->dev, "s6e63m0", &spi->dev, lcd, - &s6e63m0_lcd_ops); - if (IS_ERR(ld)) - return PTR_ERR(ld); - - lcd->ld = ld; - - memset(&props, 0, sizeof(struct backlight_properties)); - props.type = BACKLIGHT_RAW; - props.max_brightness = MAX_BRIGHTNESS; - - bd = devm_backlight_device_register(&spi->dev, "s6e63m0bl-bl", - &spi->dev, lcd, &s6e63m0_backlight_ops, - &props); - if (IS_ERR(bd)) - return PTR_ERR(bd); - - bd->props.brightness = MAX_BRIGHTNESS; - lcd->bd = bd; - - /* - * it gets gamma table count available so it gets user - * know that. - */ - lcd->gamma_table_count = - sizeof(gamma_table) / (MAX_GAMMA_LEVEL * sizeof(int *)); - - ret = device_create_file(&(spi->dev), &dev_attr_gamma_mode); - if (ret < 0) - dev_err(&(spi->dev), "failed to add sysfs entries\n"); - - ret = device_create_file(&(spi->dev), &dev_attr_gamma_table); - if (ret < 0) - dev_err(&(spi->dev), "failed to add sysfs entries\n"); - - /* - * if lcd panel was on from bootloader like u-boot then - * do not lcd on. - */ - if (!lcd->lcd_pd->lcd_enabled) { - /* - * if lcd panel was off from bootloader then - * current lcd status is powerdown and then - * it enables lcd panel. - */ - lcd->power = FB_BLANK_POWERDOWN; - - s6e63m0_power(lcd, FB_BLANK_UNBLANK); - } else { - lcd->power = FB_BLANK_UNBLANK; - } - - spi_set_drvdata(spi, lcd); - - dev_info(&spi->dev, "s6e63m0 panel driver has been probed.\n"); - - return 0; -} - -static int s6e63m0_remove(struct spi_device *spi) -{ - struct s6e63m0 *lcd = spi_get_drvdata(spi); - - s6e63m0_power(lcd, FB_BLANK_POWERDOWN); - device_remove_file(&spi->dev, &dev_attr_gamma_table); - device_remove_file(&spi->dev, &dev_attr_gamma_mode); - - return 0; -} - -#ifdef CONFIG_PM_SLEEP -static int s6e63m0_suspend(struct device *dev) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - - dev_dbg(dev, "lcd->power = %d\n", lcd->power); - - /* - * when lcd panel is suspend, lcd panel becomes off - * regardless of status. - */ - return s6e63m0_power(lcd, FB_BLANK_POWERDOWN); -} - -static int s6e63m0_resume(struct device *dev) -{ - struct s6e63m0 *lcd = dev_get_drvdata(dev); - - lcd->power = FB_BLANK_POWERDOWN; - - return s6e63m0_power(lcd, FB_BLANK_UNBLANK); -} -#endif - -static SIMPLE_DEV_PM_OPS(s6e63m0_pm_ops, s6e63m0_suspend, s6e63m0_resume); - -/* Power down all displays on reboot, poweroff or halt. */ -static void s6e63m0_shutdown(struct spi_device *spi) -{ - struct s6e63m0 *lcd = spi_get_drvdata(spi); - - s6e63m0_power(lcd, FB_BLANK_POWERDOWN); -} - -static struct spi_driver s6e63m0_driver = { - .driver = { - .name = "s6e63m0", - .pm = &s6e63m0_pm_ops, - }, - .probe = s6e63m0_probe, - .remove = s6e63m0_remove, - .shutdown = s6e63m0_shutdown, -}; - -module_spi_driver(s6e63m0_driver); - -MODULE_AUTHOR("InKi Dae "); -MODULE_DESCRIPTION("S6E63M0 LCD Driver"); -MODULE_LICENSE("GPL"); - diff --git a/drivers/video/backlight/s6e63m0_gamma.h b/drivers/video/backlight/s6e63m0_gamma.h deleted file mode 100644 index 2c44bdb0696b..000000000000 --- a/drivers/video/backlight/s6e63m0_gamma.h +++ /dev/null @@ -1,266 +0,0 @@ -/* linux/drivers/video/samsung/s6e63m0_brightness.h - * - * Gamma level definitions. - * - * Copyright (c) 2009 Samsung Electronics - * InKi Dae - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation. -*/ - -#ifndef _S6E63M0_BRIGHTNESS_H -#define _S6E63M0_BRIGHTNESS_H - -#define MAX_GAMMA_LEVEL 11 -#define GAMMA_TABLE_COUNT 21 - -/* gamma value: 2.2 */ -static const unsigned int s6e63m0_22_300[] = { - 0x18, 0x08, 0x24, 0x5f, 0x50, 0x2d, 0xB6, - 0xB9, 0xA7, 0xAd, 0xB1, 0x9f, 0xbe, 0xC0, - 0xB5, 0x00, 0xa0, 0x00, 0xa4, 0x00, 0xdb -}; - -static const unsigned int s6e63m0_22_280[] = { - 0x18, 0x08, 0x24, 0x64, 0x56, 0x33, 0xB6, - 0xBA, 0xA8, 0xAC, 0xB1, 0x9D, 0xC1, 0xC1, - 0xB7, 0x00, 0x9C, 0x00, 0x9F, 0x00, 0xD6 -}; - -static const unsigned int s6e63m0_22_260[] = { - 0x18, 0x08, 0x24, 0x66, 0x58, 0x34, 0xB6, - 0xBA, 0xA7, 0xAF, 0xB3, 0xA0, 0xC1, 0xC2, - 0xB7, 0x00, 0x97, 0x00, 0x9A, 0x00, 0xD1 - -}; - -static const unsigned int s6e63m0_22_240[] = { - 0x18, 0x08, 0x24, 0x62, 0x54, 0x30, 0xB9, - 0xBB, 0xA9, 0xB0, 0xB3, 0xA1, 0xC1, 0xC3, - 0xB7, 0x00, 0x91, 0x00, 0x95, 0x00, 0xDA - -}; -static const unsigned int s6e63m0_22_220[] = { - 0x18, 0x08, 0x24, 0x63, 0x53, 0x31, 0xB8, - 0xBC, 0xA9, 0xB0, 0xB5, 0xA2, 0xC4, 0xC4, - 0xB8, 0x00, 0x8B, 0x00, 0x8E, 0x00, 0xC2 -}; - -static const unsigned int s6e63m0_22_200[] = { - 0x18, 0x08, 0x24, 0x66, 0x55, 0x34, 0xBA, - 0xBD, 0xAB, 0xB1, 0xB5, 0xA3, 0xC5, 0xC6, - 0xB9, 0x00, 0x85, 0x00, 0x88, 0x00, 0xBA -}; - -static const unsigned int s6e63m0_22_170[] = { - 0x18, 0x08, 0x24, 0x69, 0x54, 0x37, 0xBB, - 0xBE, 0xAC, 0xB4, 0xB7, 0xA6, 0xC7, 0xC8, - 0xBC, 0x00, 0x7B, 0x00, 0x7E, 0x00, 0xAB -}; - -static const unsigned int s6e63m0_22_140[] = { - 0x18, 0x08, 0x24, 0x6C, 0x54, 0x3A, 0xBC, - 0xBF, 0xAC, 0xB7, 0xBB, 0xA9, 0xC9, 0xC9, - 0xBE, 0x00, 0x71, 0x00, 0x73, 0x00, 0x9E -}; - -static const unsigned int s6e63m0_22_110[] = { - 0x18, 0x08, 0x24, 0x70, 0x51, 0x3E, 0xBF, - 0xC1, 0xAF, 0xB9, 0xBC, 0xAB, 0xCC, 0xCC, - 0xC2, 0x00, 0x65, 0x00, 0x67, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_22_90[] = { - 0x18, 0x08, 0x24, 0x73, 0x4A, 0x3D, 0xC0, - 0xC2, 0xB1, 0xBB, 0xBE, 0xAC, 0xCE, 0xCF, - 0xC5, 0x00, 0x5D, 0x00, 0x5E, 0x00, 0x82 -}; - -static const unsigned int s6e63m0_22_30[] = { - 0x18, 0x08, 0x24, 0x78, 0xEC, 0x3D, 0xC8, - 0xC2, 0xB6, 0xC4, 0xC7, 0xB6, 0xD5, 0xD7, - 0xCC, 0x00, 0x39, 0x00, 0x36, 0x00, 0x51 -}; - -/* gamma value: 1.9 */ -static const unsigned int s6e63m0_19_300[] = { - 0x18, 0x08, 0x24, 0x61, 0x5F, 0x39, 0xBA, - 0xBD, 0xAD, 0xB1, 0xB6, 0xA5, 0xC4, 0xC5, - 0xBC, 0x00, 0xA0, 0x00, 0xA4, 0x00, 0xDB -}; - -static const unsigned int s6e63m0_19_280[] = { - 0x18, 0x08, 0x24, 0x61, 0x60, 0x39, 0xBB, - 0xBE, 0xAD, 0xB2, 0xB6, 0xA6, 0xC5, 0xC7, - 0xBD, 0x00, 0x9B, 0x00, 0x9E, 0x00, 0xD5 -}; - -static const unsigned int s6e63m0_19_260[] = { - 0x18, 0x08, 0x24, 0x63, 0x61, 0x3B, 0xBA, - 0xBE, 0xAC, 0xB3, 0xB8, 0xA7, 0xC6, 0xC8, - 0xBD, 0x00, 0x96, 0x00, 0x98, 0x00, 0xCF -}; - -static const unsigned int s6e63m0_19_240[] = { - 0x18, 0x08, 0x24, 0x67, 0x64, 0x3F, 0xBB, - 0xBE, 0xAD, 0xB3, 0xB9, 0xA7, 0xC8, 0xC9, - 0xBE, 0x00, 0x90, 0x00, 0x92, 0x00, 0xC8 -}; - -static const unsigned int s6e63m0_19_220[] = { - 0x18, 0x08, 0x24, 0x68, 0x64, 0x40, 0xBC, - 0xBF, 0xAF, 0xB4, 0xBA, 0xA9, 0xC8, 0xCA, - 0xBE, 0x00, 0x8B, 0x00, 0x8C, 0x00, 0xC0 -}; - -static const unsigned int s6e63m0_19_200[] = { - 0x18, 0x08, 0x24, 0x68, 0x64, 0x3F, 0xBE, - 0xC0, 0xB0, 0xB6, 0xBB, 0xAB, 0xC8, 0xCB, - 0xBF, 0x00, 0x85, 0x00, 0x86, 0x00, 0xB8 -}; - -static const unsigned int s6e63m0_19_170[] = { - 0x18, 0x08, 0x24, 0x69, 0x64, 0x40, 0xBF, - 0xC1, 0xB0, 0xB9, 0xBE, 0xAD, 0xCB, 0xCD, - 0xC2, 0x00, 0x7A, 0x00, 0x7B, 0x00, 0xAA -}; - -static const unsigned int s6e63m0_19_140[] = { - 0x18, 0x08, 0x24, 0x6E, 0x65, 0x45, 0xC0, - 0xC3, 0xB2, 0xBA, 0xBE, 0xAE, 0xCD, 0xD0, - 0xC4, 0x00, 0x70, 0x00, 0x70, 0x00, 0x9C -}; - -static const unsigned int s6e63m0_19_110[] = { - 0x18, 0x08, 0x24, 0x6F, 0x65, 0x46, 0xC2, - 0xC4, 0xB3, 0xBF, 0xC2, 0xB2, 0xCF, 0xD1, - 0xC6, 0x00, 0x64, 0x00, 0x64, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_19_90[] = { - 0x18, 0x08, 0x24, 0x74, 0x60, 0x4A, 0xC3, - 0xC6, 0xB5, 0xBF, 0xC3, 0xB2, 0xD2, 0xD3, - 0xC8, 0x00, 0x5B, 0x00, 0x5B, 0x00, 0x81 -}; - -static const unsigned int s6e63m0_19_30[] = { - 0x18, 0x08, 0x24, 0x84, 0x45, 0x4F, 0xCA, - 0xCB, 0xBC, 0xC9, 0xCB, 0xBC, 0xDA, 0xDA, - 0xD0, 0x00, 0x35, 0x00, 0x34, 0x00, 0x4E -}; - -/* gamma value: 1.7 */ -static const unsigned int s6e63m0_17_300[] = { - 0x18, 0x08, 0x24, 0x70, 0x70, 0x4F, 0xBF, - 0xC2, 0xB2, 0xB8, 0xBC, 0xAC, 0xCB, 0xCD, - 0xC3, 0x00, 0xA0, 0x00, 0xA4, 0x00, 0xDB -}; - -static const unsigned int s6e63m0_17_280[] = { - 0x18, 0x08, 0x24, 0x71, 0x71, 0x50, 0xBF, - 0xC2, 0xB2, 0xBA, 0xBE, 0xAE, 0xCB, 0xCD, - 0xC3, 0x00, 0x9C, 0x00, 0x9F, 0x00, 0xD6 -}; - -static const unsigned int s6e63m0_17_260[] = { - 0x18, 0x08, 0x24, 0x72, 0x72, 0x50, 0xC0, - 0xC3, 0xB4, 0xB9, 0xBE, 0xAE, 0xCC, 0xCF, - 0xC4, 0x00, 0x97, 0x00, 0x9A, 0x00, 0xD1 -}; - -static const unsigned int s6e63m0_17_240[] = { - 0x18, 0x08, 0x24, 0x71, 0x72, 0x4F, 0xC2, - 0xC4, 0xB5, 0xBB, 0xBF, 0xB0, 0xCC, 0xCF, - 0xC3, 0x00, 0x91, 0x00, 0x95, 0x00, 0xCA -}; - -static const unsigned int s6e63m0_17_220[] = { - 0x18, 0x08, 0x24, 0x71, 0x73, 0x4F, 0xC2, - 0xC5, 0xB5, 0xBD, 0xC0, 0xB2, 0xCD, 0xD1, - 0xC5, 0x00, 0x8B, 0x00, 0x8E, 0x00, 0xC2 -}; - -static const unsigned int s6e63m0_17_200[] = { - 0x18, 0x08, 0x24, 0x72, 0x75, 0x51, 0xC2, - 0xC6, 0xB5, 0xBF, 0xC1, 0xB3, 0xCE, 0xD1, - 0xC6, 0x00, 0x85, 0x00, 0x88, 0x00, 0xBA -}; - -static const unsigned int s6e63m0_17_170[] = { - 0x18, 0x08, 0x24, 0x75, 0x77, 0x54, 0xC3, - 0xC7, 0xB7, 0xC0, 0xC3, 0xB4, 0xD1, 0xD3, - 0xC9, 0x00, 0x7B, 0x00, 0x7E, 0x00, 0xAB -}; - -static const unsigned int s6e63m0_17_140[] = { - 0x18, 0x08, 0x24, 0x7B, 0x77, 0x58, 0xC3, - 0xC8, 0xB8, 0xC2, 0xC6, 0xB6, 0xD3, 0xD4, - 0xCA, 0x00, 0x71, 0x00, 0x73, 0x00, 0x9E -}; - -static const unsigned int s6e63m0_17_110[] = { - 0x18, 0x08, 0x24, 0x81, 0x7B, 0x5D, 0xC6, - 0xCA, 0xBB, 0xC3, 0xC7, 0xB8, 0xD6, 0xD8, - 0xCD, 0x00, 0x65, 0x00, 0x67, 0x00, 0x8D -}; - -static const unsigned int s6e63m0_17_90[] = { - 0x18, 0x08, 0x24, 0x82, 0x7A, 0x5B, 0xC8, - 0xCB, 0xBD, 0xC5, 0xCA, 0xBA, 0xD6, 0xD8, - 0xCE, 0x00, 0x5D, 0x00, 0x5E, 0x00, 0x82 -}; - -static const unsigned int s6e63m0_17_30[] = { - 0x18, 0x08, 0x24, 0x8F, 0x73, 0x63, 0xD1, - 0xD0, 0xC5, 0xCC, 0xD1, 0xC2, 0xDE, 0xE0, - 0xD6, 0x00, 0x39, 0x00, 0x36, 0x00, 0x51 -}; - -struct s6e63m0_gamma { - unsigned int *gamma_22_table[MAX_GAMMA_LEVEL]; - unsigned int *gamma_19_table[MAX_GAMMA_LEVEL]; - unsigned int *gamma_17_table[MAX_GAMMA_LEVEL]; -}; - -static struct s6e63m0_gamma gamma_table = { - .gamma_22_table[0] = (unsigned int *)&s6e63m0_22_30, - .gamma_22_table[1] = (unsigned int *)&s6e63m0_22_90, - .gamma_22_table[2] = (unsigned int *)&s6e63m0_22_110, - .gamma_22_table[3] = (unsigned int *)&s6e63m0_22_140, - .gamma_22_table[4] = (unsigned int *)&s6e63m0_22_170, - .gamma_22_table[5] = (unsigned int *)&s6e63m0_22_200, - .gamma_22_table[6] = (unsigned int *)&s6e63m0_22_220, - .gamma_22_table[7] = (unsigned int *)&s6e63m0_22_240, - .gamma_22_table[8] = (unsigned int *)&s6e63m0_22_260, - .gamma_22_table[9] = (unsigned int *)&s6e63m0_22_280, - .gamma_22_table[10] = (unsigned int *)&s6e63m0_22_300, - - .gamma_19_table[0] = (unsigned int *)&s6e63m0_19_30, - .gamma_19_table[1] = (unsigned int *)&s6e63m0_19_90, - .gamma_19_table[2] = (unsigned int *)&s6e63m0_19_110, - .gamma_19_table[3] = (unsigned int *)&s6e63m0_19_140, - .gamma_19_table[4] = (unsigned int *)&s6e63m0_19_170, - .gamma_19_table[5] = (unsigned int *)&s6e63m0_19_200, - .gamma_19_table[6] = (unsigned int *)&s6e63m0_19_220, - .gamma_19_table[7] = (unsigned int *)&s6e63m0_19_240, - .gamma_19_table[8] = (unsigned int *)&s6e63m0_19_260, - .gamma_19_table[9] = (unsigned int *)&s6e63m0_19_280, - .gamma_19_table[10] = (unsigned int *)&s6e63m0_19_300, - - .gamma_17_table[0] = (unsigned int *)&s6e63m0_17_30, - .gamma_17_table[1] = (unsigned int *)&s6e63m0_17_90, - .gamma_17_table[2] = (unsigned int *)&s6e63m0_17_110, - .gamma_17_table[3] = (unsigned int *)&s6e63m0_17_140, - .gamma_17_table[4] = (unsigned int *)&s6e63m0_17_170, - .gamma_17_table[5] = (unsigned int *)&s6e63m0_17_200, - .gamma_17_table[6] = (unsigned int *)&s6e63m0_17_220, - .gamma_17_table[7] = (unsigned int *)&s6e63m0_17_240, - .gamma_17_table[8] = (unsigned int *)&s6e63m0_17_260, - .gamma_17_table[9] = (unsigned int *)&s6e63m0_17_280, - .gamma_17_table[10] = (unsigned int *)&s6e63m0_17_300, -}; - -#endif - -- 2.14.1