|From:||Tomasz Figa <firstname.lastname@example.org>|
|Subject:||[PATCH v3 0/3] Generic Device Tree based power domain look-up|
|Date:||Wed, 23 Apr 2014 18:46:55 +0200|
|Cc:||email@example.com, firstname.lastname@example.org, email@example.com, firstname.lastname@example.org, Greg Kroah-Hartman <email@example.com>, "Rafael J. Wysocki" <firstname.lastname@example.org>, Pavel Machek <email@example.com>, Len Brown <firstname.lastname@example.org>, Russell King <email@example.com>, Kukjin Kim <firstname.lastname@example.org>, Kumar Gala <email@example.com>, Ian Campbell <firstname.lastname@example.org>, Mark Rutland <email@example.com>, Pawel Moll <firstname.lastname@example.org>, Rob Herring <email@example.com>, Bartlomiej Zolnierkiewicz <firstname.lastname@example.org>, Stephen Warren <email@example.com>, Mark Brown <firstname.lastname@example.org>, Stephen Boyd <email@example.com>, Lorenzo Pieralisi <firstname.lastname@example.org>, Ulf Hansson <email@example.com>, Marek Szyprowski <firstname.lastname@example.org>, Tomasz Figa <email@example.com>, Kevin Hilman <firstname.lastname@example.org>, Philipp Zabel <email@example.com>, Tomasz Figa <firstname.lastname@example.org>|
Up till now there was no single generic method to bind devices to their power domains using Device Tree. Each platform has been doing this using its own way, example of which are Exynos power domain bindings  and look-up code . This series is intended to change this and provide generic DT bindings for power domain specification and generic code performing look-up of power domains and binding them to devices. First two patches are the most important part of this series, as they introduce $subject. Patch 3 converts mach-exynos to use the new generic method. Further patches are adding one more user of the new code, mach-s3c64xx, with first 3 patches (4-6) required to clean-up its power domain driver a bit and last 3 patches (9-11) adding display support for Mini6410 board, including a node for display controller (FIMD) which is a power domain consumer. The design of DT bindings and provider code is heavily inspired by implementation of clock providers in Common Clock Framework, while the code binding devices to power domains by my Exynos power domain implementation (now removed by this series ;)). Successfully tested on Exynos4210-based Trats and Exynos4412-based Trats2 boards using MFC,  Documentation/devicetree/bindings/arm/exynos/power_domain.txt  arch/arm/mach-exynos/pm_domains.c Changes since v2: (http://thread.gmane.org/gmane.linux.kernel/1658926) - rebased onto current Rafael's linux-pm bleeding-edge branch, - dropped patches for s3c64xx for now. I will send them in separate series, - do not call pm_genpd_dev_need_restore(true) in genpd_bind_domain(), - fixed various stylistic issues reported in review comments. Changes since v1 (RFC): [https://lkml.org/lkml/2014/1/11/141] - rebased onto current Rafael's linux-pm bleeding-edge branch, - reordered the patches a bit (to have the generic ones first), - dropped renaming of S3C64xx power domains (as suggested by Mark Brown), - added support for deferred probing (as suggested by Stephen Boyd), - fixed several minor issues pointed by Stephen Boyd, - replaced notifiers with direct hooks in driver core to make power domain support independent from specific bus type and allow error handling. Tomasz Figa (3): base: power: Add generic OF-based power domain look-up drivercore: Bind/unbind power domain on probe/remove ARM: exynos: Move to generic power domain bindings .../bindings/arm/exynos/power_domain.txt | 12 +- .../devicetree/bindings/power/power_domain.txt | 51 ++++ arch/arm/mach-exynos/pm_domains.c | 81 +----- drivers/base/dd.c | 9 +- drivers/base/power/domain.c | 283 +++++++++++++++++++++ include/linux/pm_domain.h | 46 ++++ kernel/power/Kconfig | 4 + 7 files changed, 398 insertions(+), 88 deletions(-) create mode 100644 Documentation/devicetree/bindings/power/power_domain.txt -- 1.9.2 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to email@example.com More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
Copyright © 2014, Eklektix, Inc.
Comments and public postings are copyrighted by their creators.
Linux is a registered trademark of Linus Torvalds