Re: [PATCH 1/2] IPMI/ACPI: Locate the IPMI system interface in ACPI namespace

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

 



On Monday 26 October 2009 07:02:55 pm ykzhao wrote:
> In fact you mention two issues about the two patches:
>    1: Load a PNP driver for it to register the IPMI system interface.
> This is about the first patch.
>    2. coding style( for example: comments, the definition about some
> variables).
> 
> For the first issue: Before I start the first patch, I consider using
> the PNP device driver. But I find that it is so complex because of the
> following two points:
>     1. One is that we can't register the IPMI system interface if the
> boot option of "pnpacpi=off" is added. This will also depend on the PNP
> module.

This is not a problem.  It is perfectly acceptable for the IPMI driver
to depend on PNP and PNPACPI in order to claim an ACPI device.  If the
users boots with "pnpacpi=off", we just won't find an IPMI device.
That is the way it works for TPM devices and serial devices described
by ACPI, and IPMI should work the same way.

>     2. The second is that there exist so many cases about the IPMI
> IO/memory resource definition. Maybe there exist both IO/memory resource
> definition for one IPMI device. In such case we can't know which should
> be selected. At the same time we have similar issues about the interrupt
> type. So I decide to parse the IO/memory/interrupt resource
> independently.

This doesn't make any sense.  The fact that an IPMI device might have
a variety of IO/memory/IRQ resources is orthogonal to the question of
whether you should use pnp_register_driver() or acpi_walk_namespace().

PNPACPI parses the IPMI device resources for every ACPI device,
including the IPMI device, before we even know whether there will be
a PNP driver for the device.  It's much easier to look at the PNP
resources and figure out which to use than it is to use
acpi_walk_resources() manually.

The main point is that ipmi_si_intf.c is a device driver, and it should
use the normal driver registration mechanisms.  I think it would be
simplest and clearest to make a few PNP enhancements so it could use
pnp_register_driver(), but even using acpi_bus_register_driver() would
be fine.  Using acpi_walk_namespace() to do everything by hand is just
completely wrong.

Bjorn


--
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