| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  *  Backlight Driver for Nvidia 8600 in Macbook Pro | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Copyright (c) Red Hat <mjg@redhat.com> | 
					
						
							|  |  |  |  *  Based on code from Pommed: | 
					
						
							|  |  |  |  *  Copyright (C) 2006 Nicolas Boichat <nicolas @boichat.ch> | 
					
						
							|  |  |  |  *  Copyright (C) 2006 Felipe Alfaro Solana <felipe_alfaro @linuxmail.org> | 
					
						
							|  |  |  |  *  Copyright (C) 2007 Julien BLACHE <jb@jblache.org> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  This driver triggers SMIs which cause the firmware to change the | 
					
						
							|  |  |  |  *  backlight brightness. This is icky in many ways, but it's impractical to | 
					
						
							|  |  |  |  *  get at the firmware code in order to figure out what it's actually doing. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <linux/module.h>
 | 
					
						
							|  |  |  | #include <linux/kernel.h>
 | 
					
						
							|  |  |  | #include <linux/init.h>
 | 
					
						
							|  |  |  | #include <linux/platform_device.h>
 | 
					
						
							|  |  |  | #include <linux/backlight.h>
 | 
					
						
							|  |  |  | #include <linux/err.h>
 | 
					
						
							|  |  |  | #include <linux/dmi.h>
 | 
					
						
							|  |  |  | #include <linux/io.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static struct backlight_device *mbp_backlight_device; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | /* Structure to be passed to the DMI_MATCH function. */ | 
					
						
							|  |  |  | struct dmi_match_data { | 
					
						
							|  |  |  | 	/* I/O resource to allocate. */ | 
					
						
							|  |  |  | 	unsigned long iostart; | 
					
						
							|  |  |  | 	unsigned long iolen; | 
					
						
							|  |  |  | 	/* Backlight operations structure. */ | 
					
						
							| 
									
										
										
										
											2009-12-14 00:58:57 +01:00
										 |  |  | 	const struct backlight_ops backlight_ops; | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | /* Module parameters. */ | 
					
						
							|  |  |  | static int debug; | 
					
						
							|  |  |  | module_param_named(debug, debug, int, 0644); | 
					
						
							|  |  |  | MODULE_PARM_DESC(debug, "Set to one to enable debugging messages."); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Implementation for MacBooks with Intel chipset. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static int intel_chipset_send_intensity(struct backlight_device *bd) | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	int intensity = bd->props.brightness; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	if (debug) | 
					
						
							|  |  |  | 		printk(KERN_DEBUG "mbp_nvidia_bl: setting brightness to %d\n", | 
					
						
							|  |  |  | 		       intensity); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 	outb(0x04 | (intensity << 4), 0xb3); | 
					
						
							|  |  |  | 	outb(0xbf, 0xb2); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | static int intel_chipset_get_intensity(struct backlight_device *bd) | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	int intensity; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 	outb(0x03, 0xb3); | 
					
						
							|  |  |  | 	outb(0xbf, 0xb2); | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	intensity = inb(0xb3) >> 4; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (debug) | 
					
						
							|  |  |  | 		printk(KERN_DEBUG "mbp_nvidia_bl: read brightness of %d\n", | 
					
						
							|  |  |  | 		       intensity); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return intensity; | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | static const struct dmi_match_data intel_chipset_data = { | 
					
						
							|  |  |  | 	.iostart = 0xb2, | 
					
						
							|  |  |  | 	.iolen = 2, | 
					
						
							|  |  |  | 	.backlight_ops	= { | 
					
						
							|  |  |  | 		.options	= BL_CORE_SUSPENDRESUME, | 
					
						
							|  |  |  | 		.get_brightness	= intel_chipset_get_intensity, | 
					
						
							|  |  |  | 		.update_status	= intel_chipset_send_intensity, | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Implementation for MacBooks with Nvidia chipset. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static int nvidia_chipset_send_intensity(struct backlight_device *bd) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int intensity = bd->props.brightness; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	if (debug) | 
					
						
							|  |  |  | 		printk(KERN_DEBUG "mbp_nvidia_bl: setting brightness to %d\n", | 
					
						
							|  |  |  | 		       intensity); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	outb(0x04 | (intensity << 4), 0x52f); | 
					
						
							|  |  |  | 	outb(0xbf, 0x52e); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int nvidia_chipset_get_intensity(struct backlight_device *bd) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	int intensity; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	outb(0x03, 0x52f); | 
					
						
							|  |  |  | 	outb(0xbf, 0x52e); | 
					
						
							| 
									
										
										
										
											2009-01-11 00:19:31 +00:00
										 |  |  | 	intensity = inb(0x52f) >> 4; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (debug) | 
					
						
							|  |  |  | 		printk(KERN_DEBUG "mbp_nvidia_bl: read brightness of %d\n", | 
					
						
							|  |  |  | 		       intensity); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return intensity; | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const struct dmi_match_data nvidia_chipset_data = { | 
					
						
							|  |  |  | 	.iostart = 0x52e, | 
					
						
							|  |  |  | 	.iolen = 2, | 
					
						
							|  |  |  | 	.backlight_ops		= { | 
					
						
							|  |  |  | 		.options	= BL_CORE_SUSPENDRESUME, | 
					
						
							|  |  |  | 		.get_brightness	= nvidia_chipset_get_intensity, | 
					
						
							|  |  |  | 		.update_status	= nvidia_chipset_send_intensity | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * DMI matching. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static /* const */ struct dmi_match_data *driver_data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int mbp_dmi_match(const struct dmi_system_id *id) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	driver_data = id->driver_data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	printk(KERN_INFO "mbp_nvidia_bl: %s detected\n", id->ident); | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const struct dmi_system_id __initdata mbp_device_table[] = { | 
					
						
							| 
									
										
										
										
											2010-03-09 19:20:58 -05:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 1,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							| 
									
										
										
										
											2010-03-23 23:12:33 +01:00
										 |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Computer, Inc."), | 
					
						
							| 
									
										
										
										
											2010-03-09 19:20:58 -05:00
										 |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook1,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 2,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook2,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 3,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook3,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 4,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook4,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 4,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook4,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2010-04-19 17:59:26 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 1,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro1,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 1,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro1,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 2,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro2,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 2,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro2,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 3,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro3,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 3,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro3,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 4,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro4,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-09-07 14:19:54 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookAir 1,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookAir1,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&intel_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 5,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook5,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-08-20 12:39:48 +02:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 5,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook5,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2010-04-19 17:59:26 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBook 6,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBook6,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookAir 2,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookAir2,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 5,1", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5,1"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-08-20 12:39:48 +02:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 5,2", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5,2"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-12-02 00:41:31 +01:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 5,3", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5,3"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 5,4", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5,4"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-08-20 12:39:48 +02:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		.callback	= mbp_dmi_match, | 
					
						
							|  |  |  | 		.ident		= "MacBookPro 5,5", | 
					
						
							|  |  |  | 		.matches	= { | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_SYS_VENDOR, "Apple Inc."), | 
					
						
							|  |  |  | 			DMI_MATCH(DMI_PRODUCT_NAME, "MacBookPro5,5"), | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		.driver_data	= (void *)&nvidia_chipset_data, | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	{ } | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int __init mbp_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-02-17 16:39:44 -05:00
										 |  |  | 	struct backlight_properties props; | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 	if (!dmi_check_system(mbp_device_table)) | 
					
						
							|  |  |  | 		return -ENODEV; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	if (!request_region(driver_data->iostart, driver_data->iolen,  | 
					
						
							|  |  |  | 						"Macbook Pro backlight")) | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 		return -ENXIO; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-17 16:39:44 -05:00
										 |  |  | 	memset(&props, 0, sizeof(struct backlight_properties)); | 
					
						
							|  |  |  | 	props.max_brightness = 15; | 
					
						
							|  |  |  | 	mbp_backlight_device = backlight_device_register("mbp_backlight", NULL, | 
					
						
							|  |  |  | 							 NULL, | 
					
						
							|  |  |  | 							 &driver_data->backlight_ops, | 
					
						
							|  |  |  | 							 &props); | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 	if (IS_ERR(mbp_backlight_device)) { | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 		release_region(driver_data->iostart, driver_data->iolen); | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 		return PTR_ERR(mbp_backlight_device); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mbp_backlight_device->props.brightness = | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 		driver_data->backlight_ops.get_brightness(mbp_backlight_device); | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | 	backlight_update_status(mbp_backlight_device); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void __exit mbp_exit(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	backlight_device_unregister(mbp_backlight_device); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-11 00:11:34 +00:00
										 |  |  | 	release_region(driver_data->iostart, driver_data->iolen); | 
					
						
							| 
									
										
										
										
											2008-06-09 21:56:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module_init(mbp_init); | 
					
						
							|  |  |  | module_exit(mbp_exit); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | MODULE_AUTHOR("Matthew Garrett <mjg@redhat.com>"); | 
					
						
							|  |  |  | MODULE_DESCRIPTION("Nvidia-based Macbook Pro Backlight Driver"); | 
					
						
							|  |  |  | MODULE_LICENSE("GPL"); | 
					
						
							| 
									
										
										
										
											2008-09-16 16:25:24 -07:00
										 |  |  | MODULE_DEVICE_TABLE(dmi, mbp_device_table); |