mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-23 23:32:14 +00:00
ARM: OMAP2+: hwmod: add parent_hwmod support
Add parent_hwmod pointer to omap_hwmod. This can be set to point to a "parent" hwmod that needs to be enabled for the "child" hwmod to work. This is used at hwmod setup time: when doing the initial setup and reset, first enable the parent hwmod, and after setup and reset is done, restore the parent hwmod to postsetup_state. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com> Reviewed-by: Archit Taneja <archit.taneja@gmail.com> [paul@pwsan.com: add kerneldoc documentation for parent_hwmod; note that it is a temporary workaround] Signed-off-by: Paul Walmsley <paul@pwsan.com>
This commit is contained in:
parent
79005fbd3e
commit
f22d254551
2 changed files with 30 additions and 0 deletions
|
@ -633,6 +633,7 @@ struct omap_hwmod_link {
|
|||
* @flags: hwmod flags (documented below)
|
||||
* @_lock: spinlock serializing operations on this hwmod
|
||||
* @node: list node for hwmod list (internal use)
|
||||
* @parent_hwmod: (temporary) a pointer to the hierarchical parent of this hwmod
|
||||
*
|
||||
* @main_clk refers to this module's "main clock," which for our
|
||||
* purposes is defined as "the functional clock needed for register
|
||||
|
@ -643,6 +644,12 @@ struct omap_hwmod_link {
|
|||
* the omap_hwmod code and should not be set during initialization.
|
||||
*
|
||||
* @masters and @slaves are now deprecated.
|
||||
*
|
||||
* @parent_hwmod is temporary; there should be no need for it, as this
|
||||
* information should already be expressed in the OCP interface
|
||||
* structures. @parent_hwmod is present as a workaround until we improve
|
||||
* handling for hwmods with multiple parents (e.g., OMAP4+ DSS with
|
||||
* multiple register targets across different interconnects).
|
||||
*/
|
||||
struct omap_hwmod {
|
||||
const char *name;
|
||||
|
@ -680,6 +687,7 @@ struct omap_hwmod {
|
|||
u8 _int_flags;
|
||||
u8 _state;
|
||||
u8 _postsetup_state;
|
||||
struct omap_hwmod *parent_hwmod;
|
||||
};
|
||||
|
||||
struct omap_hwmod *omap_hwmod_lookup(const char *name);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue