Re: [PATCH 55/84] ACPI: video: fix brightness allocation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Saturday 28 June 2008 07:43:59 Len Brown wrote:
> From: Julia Jomantaite <julia.jomantaite@xxxxxxxxx>
>
> Fix use of uninitialized device->brightness.

Can this one be left out.
I did something similar and put the brightness (and display output) 
initialization into separate functions for bug #9614:
http://bugzilla.kernel.org/show_bug.cgi?id=9614

My patches go a step further and make sure that not several drivers try to do 
the switching.

They probably still need a bit testing and reviewing, but the first one:
Cleanup: Initialize brightness and display switching in separate functions
could replace this one (maybe a small one on top is still needed) already?
This would make things easier for me.

Could these three posted on the bug go into linux-next or into -mm?
Or should I better set up separate [PATCH 0/3] mails?

Thanks,

    Thomas

>
> Signed-off-by: Julia Jomantaite <julia.jomantaite@xxxxxxxxx>
> Acked-by: Zhang Rui <rui.zhang@xxxxxxxxx>
> Signed-off-by: Len Brown <len.brown@xxxxxxxxx>
> ---
>  drivers/acpi/video.c |  123
> +++++++++++++++++++++++++++++-------------------- 1 files changed, 73
> insertions(+), 50 deletions(-)
>
> diff --git a/drivers/acpi/video.c b/drivers/acpi/video.c
> index d089c45..0da8f55 100644
> --- a/drivers/acpi/video.c
> +++ b/drivers/acpi/video.c
> @@ -631,6 +631,76 @@ acpi_video_bus_DOS(struct acpi_video_bus *video, int
> bios_flag, int lcd_flag) *  	device	: video output device (LCD, CRT, ..)
>   *
>   *  Return Value:
> + *  	Maximum brightness level
> + *
> + *  Allocate and initialize device->brightness.
> + */
> +
> +static int
> +acpi_video_init_brightness(struct acpi_video_device *device)
> +{
> +	union acpi_object *obj = NULL;
> +	int i, max_level = 0, count = 0;
> +	union acpi_object *o;
> +	struct acpi_video_device_brightness *br = NULL;
> +
> +	if (!ACPI_SUCCESS(acpi_video_device_lcd_query_levels(device, &obj))) {
> +		ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Could not query available "
> +						"LCD brightness level\n"));
> +		goto out;
> +	}
> +
> +	if (obj->package.count < 2)
> +		goto out;
> +
> +	br = kzalloc(sizeof(*br), GFP_KERNEL);
> +	if (!br) {
> +		printk(KERN_ERR "can't allocate memory\n");
> +		goto out;
> +	}
> +
> +	br->levels = kmalloc(obj->package.count * sizeof *(br->levels),
> +				GFP_KERNEL);
> +	if (!br->levels)
> +		goto out_free;
> +
> +	for (i = 0; i < obj->package.count; i++) {
> +		o = (union acpi_object *)&obj->package.elements[i];
> +		if (o->type != ACPI_TYPE_INTEGER) {
> +			printk(KERN_ERR PREFIX "Invalid data\n");
> +			continue;
> +		}
> +		br->levels[count] = (u32) o->integer.value;
> +
> +		if (br->levels[count] > max_level)
> +			max_level = br->levels[count];
> +		count++;
> +	}
> +
> +	if (count < 2)
> +		goto out_free_levels;
> +
> +	br->count = count;
> +	device->brightness = br;
> +	ACPI_DEBUG_PRINT((ACPI_DB_INFO,	"found %d brightness levels\n",	count));
> +	kfree(obj);
> +	return max_level;
> +
> +out_free_levels:
> +	kfree(br->levels);
> +out_free:
> +	kfree(br);
> +out:
> +	device->brightness = NULL;
> +	kfree(obj);
> +	return 0;
> +}
> +
> +/*
> + *  Arg:
> + *  	device	: video output device (LCD, CRT, ..)
> + *
> + *  Return Value:
>   *  	None
>   *
>   *  Find out all required AML methods defined under the output
> @@ -640,10 +710,7 @@ acpi_video_bus_DOS(struct acpi_video_bus *video, int
> bios_flag, int lcd_flag) static void acpi_video_device_find_cap(struct
> acpi_video_device *device) {
>  	acpi_handle h_dummy1;
> -	int i;
>  	u32 max_level = 0;
> -	union acpi_object *obj = NULL;
> -	struct acpi_video_device_brightness *br = NULL;
>
>
>  	memset(&device->cap, 0, sizeof(device->cap));
> @@ -672,53 +739,7 @@ static void acpi_video_device_find_cap(struct
> acpi_video_device *device) device->cap._DSS = 1;
>  	}
>
> -	if (ACPI_SUCCESS(acpi_video_device_lcd_query_levels(device, &obj))) {
> -
> -		if (obj->package.count >= 2) {
> -			int count = 0;
> -			union acpi_object *o;
> -
> -			br = kzalloc(sizeof(*br), GFP_KERNEL);
> -			if (!br) {
> -				printk(KERN_ERR "can't allocate memory\n");
> -			} else {
> -				br->levels = kmalloc(obj->package.count *
> -						     sizeof *(br->levels), GFP_KERNEL);
> -				if (!br->levels)
> -					goto out;
> -
> -				for (i = 0; i < obj->package.count; i++) {
> -					o = (union acpi_object *)&obj->package.
> -					    elements[i];
> -					if (o->type != ACPI_TYPE_INTEGER) {
> -						printk(KERN_ERR PREFIX "Invalid data\n");
> -						continue;
> -					}
> -					br->levels[count] = (u32) o->integer.value;
> -
> -					if (br->levels[count] > max_level)
> -						max_level = br->levels[count];
> -					count++;
> -				}
> -			      out:
> -				if (count < 2) {
> -					kfree(br->levels);
> -					kfree(br);
> -				} else {
> -					br->count = count;
> -					device->brightness = br;
> -					ACPI_DEBUG_PRINT((ACPI_DB_INFO,
> -							  "found %d brightness levels\n",
> -							  count));
> -				}
> -			}
> -		}
> -
> -	} else {
> -		ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Could not query available LCD
> brightness level\n")); -	}
> -
> -	kfree(obj);
> +	max_level = acpi_video_init_brightness(device);
>
>  	if (device->cap._BCL && device->cap._BCM && device->cap._BQC && max_level
> > 0){ int result;
> @@ -1695,6 +1716,8 @@ static void
>  acpi_video_switch_brightness(struct acpi_video_device *device, int event)
>  {
>  	unsigned long level_current, level_next;
> +	if (!device->brightness)
> +		return;
>  	acpi_video_device_lcd_get_level_current(device, &level_current);
>  	level_next = acpi_video_get_next_level(device, level_current, event);
>  	acpi_video_device_lcd_set_level(device, level_next);


--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux