mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	fbdev: remove display subsystem
This four year old subsystem does not have a single in-tree user not even in staging and as far as I know also none out-of-tree. I think that justifies removing it which cleans the config up. Signed-off-by: Florian Tobias Schandinat <FlorianSchandinat@gmx.de> Acked-by: James Simmons <jsimmons@infradead.org> Cc: Andrew Morton <akpm@linux-foundation.org>
This commit is contained in:
		
							parent
							
								
									b57287ba49
								
							
						
					
					
						commit
						5a6b5e02d6
					
				| @ -2413,7 +2413,6 @@ source "drivers/video/omap/Kconfig" | |||||||
| source "drivers/video/omap2/Kconfig" | source "drivers/video/omap2/Kconfig" | ||||||
| 
 | 
 | ||||||
| source "drivers/video/backlight/Kconfig" | source "drivers/video/backlight/Kconfig" | ||||||
| source "drivers/video/display/Kconfig" |  | ||||||
| 
 | 
 | ||||||
| if VT | if VT | ||||||
| 	source "drivers/video/console/Kconfig" | 	source "drivers/video/console/Kconfig" | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ fb-objs                           := $(fb-y) | |||||||
| 
 | 
 | ||||||
| obj-$(CONFIG_VT)		  += console/ | obj-$(CONFIG_VT)		  += console/ | ||||||
| obj-$(CONFIG_LOGO)		  += logo/ | obj-$(CONFIG_LOGO)		  += logo/ | ||||||
| obj-y				  += backlight/ display/ | obj-y				  += backlight/ | ||||||
| 
 | 
 | ||||||
| obj-$(CONFIG_FB_CFB_FILLRECT)  += cfbfillrect.o | obj-$(CONFIG_FB_CFB_FILLRECT)  += cfbfillrect.o | ||||||
| obj-$(CONFIG_FB_CFB_COPYAREA)  += cfbcopyarea.o | obj-$(CONFIG_FB_CFB_COPYAREA)  += cfbcopyarea.o | ||||||
|  | |||||||
| @ -1,24 +0,0 @@ | |||||||
| # |  | ||||||
| # Display drivers configuration |  | ||||||
| # |  | ||||||
| 
 |  | ||||||
| menu "Display device support" |  | ||||||
| 
 |  | ||||||
| config DISPLAY_SUPPORT |  | ||||||
| 	tristate "Display panel/monitor support" |  | ||||||
| 	---help--- |  | ||||||
| 	  This framework adds support for low-level control of a display. |  | ||||||
| 	  This includes support for power. |  | ||||||
| 
 |  | ||||||
| 	  Enable this to be able to choose the drivers for controlling the |  | ||||||
| 	  physical display panel/monitor on some platforms. This not only |  | ||||||
| 	  covers LCD displays for PDAs but also other types of displays |  | ||||||
| 	  such as CRT, TVout etc. |  | ||||||
| 
 |  | ||||||
| 	  To have support for your specific display panel you will have to |  | ||||||
| 	  select the proper drivers which depend on this option. |  | ||||||
| 
 |  | ||||||
| comment "Display hardware drivers" |  | ||||||
| 	depends on DISPLAY_SUPPORT |  | ||||||
| 
 |  | ||||||
| endmenu |  | ||||||
| @ -1,6 +0,0 @@ | |||||||
| # Display drivers
 |  | ||||||
| 
 |  | ||||||
| display-objs				:= display-sysfs.o |  | ||||||
| 
 |  | ||||||
| obj-$(CONFIG_DISPLAY_SUPPORT)		+= display.o |  | ||||||
| 
 |  | ||||||
