1 /*
2  * dspbridge/mpu_api/inc/DSPManager.h
3  *
4  * DSP-BIOS Bridge driver support functions for TI OMAP processors.
5  *
6  * Copyright (C) 2007 Texas Instruments, Inc.
7  *
8  * This program is free software; you can redistribute it and/or modify it
9  * under the terms of the GNU Lesser General Public License as published
10  * by the Free Software Foundation version 2.1 of the License.
11  *
12  * This program is distributed .as is. WITHOUT ANY WARRANTY of any kind,
13  * whether express or implied; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  */
17 
18 
19 /*
20  *  ======== DSPManager.h ========
21  *  Description:
22  *      This is the header for the DSP/BIOS Bridge manager module.
23  *
24  *  Public Functions:
25  *      DspManager_Open
26  *      DspManager_Close
27  *      DSPManager_EnumNodeInfo
28  *      DSPManager_EnumProcessorInfo
29  *      DSPManager_WaitForEvents
30  *      DSPManager_RegisterObject
31  *      DSPManager_UnregisterObject
32  *
33  *! Revision History:
34  *! ================
35  *! 03-Dec-2003 map Replaced include of dbdcddefs.h with dbdefs.h
36  *! 22-Nov-2002 gp  Replaced include of dbdcd.h w/ dbdcddefs.h (hiding DCD APIs)
37  *!                 Formatting cleanup.
38  *! 15-Oct-2002 kc  Removed legacy PERF definitions.
39  *! 16-Aug-2002 map Added DSPManager_RegisterObject/UnregisterObject for
40  *!                     registering Dynamic Libraries
41  *! 13-Feb-2001 kc: DSP/BIOS Bridge name updates.
42  *! 22-Nov-2000 kc: Added DSPManager_PerfGetStat to acquire PERF stats.
43  *! 25-Sep-2000 rr: Updated to Version 0.9
44  *! 14-Aug-2000 rr: Cleaned up.
45  *! 20-Jul-2000 rr: Updated to Version 0.8.
46  *! 27-Jun-2000 rr: Created from dbapi.h
47  */
48 
49 #ifndef DSPMANAGER_
50 #define DSPMANAGER_
51 
52 #ifdef __cplusplus
53 extern "C" {
54 #endif
55 
56 #include <dbdefs.h>
57 
58 /*
59  *  ======== DspManager_Open ========
60  *  Purpose:
61  *      Open handle to the DSP/BIOS Bridge driver
62  *  Parameters:
63  *      argc:               Reserved, set to zero
64  *      argp:               Reserved, set to NULL
65  *                          in the database will be returned.
66  *  Returns:
67  *      DSP_SOK:            Success.
68  *      DSP_EFAIL:          Failed to open handle to the DSP/BIOS Bridge driver
69  *  Details:
70  */
71 	extern DBAPI DspManager_Open(UINT argc, PVOID argp);
72 
73 /*
74  *  ======== DspManager_Close ========
75  *  Purpose:
76  *      Close handle to the DSP/BIOS Bridge driver
77  *  Parameters:
78  *      argc:               Reserved, set to zero
79  *      argp:               Reserved, set to NULL
80  *                          in the database will be returned.
81  *  Returns:
82  *      DSP_SOK:            Success.
83  *      DSP_EFAIL:          Failed to close handle to the DSP/BIOS Bridge driver
84  *  Details:
85  */
86 	extern DBAPI DspManager_Close(UINT argc, PVOID argp);
87 
88 /*
89  *  ======== DSPManager_EnumNodeInfo ========
90  *  Purpose:
91  *      Enumerate and get configuration information about nodes configured
92  *      in the node database.
93  *  Parameters:
94  *      uNode:              The node index, counting up from 0.
95  *      pNDBProps:          Ptr to the DSP_NDBPROPS structure for output.
96  *      uNDBPropsSize:      Size of the DSP_NDBPROPS structure.
97  *      puNumNodes:         Location where the number of nodes configured
98  *                          in the database will be returned.
99  *  Returns:
100  *      DSP_SOK:            Success.
101  *      DSP_EINVALIDARG:    Parameter uNode is out of range
102  *      DSP_EPOINTER:       Parameter pNDBProps or puNumNodes is not valid
103  *      DSP_EFAIL:          Unable to get the node information.
104  *      DSP_ESIZE:          The size of the specified DSP_NDBPROPS structure
105  *                          is too small to hold all node information,
106  *                          (i.e., uNDBPropsSize is too small).
107  *      DSP_ECHANGEDURINGENUM:  During Enumeration there has been a change in
108  *                          the number of nodes configured or in the
109  *                          the properties of the enumerated nodes.
110  *  Details:
111  */
112 	extern DBAPI DSPManager_EnumNodeInfo(UINT uNode,
113 					     OUT struct DSP_NDBPROPS * pNDBProps,
114 					     UINT uNDBPropsSize,
115 					     OUT UINT * puNumNodes);
116 
117 /*
118  *  ======== DSPManager_EnumProcessorInfo ========
119  *  Purpose:
120  *      Enumerate and get configuration information about available DSP
121  *      processors.
122  *  Parameters:
123  *      uProcessor:         The processor index, counting up from 0.
124  *      pProcessorInfo:     Ptr to the DSP_PROCESSORINFO structure .
125  *      uProcessorInfoSize: Size of DSP_PROCESSORINFO structure.
126  *      puNumProcs:         Location where the number of DSPs configured
127  *                          in the database will be returned
128  *  Returns:
129  *      DSP_SOK:            Success.
130  *      DSP_EINVALIDARG:    Parameter uProcessor is out of range
131  *      DSP_EPOINTER:       Parameter pProcessorInfo or puNumProcs is not valid.
132  *      DSP_EFAIL:          Unable to get the processor information.
133  *      DSP_ESIZE:          The size of the specified DSP_PROCESSORINFO struct
134  *                          is too small to hold all the processor information,
135  *                          (i.e., uProcessorInfoSize is too small).
136  *  Details:
137  */
138 	extern DBAPI DSPManager_EnumProcessorInfo(UINT uProcessor,
139 						  OUT struct DSP_PROCESSORINFO *
140 						  pProcessorInfo,
141 						  UINT uProcessorInfoSize,
142 						  OUT UINT * puNumProcs);
143 
144 /*
145  *  ======== DSPManager_WaitForEvents ========
146  *  Purpose:
147  *      Block on any Bridge event(s)
148  *  Parameters:
149  *      aNotifications  : array of pointers to notification objects.
150  *      uCount          : number of elements in above array
151  *      puIndex         : index of signaled event object
152  *      uTimeout        : timeout interval in milliseocnds
153  *  Returns:
154  *      DSP_SOK         : Success.
155  *      DSP_ETIMEOUT    : Wait timed out. *puIndex is undetermined.
156  *  Details:
157  */
158 	extern DBAPI DSPManager_WaitForEvents(struct DSP_NOTIFICATION**
159 					      aNotifications, UINT uCount,
160 					      OUT UINT * puIndex,
161 					      UINT uTimeout);
162 
163 /*
164  *  ======== DSPManager_RegisterObject ========
165  *  Purpose:
166  *     Register object with DSP/BIOS Bridge Configuration database (DCD).
167  *  Parameters:
168  *     pUuid:          Pointer to UUID structure.
169  *     objType:        Library Type
170  *     pszPathName:    Path to library
171  *  Returns:
172  *     DSP_SOK:        Success.
173  *     DSP_EFAIL:      Unable to register object with the DCD.
174  *  Details:
175  */
176 	extern DBAPI DSPManager_RegisterObject(struct DSP_UUID * pUuid,
177 					       DSP_DCDOBJTYPE objType,
178 					       CHAR * pszPathName);
179 
180 /*
181  *  ======== DSPManager_UnregisterObject ========
182  *  Purpose:
183  *     Unregister object with DSP/BIOS Bridge Configuration Database (DCD).
184  *  Parameters:
185  *     pUuid:          Pointer to UUID structure.
186  *     objType:        Library Type
187  *  Returns:
188  *     DSP_SOK:        Success.
189  *     DSP_EFAIL:      Unable to unregister object from the DCD.
190  *  Details:
191  */
192 	extern DBAPI DSPManager_UnregisterObject(struct DSP_UUID * pUuid,
193 						 DSP_DCDOBJTYPE objType);
194 
195 #ifndef RES_CLEANUP_DISABLE
196 /*
197  *  ======== DSPManager_GetProcResourceInfo========
198  *  Purpose:
199  *     Get GPP process resource information.
200  *  Parameters:
201  *     pBuf:           Pointer to information buffer.
202  *  Returns:
203  *     DSP_SOK:        Success.
204  *     DSP_EFAIL:      Unable to unregister object from the DCD.
205  *  Details:
206  */
207 	extern DBAPI DSPManager_GetProcResourceInfo(UINT *pBuf, UINT *pSize);
208 #endif
209 
210 
211 #ifdef __cplusplus
212 }
213 #endif
214 #endif				/* DSPManager_ */
215