Hi, all, I'm working on ACPI device enumeration support recently, and here is the proposal I made to enumerate devices via ACPI namespace. the main idea is that, for Serial Buses like I2C and SPI, we enumerate the controller as a platform device, and then enumerate the slaves via i2c/spi_register_board_info. And then, when the controller is really probed and enabled in the platform driver, the SPI/I2C bus code will enumerate I2C/SPI slaves automatically. And for the other devices, we will enumerate all of them as platform devices, which is not covered in this patch set yet. Patch 1 & 2 Introduce ACPI style device match method in platform_match. this is because an ACPI device may have multiple hardware ID (_HID) and Compatible IDs, aka, _CID, but in platform device code, only pdev->name is used to match the driver id_table currently. Patch 3 introduces a new API acpi_get_generic_resources(). this API is used to convert ACPI style resources to the generic struct resource. Patch 4 changes i2c_register_board_info from __init to __devinit. This is needed because I want to enumerate the slave devices in ACPI I2C control Driver, which supports hotplug in theory. Patch 5 introduces the ACPI I2C controller enumeration drive. it enumerate the ACPI I2C controller to a platform device and then enumerate the I2C slaves as I2C_board_info. Patch 6 is an example driver for an ACPI enuemrated I2C controller. Note that this is just prototype patch set, which just passes build test. Because I'd like to get your ideas about this before going on. any comments are welcome. thanks, rui