From mboxrd@z Thu Jan 1 00:00:00 1970 From: Rene Herman Subject: Re: [patch 11/15] PNP: centralize resource option allocations Date: Mon, 02 Jun 2008 01:21:10 +0200 Message-ID: <48432EE6.8000501@keyaccess.nl> References: <20080530224853.976744229@ldl.fc.hp.com> <20080530224933.560428539@ldl.fc.hp.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-15; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from smtpq2.groni1.gr.home.nl ([213.51.130.201]:35713 "EHLO smtpq2.groni1.gr.home.nl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752487AbYFAXR7 (ORCPT ); Sun, 1 Jun 2008 19:17:59 -0400 In-Reply-To: <20080530224933.560428539@ldl.fc.hp.com> Sender: linux-acpi-owner@vger.kernel.org List-Id: linux-acpi@vger.kernel.org To: Bjorn Helgaas Cc: Len Brown , linux-acpi@vger.kernel.org, linux-kernel@vger.kernel.org, Adam Belay , Adam M Belay , Li Shaohua , Matthieu Castet , Thomas Renninger , Jaroslav Kysela , Andrew Morton , Takashi Iwai On 31-05-08 00:49, Bjorn Helgaas wrote: > This patch moves all the option allocations (pnp_mem, pnp_port, etc) > into the pnp_register_{mem,port,irq,dma}_resource() functions. This > will make it easier to rework the option data structures. > > The non-trivial part of this patch is the IRQ handling. The backends > have to allocate a local pnp_irq_mask_t bitmap, populate it, and pass > a pointer to pnp_register_irq_resource(). > > Signed-off-by: Bjorn Helgaas [ ... ] > Index: work10/drivers/pnp/isapnp/core.c > =================================================================== > --- work10.orig/drivers/pnp/isapnp/core.c 2008-05-30 13:20:36.000000000 -0600 > +++ work10/drivers/pnp/isapnp/core.c 2008-05-30 13:23:34.000000000 -0600 > @@ -433,20 +433,23 @@ static void __init isapnp_parse_irq_reso > int size) > { > unsigned char tmp[3]; > - struct pnp_irq *irq; > unsigned long bits; > + int i; > + pnp_irq_mask_t map; > + unsigned char flags = IORESOURCE_IRQ_HIGHEDGE; > > isapnp_peek(tmp, size); > - irq = kzalloc(sizeof(struct pnp_irq), GFP_KERNEL); > - if (!irq) > - return; > bits = (tmp[1] << 8) | tmp[0]; > - bitmap_copy(irq->map.bits, &bits, 16); > + > + bitmap_zero(map.bits, PNP_IRQ_NR); > + for (i = 0; i < 15; i++) > + if (bits & (1 << i)) > + __set_bit(i, map.bits); > + for (i = 0; i < 16; i++) (16 instead of 15) it would seem. And why not simply: bitmap_zero(map.bits, PNP_IRQ_NR); bitmap_copy(map.bits, &bits, 16); That last bit of the comment same for pnpbios_parse_irq_option(). Should be fine, no? > static __init void pnpbios_parse_port_option(struct pnp_dev *dev, > unsigned char *p, int size, > struct pnp_option *option) > { > - struct pnp_port *port; > + resource_size_t min, max, align, len, flags; unsigned char flags; All the rest: Acked-by: Rene Herman Rene.