On Tue, 2009-12-15 at 13:22 +0800, Bjorn Helgaas wrote: > On Tue, 2009-12-15 at 08:59 +0800, ykzhao wrote: > > On Tue, 2009-12-15 at 08:18 +0800, Bjorn Helgaas wrote: > > > On Sunday 13 December 2009 03:20:27 am ykzhao wrote: > > > > On Wed, 2009-12-09 at 22:57 +0800, Bjorn Helgaas wrote: > > > > > On Tuesday 08 December 2009 06:58:45 pm yakui.zhao@xxxxxxxxx wrote: > > > > > > From: Zhao Yakui <yakui.zhao@xxxxxxxxx> > > > > > > > > > > > > Add the IPMI opregion driver so that the AML code can communicate with BMC > > > > > > throught IPMI message. > > > > > > It will create IPMI user interface for every IPMI device detected > > > > > > in ACPI namespace and install the corresponding IPMI opregion space handler. > > > > > > > > > > > > The following describes how to process the IPMI request in IPMI space handler: > > > > > > 1. format the IPMI message based on the request in AML code. > > > > > > IPMI system address. Now the address type is SYSTEM_INTERFACE_ADDR_TYPE > > > > > > IPMI net function & command > > > > > > IPMI message payload > > > > > > 2. send the IPMI message by using the function of ipmi_request_settime > > > > > > 3. wait for the completion of IPMI message. It can be done in different > > > > > > routes: One is in handled in IPMI user recv callback function. Another is > > > > > > handled in timeout function. > > > > > > 4. format the IPMI response and return it to ACPI AML code. > > > > > > > > > > I think this should be part of the ipmi_si_intf module, not a separate > > > > > module. This opregion code is of no use without ipmi_si_intf. The > > > > > opregion code can still be under its own config option, but I don't > > > > > see the value in having it be a separate module. > > > > > > > > This opregion code can't work if the IPMI subsystem is not loaded. this > > > > is right. I also agree with this point. > > > > But this doesn't mean that this must be put into the module of > > > > ipmi_si_intf. > > > > In fact this opregion code only uses the IPMI API function to > > > > communicate with IPMI system interface. At the same time its main > > > > purpose is to handle the request from ACPI AML code. It had better be > > > > put into the ACPI subsystem. I think that it is unnecessary to put it > > > > into the ipmi_si_intf module. > > > > > > > > > > > > BTW: Several modules(for example: drivers/hwmon/ibmaem.c , > > > > drivers/hwmon/ibmpex.c) also use the IPMI system interface to > > > > communicate with the IPMI subsystem. But they are the different part of > > > > ipmi_si_intf module. > > > > > > > > > The opregion code should definitely not use acpi_bus_register_driver() > > > > > to claim IPI0001 devices. The ipmi_si_intf driver already uses > > > > > pnp_register_driver() to claim IPI0001 devices. The fact that Linux > > > > > allows two drivers to claim the same device (one via pnp_register_driver() > > > > > and the other via acpi_bus_register_driver()) is a defect in Linux, and > > > > > we shouldn't take advantage of that. > > > > > > > > If you think that this code had better not use the > > > > acpi_bus_register_driver, I will try to enumerate this device from ACPI > > > > device tree directly and then install the IPMI opregion handler for it. > > > > > > I think there are two questions here: (1) should this be part of > > > ipmi_si_intf? and (2) how should it be registered? > > > > > > For (1), I see your point that we do have existing modules that are > > > separate modules, and this is conceptually similar to those. So > > > maybe this should be a separate module, too. If they're separate > > > modules, I think the issues are how they communicate and how we get > > > the opregion part autoloaded. It's easy to see how ipmi_si_intf > > > gets autoloaded -- the PNP or PCI core discovers a device and emits > > > a uevent that udev can match with a driver. I don't think we want > > > the user to have to explicitly modprobe the opregion driver, so we > > > need some uevent or similar hook that udev can use to load it > > > automatically when appropriate. > > > > From the source code it seems that the ipmi_si_intf module only detects > > the available BMC device. It doesn't care which part communicates with > > the BMC device. So it will be better to put this code out of > > ipmi_si_intf module. > > > > Whether the opregion code should used depends on the user configuration. > > If we expect that the ACPI aml code can communicate with the BMC, we > > will select this part. Correspondingly the IPMI subsystem will also be > > selected as this part depends on the IPMI subsystem. If the user doesn't > > care whether the AML code can communicate with the BMC, they can leave > > it alone. If we expect to use the uevent, that is not related with this > > patch. > > I'm sorry, I don't understand what you're saying here. I expect the > opregion module to be generally useful, so distros will probably enable > the config option, so the module will be present on every machine. How > do you plan to have it loaded? We need some sort of automatic > mechanism; the user should not have to decide whether to load the > module. What I said is that user needs to decide whether the IPMI opregion module should be used when building the kernel. If we want to use it, we will have to select it in kernel configuration. And then system will load it in the boot time. Right? If not right, do we need care the case that this opregion code is not loaded automatically in the boot time? If you think that it is ok to enable the opregion part as soon as we finish the detection of IPMI system interfaces, I can add the opregion code into the ipmi_si_intf part. But if so, maybe we can use the ACPI device driver to detect the BMC controller defined in ACPI namespace instead of using PNP device driver. At the same time this mechanism should be used firstly. Is this OK to you? > > > > For (2), I don't think using acpi_walk_namespace() to determine when > > > to install the IPMI opregion handler is quite the right thing either. > > > > This opregion handler allows AML to use IPMI services. Using > > > acpi_walk_namespace() means that we'll only install the handler > > > when we have an ACPI IPMI device. But I think the opregion should > > > be independent of the type of IPMI device, i.e., I think we want > > > this opregion to work even if the underlying IPMI interface is PCI. > > > > This opregion code is only to enable the ACPI AML code to communicate > > with the BMC device. If AML code wants to access the BMC controller, we > > must declare the corresponding IPMI device in ACPI namespace and add the > > opregion field definition. If the IPMI device is not declared explicitly > > in ACPI table, this code won't work even when there exists the BMC > > device on the system. > > Oops, sorry, I see that you are right: the ACPI 4.0 spec, sec 5.5.2.4.3, > Declaring IPMI Operation Regions, is indeed restricted so it only works > with ACPI IPMI devices. That is an unfortunate restriction on the > platform architecture, but maybe there's a good reason for it. > > That section says that operation regions are defined within the > immediate context of the 'owning' IPMI device. This, together with the > fact that the opregion support is only useful for ACPI devices, suggests > to me that the opregion module is different from the ibmaem and ibmpex > modules after all. Those modules apparently can work with *any* sort of > IPMI device, so they are more independent. The IPMI opregion code is only used for the IPMI device that defined in ACPI namespace. If one IPMI device is not defined in ACPI namespace, then we won't install IPMI opregion space handler for it. Corresponding the ACPI AML code won't communicate with it. > > I know we have an implicit assumption that a system contains only one > IPMI device, but the ACPI spec doesn't mention that, so I'd like to > avoid that assumption. The sentence in the spec about the "'owning' > IPMI device" implies an association between an opregion and a device. > That association is easy to maintain if the opregion support is > integrated into ipmi_si_intf, but hard to maintain if they are separate. I agree that it is easier to maintain the IPMI opregion code in the ipmi_si_intf module. But this opregion code has no relationship with IPMI subsystem besides that it uses the IPMI API interface function. If we put it together, maybe some other people will be confused. They will ask why put irrelevant code into the ipmi_si_intf module that only detects the system available BMC controller? I doesn't assume that the system only contains one IPMI device. In the patch it will compare the device pointed by IPMI smi_info with the ACPI device and create one user_interface for it, which is used to communicate with the BMC controller. When more than one BMC controller is found on the system, the opregion code still can work if we first register the IPMI device that is defined in ACPI namespace. But in fact maybe the IPMI device defined in ACPI namespace is already registered by other mechanism(DMI, SPMI, PCI and so on). In such case the device pointed by IPMI smi_info is not the ACPI device. So I add a workaround for this issue. That means that it will create user_interface even when the dev pointed by IPMI smi_info is not a ACPI device. Then if two IPMI devices are defined in ACPI namespace, maybe this is a problem. > 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