Added policy tree elements
[keystone-rtos/rm-lld.git] / include / rm_treeloc.h
1 /*
2  *  file  rm_treeloc.h
3  *
4  *  Prototypes and data structures for the various RM Trees.
5  *
6  *  ============================================================================
7  *      (C) Copyright 2012-2015, Texas Instruments, Inc.
8  * 
9  *  Redistribution and use in source and binary forms, with or without 
10  *  modification, are permitted provided that the following conditions 
11  *  are met:
12  *
13  *    Redistributions of source code must retain the above copyright 
14  *    notice, this list of conditions and the following disclaimer.
15  *
16  *    Redistributions in binary form must reproduce the above copyright
17  *    notice, this list of conditions and the following disclaimer in the 
18  *    documentation and/or other materials provided with the   
19  *    distribution.
20  *
21  *    Neither the name of Texas Instruments Incorporated nor the names of
22  *    its contributors may be used to endorse or promote products derived
23  *    from this software without specific prior written permission.
24  *
25  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
26  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
27  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
28  *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 
29  *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 
30  *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 
31  *  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
32  *  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
33  *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 
34  *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
35  *  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36  *
37  *  \par
38 */
40 #ifndef RM_TREELOC_H_
41 #define RM_TREELOC_H_
43 #ifdef __cplusplus
44 extern "C" {
45 #endif
47 /* Standard includes */
48 #include <stdint.h>
50 /* RM external includes */
51 #include <ti/drv/rm/rm.h>
53 /* Tree algorithm includes */
54 #include <ti/drv/rm/util/tree.h>
56 /**********************************************************************
57  *************** Tree Node Data Structure Definitions *****************
58  **********************************************************************/
60 /* NameServer node configuration structure */
61 typedef struct {
62     /* Name to assign to the resource values */
63     char     *objName;
64     /* Resource name assigned to the NameServer name */
65     char     *resourceName;
66     /* Resource base value assigned to the NameServer name */
67     uint32_t  resourceBase;
68     /* Resource length value (starting from base) assigned to the NameServer
69      * name */
70     uint32_t  resourceLength;
71 } Rm_NameServerNodeCfg;
73 /* NameServer node */
74 typedef struct _Rm_NameServerNode {
75     /* Tree algorithm data structure */
76     RB_ENTRY(_Rm_NameServerNode) linkage;
77     /* Name string */
78     char                         objName[RM_NAME_MAX_CHARS];
79     /* Resource name */
80     char                         resourceName[RM_NAME_MAX_CHARS];
81     /* Resource base value */
82     uint32_t                     resourceBase;
83     /* Resource length value */
84     uint32_t                     resourceLength;
85 } Rm_NameServerNode;
87 /* NameServer tree root entry type definition */
88 typedef RB_HEAD(_Rm_NameServerTree, _Rm_NameServerNode) Rm_NameServerTree;
90 /* Valid instance node */
91 typedef struct _Rm_PolicyValidInstNode {
92     /* Tree algorithm data structure */
93     RB_ENTRY(_Rm_PolicyValidInstNode) linkage;
94     /* Valid instance name string */
95     char                              name[RM_NAME_MAX_CHARS];
96     /* Number of existing resource allocations the instance is
97      * reference in.  Resource frees involving the instance
98      * will decrement this count.  A valid instance node cannot
99      * be deleted until this value is zero */
100     uint32_t                          allocRefCount;
101     /* TRUE: Delete this valid instance node once the allocRefCount
102      *       reaches zero
103      * FALSE: Do not delete */
104     int32_t                           deletePending;
105     /* Instance index used in policy permission assignments */
106     int32_t                           instIdx;
107 } Rm_PolicyValidInstNode;
109 /* Valid instance tree root entry type definition */
110 typedef RB_HEAD(_Rm_PolicyValidInstTree,
111                 _Rm_PolicyValidInstNode) Rm_PolicyValidInstTree;
113 /* Resource node owner linked list node */
114 typedef struct Rm_Owner_s {
115     /* Pointer to the valid instance node that currently
116      * owns or partially owns the resource */
117     Rm_PolicyValidInstNode *instNameNode;
118     /* Number of times this owner has allocated the resource it is
119      * linked to. */
120     uint16_t                refCnt;
121     /* Link to the next owner of the resoruce if the resource is shared */
122     struct Rm_Owner_s      *nextOwner;
123 } Rm_Owner;
125 /* Resource node */
126 typedef struct _Rm_ResourceNode {
127     /* Tree algorithm data structure */
128     RB_ENTRY(_Rm_ResourceNode) linkage;
129     /* Resource base value */
130     uint32_t                   base;
131     /* Resource length value.  With base this node covers a resource's values
132      * from base to base+length-1 */
133     uint32_t                   length;
134     /* Number of times this resource node has been allocated to a valid
135      * instance.  This value will decrement for each free operation */
136     uint16_t                   allocationCount;
137     /* Linked list of existing owners.  Will be NULL if no owners exist
138      * for the resource node */
139     Rm_Owner                   *ownerList;
140 } Rm_ResourceNode;
142 /* Resource tree root entry type definition */
143 typedef RB_HEAD(_Rm_AllocatorResourceTree, _Rm_ResourceNode) Rm_ResourceTree;
145 /* Policy node */
146 typedef struct _Rm_PolicyNode {
147     /* Tree algorithm data structure */
148     RB_ENTRY(_Rm_PolicyNode)  linkage;
149     /* Policy base value */
150     uint32_t                  base;
151     /* Policy length value.  With base this node covers a policy's values
152      * from base to base+length-1 */
153     uint32_t                  len;
154     /* Pointer to array containing permission bitfields for the node's 
155      * resource range */
156     uint32_t                 *perms;
157     /* Size of permissions array in bytes pointed to by the perms pointer */
158     uint32_t                  permsLen;
159 } Rm_PolicyNode;
161 /* Policy tree root entry type definition */
162 typedef RB_HEAD(_Rm_AllocatorPolicyTree, _Rm_PolicyNode) Rm_PolicyTree;
164 /* Allocator node */
165 typedef struct _Rm_AllocatorNode {
166     /* Tree algorithm data structure */
167     RB_ENTRY(_Rm_AllocatorNode)  linkage;
168     /* Resource name for which the allocator was created.  The resource name
169      * must match a resource node defined in both the GRL and the Policy */
170     char                         resourceName[RM_NAME_MAX_CHARS];
171     /* Pointer to root entry of allocator's resource tree */
172     Rm_ResourceTree             *resourceRoot;
173     /* Pointer to root entry of allocator's policy tree */
174     Rm_PolicyTree               *policyRoot;
175 } Rm_AllocatorNode;
177 /* Allocator tree root entry type definition */
178 typedef RB_HEAD(_Rm_AllocatorTree, _Rm_AllocatorNode) Rm_AllocatorTree;
180 /**********************************************************************
181  ****************** Tree Node Function Definitions ********************
182  **********************************************************************/
184 void rmNameServerTreeInv(Rm_NameServerTree *treeRoot);
185 void rmNameServerTreeWb(Rm_NameServerTree *treeRoot);
186 Rm_NameServerNode *rmNameServerNodeNew(Rm_NameServerNodeCfg *nodeCfg);
187 void rmNameServerNodeFree(Rm_NameServerNode *node);
188 int rmNameServerNodeCompare(Rm_NameServerNode *node1,
189                             Rm_NameServerNode *node2);
190 void rmNameServerNodeInv(Rm_NameServerNode *node);
192 void rmPolicyValidInstTreeInv(Rm_PolicyValidInstTree *treeRoot);
193 void rmPolicyValidInstTreeWb(Rm_PolicyValidInstTree *treeRoot);
194 Rm_PolicyValidInstNode *rmPolicyValidInstNodeNew(const char *instName,
195                                                  const int32_t instIdx);
196 void rmPolicyValidInstNodeFree(Rm_PolicyValidInstNode *node);
197 int rmPolicyValidInstNodeCompare(Rm_PolicyValidInstNode *node1,
198                                  Rm_PolicyValidInstNode *node2);
199 void rmPolicyValidInstNodeInv(Rm_PolicyValidInstNode *node);
201 void rmResourceTreeInv(Rm_ResourceTree *treeRoot);
202 void rmResourceTreeWb(Rm_ResourceTree *treeRoot);
203 Rm_ResourceNode *rmResourceNodeNew(uint32_t resourceBase,
204                                    uint32_t resourceLength);
205 void rmResourceNodeFree(Rm_ResourceNode *node);
206 int rmResourceNodeCompare(Rm_ResourceNode *node1, Rm_ResourceNode *node2);
207 void rmResourceNodeInv(Rm_ResourceNode *node);
209 void rmPolicyTreeInv(Rm_PolicyTree *treeRoot);
210 void rmPolicyTreeWb(Rm_PolicyTree *treeRoot);
211 Rm_PolicyNode *rmPolicyNodeNew(uint32_t resourceBase, uint32_t resourceLength);
212 void rmPolicyNodeFree(Rm_PolicyNode *node);
213 int rmPolicyNodeCompare(Rm_PolicyNode *node1, Rm_PolicyNode *node2);
214 void rmPolicyNodeInv(Rm_PolicyNode *node);
216 void rmAllocatorTreeInv(Rm_AllocatorTree *treeRoot);
217 void rmAllocatorTreeWb(Rm_AllocatorTree *treeRoot);
218 Rm_AllocatorNode *rmAllocatorNodeNew(const char *resourceName);
219 void rmAllocatorNodeFree(Rm_AllocatorNode *node);
220 int rmAllocatorNodeCompare(Rm_AllocatorNode *node1, Rm_AllocatorNode *node2);
221 void rmAllocatorNodeInv(Rm_AllocatorNode *node);
223 /**********************************************************************
224  ******************** Tree Prototype Generation ***********************
225  **********************************************************************/
226  
227 RB_PROTOTYPE(_Rm_NameServerTree, _Rm_NameServerNode, linkage,
228              rmNameServerNodeCompare, rmNameServerNodeInv)
229 RB_PROTOTYPE(_Rm_PolicyValidInstTree, _Rm_PolicyValidInstNode, linkage,
230              rmPolicyValidInstNodeCompare, rmPolicyValidInstNodeInv)
231 RB_PROTOTYPE(_Rm_AllocatorResourceTree, _Rm_ResourceNode, linkage,
232              rmResourceNodeCompare, rmResourceNodeInv)
233 RB_PROTOTYPE(_Rm_AllocatorPolicyTree, _Rm_PolicyNode, linkage,
234              rmPolicyNodeCompare, rmPolicyNodeInv)
235 RB_PROTOTYPE(_Rm_AllocatorTree, _Rm_AllocatorNode, linkage,
236              rmAllocatorNodeCompare, rmAllocatorNodeInv)
238 #ifdef __cplusplus
240 #endif
242 #endif /* RM_TREELOC_H_ */