lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Date:	Mon, 28 Feb 2011 21:33:04 +0100
From:	"Rafael J. Wysocki" <rjw@...k.pl>
To:	Johan Wessfeldt <johan.wessfeldt@...il.com>
Cc:	lenb@...nel.org, linux-acpi@...r.kernel.org,
	linux-kernel@...r.kernel.org
Subject: Re: [PATCH] acpi: Corrections of unchecked calls to request_region

On Monday, February 28, 2011, Johan Wessfeldt wrote:
> This patch introduces checks when acpi osl reserves resources by calling
> request_region.

Why is the patch necessary?

> Please review:
> Is it valid to return early when acpi_request_region() fails?

What do you mean by "return early"?

Rafael


> Signed-off-by: Johan Wessfeldt <johan.wessfeldt@...il.com>
> ---
>  drivers/acpi/osl.c |   85 +++++++++++++++++++++++++++++++++++-----------------
>  1 files changed, 57 insertions(+), 28 deletions(-)
> 
> diff --git a/drivers/acpi/osl.c b/drivers/acpi/osl.c
> index c90c76a..5c8c521 100644
> --- a/drivers/acpi/osl.c
> +++ b/drivers/acpi/osl.c
> @@ -166,48 +166,77 @@ static u32 acpi_osi_handler(acpi_string interface, u32 supported)
>  	return supported;
>  }
>  
> -static void __init acpi_request_region (struct acpi_generic_address *addr,
> +static int __init acpi_request_region(struct acpi_generic_address *addr,
>  	unsigned int length, char *desc)
>  {
> +	struct resource *pRes;
> +
>  	if (!addr->address || !length)
> -		return;
> +		return -EIO;
>  
>  	/* Resources are never freed */
> -	if (addr->space_id == ACPI_ADR_SPACE_SYSTEM_IO)
> -		request_region(addr->address, length, desc);
> -	else if (addr->space_id == ACPI_ADR_SPACE_SYSTEM_MEMORY)
> -		request_mem_region(addr->address, length, desc);
> +	if (addr->space_id == ACPI_ADR_SPACE_SYSTEM_IO) {
> +		pRes = request_region(addr->address, length, desc);
> +		if (pRes == NULL)
> +			return -EIO;
> +
> +	} else if (addr->space_id == ACPI_ADR_SPACE_SYSTEM_MEMORY) {
> +		pRes = request_mem_region(addr->address, length, desc);
> +		if (pRes == NULL)
> +			return -EIO;
> +	}
> +
> +	return 0;
>  }
>  
>  static int __init acpi_reserve_resources(void)
>  {
> -	acpi_request_region(&acpi_gbl_FADT.xpm1a_event_block, acpi_gbl_FADT.pm1_event_length,
> -		"ACPI PM1a_EVT_BLK");
> +	if (!acpi_request_region(&acpi_gbl_FADT.xpm1a_event_block,
> +				 acpi_gbl_FADT.pm1_event_length,
> +				 "ACPI PM1a_EVT_BLK"))
> +		return -EIO;
>  
> -	acpi_request_region(&acpi_gbl_FADT.xpm1b_event_block, acpi_gbl_FADT.pm1_event_length,
> -		"ACPI PM1b_EVT_BLK");
> +	if (!acpi_request_region(&acpi_gbl_FADT.xpm1b_event_block,
> +				 acpi_gbl_FADT.pm1_event_length,
> +				 "ACPI PM1b_EVT_BLK"))
> +		return -EIO;
>  
> -	acpi_request_region(&acpi_gbl_FADT.xpm1a_control_block, acpi_gbl_FADT.pm1_control_length,
> -		"ACPI PM1a_CNT_BLK");
> +	if (!acpi_request_region(&acpi_gbl_FADT.xpm1a_control_block,
> +				 acpi_gbl_FADT.pm1_control_length,
> +				 "ACPI PM1a_CNT_BLK"))
> +		return -EIO;
>  
> -	acpi_request_region(&acpi_gbl_FADT.xpm1b_control_block, acpi_gbl_FADT.pm1_control_length,
> -		"ACPI PM1b_CNT_BLK");
> +	if (!acpi_request_region(&acpi_gbl_FADT.xpm1b_control_block,
> +				 acpi_gbl_FADT.pm1_control_length,
> +				 "ACPI PM1b_CNT_BLK"))
> +		return -EIO;
>  
> -	if (acpi_gbl_FADT.pm_timer_length == 4)
> -		acpi_request_region(&acpi_gbl_FADT.xpm_timer_block, 4, "ACPI PM_TMR");
> +	if (acpi_gbl_FADT.pm_timer_length == 4) {
> +		if (!acpi_request_region(&acpi_gbl_FADT.xpm_timer_block,
> +					 4, "ACPI PM_TMR"))
> +			return -EIO;
> +	}
>  
> -	acpi_request_region(&acpi_gbl_FADT.xpm2_control_block, acpi_gbl_FADT.pm2_control_length,
> -		"ACPI PM2_CNT_BLK");
> +	if (!acpi_request_region(&acpi_gbl_FADT.xpm2_control_block,
> +				 acpi_gbl_FADT.pm2_control_length,
> +				 "ACPI PM2_CNT_BLK"))
> +		return -EIO;
>  
>  	/* Length of GPE blocks must be a non-negative multiple of 2 */
>  
> -	if (!(acpi_gbl_FADT.gpe0_block_length & 0x1))
> -		acpi_request_region(&acpi_gbl_FADT.xgpe0_block,
> -			       acpi_gbl_FADT.gpe0_block_length, "ACPI GPE0_BLK");
> +	if (!(acpi_gbl_FADT.gpe0_block_length & 0x1)) {
> +		if (!acpi_request_region(&acpi_gbl_FADT.xgpe0_block,
> +					 acpi_gbl_FADT.gpe0_block_length,
> +					 "ACPI GPE0_BLK"))
> +			return -EIO;
> +	}
>  
> -	if (!(acpi_gbl_FADT.gpe1_block_length & 0x1))
> -		acpi_request_region(&acpi_gbl_FADT.xgpe1_block,
> -			       acpi_gbl_FADT.gpe1_block_length, "ACPI GPE1_BLK");
> +	if (!(acpi_gbl_FADT.gpe1_block_length & 0x1)) {
> +		if (!acpi_request_region(&acpi_gbl_FADT.xgpe1_block,
> +					 acpi_gbl_FADT.gpe1_block_length,
> +					 "ACPI GPE1_BLK"))
> +			return -EIO;
> +	}
>  
>  	return 0;
>  }
> 

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