| @ -1,219 +0,0 @@ | |||||||
| /*
 |  | ||||||
|  *  display-sysfs.c - Display output driver sysfs interface |  | ||||||
|  * |  | ||||||
|  *  Copyright (C) 2007 James Simmons <jsimmons@infradead.org> |  | ||||||
|  * |  | ||||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  * |  | ||||||
|  *  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. |  | ||||||
|  * |  | ||||||
|  *  This program is distributed in the hope that it will be useful, but |  | ||||||
|  *  WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |  | ||||||
|  *  General Public License for more details. |  | ||||||
|  * |  | ||||||
|  *  You should have received a copy of the GNU General Public License along |  | ||||||
|  *  with this program; if not, write to the Free Software Foundation, Inc., |  | ||||||
|  *  59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. |  | ||||||
|  * |  | ||||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  */ |  | ||||||
| #include <linux/module.h> |  | ||||||
| #include <linux/display.h> |  | ||||||
| #include <linux/ctype.h> |  | ||||||
| #include <linux/idr.h> |  | ||||||
| #include <linux/err.h> |  | ||||||
| #include <linux/kdev_t.h> |  | ||||||
| #include <linux/slab.h> |  | ||||||
| 
 |  | ||||||
| static ssize_t display_show_name(struct device *dev, |  | ||||||
| 				struct device_attribute *attr, char *buf) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 	return snprintf(buf, PAGE_SIZE, "%s\n", dsp->name); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static ssize_t display_show_type(struct device *dev, |  | ||||||
| 				struct device_attribute *attr, char *buf) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 	return snprintf(buf, PAGE_SIZE, "%s\n", dsp->type); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static ssize_t display_show_contrast(struct device *dev, |  | ||||||
| 				struct device_attribute *attr, char *buf) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 	ssize_t rc = -ENXIO; |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&dsp->lock); |  | ||||||
| 	if (likely(dsp->driver) && dsp->driver->get_contrast) |  | ||||||
| 		rc = sprintf(buf, "%d\n", dsp->driver->get_contrast(dsp)); |  | ||||||
| 	mutex_unlock(&dsp->lock); |  | ||||||
| 	return rc; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static ssize_t display_store_contrast(struct device *dev, |  | ||||||
| 					struct device_attribute *attr, |  | ||||||
| 					const char *buf, size_t count) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 	ssize_t ret = -EINVAL, size; |  | ||||||
| 	int contrast; |  | ||||||
| 	char *endp; |  | ||||||
| 
 |  | ||||||
| 	contrast = simple_strtoul(buf, &endp, 0); |  | ||||||
| 	size = endp - buf; |  | ||||||
| 
 |  | ||||||
| 	if (isspace(*endp)) |  | ||||||
| 		size++; |  | ||||||
| 
 |  | ||||||
| 	if (size != count) |  | ||||||
| 		return ret; |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&dsp->lock); |  | ||||||
| 	if (likely(dsp->driver && dsp->driver->set_contrast)) { |  | ||||||
| 		pr_debug("display: set contrast to %d\n", contrast); |  | ||||||
| 		dsp->driver->set_contrast(dsp, contrast); |  | ||||||
| 		ret = count; |  | ||||||
| 	} |  | ||||||
| 	mutex_unlock(&dsp->lock); |  | ||||||
| 	return ret; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static ssize_t display_show_max_contrast(struct device *dev, |  | ||||||
| 					struct device_attribute *attr, |  | ||||||
| 					char *buf) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 	ssize_t rc = -ENXIO; |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&dsp->lock); |  | ||||||
| 	if (likely(dsp->driver)) |  | ||||||
| 		rc = sprintf(buf, "%d\n", dsp->driver->max_contrast); |  | ||||||
| 	mutex_unlock(&dsp->lock); |  | ||||||
| 	return rc; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static struct device_attribute display_attrs[] = { |  | ||||||
| 	__ATTR(name, S_IRUGO, display_show_name, NULL), |  | ||||||
| 	__ATTR(type, S_IRUGO, display_show_type, NULL), |  | ||||||
| 	__ATTR(contrast, S_IRUGO | S_IWUSR, display_show_contrast, display_store_contrast), |  | ||||||
| 	__ATTR(max_contrast, S_IRUGO, display_show_max_contrast, NULL), |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static int display_suspend(struct device *dev, pm_message_t state) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&dsp->lock); |  | ||||||
| 	if (likely(dsp->driver->suspend)) |  | ||||||
| 		dsp->driver->suspend(dsp, state); |  | ||||||
| 	mutex_unlock(&dsp->lock); |  | ||||||
| 	return 0; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static int display_resume(struct device *dev) |  | ||||||
| { |  | ||||||
| 	struct display_device *dsp = dev_get_drvdata(dev); |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&dsp->lock); |  | ||||||
| 	if (likely(dsp->driver->resume)) |  | ||||||
| 		dsp->driver->resume(dsp); |  | ||||||
| 	mutex_unlock(&dsp->lock); |  | ||||||
| 	return 0; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| static struct mutex allocated_dsp_lock; |  | ||||||
| static DEFINE_IDR(allocated_dsp); |  | ||||||
| static struct class *display_class; |  | ||||||
| 
 |  | ||||||
| struct display_device *display_device_register(struct display_driver *driver, |  | ||||||
| 						struct device *parent, void *devdata) |  | ||||||
| { |  | ||||||
| 	struct display_device *new_dev = NULL; |  | ||||||
| 	int ret = -EINVAL; |  | ||||||
| 
 |  | ||||||
| 	if (unlikely(!driver)) |  | ||||||
| 		return ERR_PTR(ret); |  | ||||||
| 
 |  | ||||||
| 	mutex_lock(&allocated_dsp_lock); |  | ||||||
| 	ret = idr_pre_get(&allocated_dsp, GFP_KERNEL); |  | ||||||
| 	mutex_unlock(&allocated_dsp_lock); |  | ||||||
| 	if (!ret) |  | ||||||
| 		return ERR_PTR(ret); |  | ||||||
| 
 |  | ||||||
| 	new_dev = kzalloc(sizeof(struct display_device), GFP_KERNEL); |  | ||||||
| 	if (likely(new_dev) && unlikely(driver->probe(new_dev, devdata))) { |  | ||||||
| 		// Reserve the index for this display
 |  | ||||||
| 		mutex_lock(&allocated_dsp_lock); |  | ||||||
| 		ret = idr_get_new(&allocated_dsp, new_dev, &new_dev->idx); |  | ||||||
| 		mutex_unlock(&allocated_dsp_lock); |  | ||||||
| 
 |  | ||||||
| 		if (!ret) { |  | ||||||
| 			new_dev->dev = device_create(display_class, parent, |  | ||||||
| 						     MKDEV(0, 0), new_dev, |  | ||||||
| 						     "display%d", new_dev->idx); |  | ||||||
| 			if (!IS_ERR(new_dev->dev)) { |  | ||||||
| 				new_dev->parent = parent; |  | ||||||
| 				new_dev->driver = driver; |  | ||||||
| 				mutex_init(&new_dev->lock); |  | ||||||
| 				return new_dev; |  | ||||||
| 			} |  | ||||||
| 			mutex_lock(&allocated_dsp_lock); |  | ||||||
| 			idr_remove(&allocated_dsp, new_dev->idx); |  | ||||||
| 			mutex_unlock(&allocated_dsp_lock); |  | ||||||
| 			ret = -EINVAL; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	kfree(new_dev); |  | ||||||
| 	return ERR_PTR(ret); |  | ||||||
| } |  | ||||||
| EXPORT_SYMBOL(display_device_register); |  | ||||||
| 
 |  | ||||||
| void display_device_unregister(struct display_device *ddev) |  | ||||||
| { |  | ||||||
| 	if (!ddev) |  | ||||||
| 		return; |  | ||||||
| 	// Free device
 |  | ||||||
| 	mutex_lock(&ddev->lock); |  | ||||||
| 	device_unregister(ddev->dev); |  | ||||||
| 	mutex_unlock(&ddev->lock); |  | ||||||
| 	// Mark device index as available
 |  | ||||||
| 	mutex_lock(&allocated_dsp_lock); |  | ||||||
| 	idr_remove(&allocated_dsp, ddev->idx); |  | ||||||
| 	mutex_unlock(&allocated_dsp_lock); |  | ||||||
| 	kfree(ddev); |  | ||||||
| } |  | ||||||
| EXPORT_SYMBOL(display_device_unregister); |  | ||||||
| 
 |  | ||||||
| static int __init display_class_init(void) |  | ||||||
| { |  | ||||||
| 	display_class = class_create(THIS_MODULE, "display"); |  | ||||||
| 	if (IS_ERR(display_class)) { |  | ||||||
| 		printk(KERN_ERR "Failed to create display class\n"); |  | ||||||
| 		display_class = NULL; |  | ||||||
| 		return -EINVAL; |  | ||||||
| 	} |  | ||||||
| 	display_class->dev_attrs = display_attrs; |  | ||||||
| 	display_class->suspend = display_suspend; |  | ||||||
| 	display_class->resume = display_resume; |  | ||||||
| 	mutex_init(&allocated_dsp_lock); |  | ||||||
| 	return 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| static void __exit display_class_exit(void) |  | ||||||
| { |  | ||||||
| 	class_destroy(display_class); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| module_init(display_class_init); |  | ||||||
| module_exit(display_class_exit); |  | ||||||
| 
 |  | ||||||
| MODULE_DESCRIPTION("Display Hardware handling"); |  | ||||||
| MODULE_AUTHOR("James Simmons <jsimmons@infradead.org>"); |  | ||||||
| MODULE_LICENSE("GPL"); |  | ||||||
| 
 |  | ||||||
| @ -1,61 +0,0 @@ | |||||||
| /*
 |  | ||||||
|  *  Copyright (C) 2006 James Simmons <jsimmons@infradead.org> |  | ||||||
|  * |  | ||||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  * |  | ||||||
|  *  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. |  | ||||||
|  * |  | ||||||
|  *  This program is distributed in the hope that it will be useful, but |  | ||||||
|  *  WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
|  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |  | ||||||
|  *  General Public License for more details. |  | ||||||
|  * |  | ||||||
|  *  You should have received a copy of the GNU General Public License along |  | ||||||
|  *  with this program; if not, write to the Free Software Foundation, Inc., |  | ||||||
|  *  59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. |  | ||||||
|  * |  | ||||||
|  * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #ifndef _LINUX_DISPLAY_H |  | ||||||
| #define _LINUX_DISPLAY_H |  | ||||||
| 
 |  | ||||||
| #include <linux/device.h> |  | ||||||
| 
 |  | ||||||
| struct display_device; |  | ||||||
| 
 |  | ||||||
| /* This structure defines all the properties of a Display. */ |  | ||||||
| struct display_driver { |  | ||||||
| 	int  (*set_contrast)(struct display_device *, unsigned int); |  | ||||||
| 	int  (*get_contrast)(struct display_device *); |  | ||||||
| 	void (*suspend)(struct display_device *, pm_message_t state); |  | ||||||
| 	void (*resume)(struct display_device *); |  | ||||||
| 	int  (*probe)(struct display_device *, void *); |  | ||||||
| 	int  (*remove)(struct display_device *); |  | ||||||
| 	int  max_contrast; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| struct display_device { |  | ||||||
| 	struct module *owner;			/* Owner module */ |  | ||||||
| 	struct display_driver *driver; |  | ||||||
| 	struct device *parent;			/* This is the parent */ |  | ||||||
| 	struct device *dev;			/* This is this display device */ |  | ||||||
| 	struct mutex lock; |  | ||||||
| 	void *priv_data; |  | ||||||
| 	char type[16]; |  | ||||||
| 	char *name; |  | ||||||
| 	int idx; |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| extern struct display_device *display_device_register(struct display_driver *driver, |  | ||||||
| 					struct device *dev, void *devdata); |  | ||||||
| extern void display_device_unregister(struct display_device *dev); |  | ||||||
| 
 |  | ||||||
| extern int probe_edid(struct display_device *dev, void *devdata); |  | ||||||
| 
 |  | ||||||
| #define to_display_device(obj) container_of(obj, struct display_device, class_dev) |  | ||||||
| 
 |  | ||||||
| #endif |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Florian Tobias Schandinat
						Florian Tobias Schandinat