• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * scr.h
3  *
4  * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  *
11  *  * Redistributions of source code must retain the above copyright
12  *    notice, this list of conditions and the following disclaimer.
13  *  * Redistributions in binary form must reproduce the above copyright
14  *    notice, this list of conditions and the following disclaimer in
15  *    the documentation and/or other materials provided with the
16  *    distribution.
17  *  * Neither the name Texas Instruments nor the names of its
18  *    contributors may be used to endorse or promote products derived
19  *    from this software without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
22  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
23  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
24  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
25  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
26  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
27  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
28  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
29  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
30  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
31  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32  */
33 
34 /** \file  scr.h
35  *  \brief This file includes internal (private) definitions to the SCR module
36  *
37  *  \see   scrApi.h, scr.c
38  */
39 
40 
41 #ifndef __SCR_H__
42 #define __SCR_H__
43 
44 #include "scrApi.h"
45 
46 /*
47  ***********************************************************************
48  *  Constant definitions.
49  ***********************************************************************
50  */
51 
52  /*
53  ***********************************************************************
54  *  Enums.
55  ***********************************************************************
56  */
57 
58 /** \enum EScrClientState
59  * \brief enumerates the different states a client may be in .\n
60  */
61 typedef enum
62 {
63     SCR_CS_IDLE = 0,    /**< client is idle */
64     SCR_CS_PENDING,     /**< client is pending to use the channel */
65     SCR_CS_RUNNING,     /**< client is using the channel */
66     SCR_CS_ABORTING     /**<
67                          * client was using the channel, but was aborted,
68                          * and complete notification is expected.
69                          */
70 } EScrClientState;
71 
72 
73 /*
74  ***********************************************************************
75  *  Typedefs.
76  ***********************************************************************
77  */
78 
79 /*
80  ***********************************************************************
81  *  Structure definitions.
82  ***********************************************************************
83  */
84 
85 /** \struct TScrClient
86  * \brief This structure contains information for a specific client
87  */
88 typedef struct
89 {
90     EScrClientState     state[ SCR_RESOURCE_NUM_OF_RESOURCES ];     /**< the client current state, per resource */
91     TScrCB              clientRequestCB;                            /**< the client's callback function */
92     TI_HANDLE           ClientRequestCBObj;                         /**< the client's object */
93     EScePendReason      currentPendingReason[ SCR_RESOURCE_NUM_OF_RESOURCES ];
94                                                                     /**<
95                                                                      * the reason why this client is pending
96                                                                      * (if at all)
97                                                                      */
98 } TScrClient;
99 
100 /** \struct TScr
101  * \brief This structure contains the SCR object data
102  */
103 typedef struct
104 {
105     TI_HANDLE               hOS;                                    /**< a handle to the OS object */
106     TI_HANDLE               hReport;                                /**< a handle to the report object */
107     TI_BOOL                 statusNotficationPending;               /**<
108                                                                      * whether the SCR is in the process of
109                                                                      * notifying a status change to a client
110                                                                      * (used to solve re-entrance problem)
111                                                                      */
112     EScrClientId            runningClient[ SCR_RESOURCE_NUM_OF_RESOURCES ];
113                                                                     /**<
114                                                                      * The index of the current running client
115                                                                      * (SCR_CID_NO_CLIENT if none), per resource
116                                                                      */
117     EScrGroupId             currentGroup;                           /**< the current group */
118     EScrModeId              currentMode;                            /**< the current mode */
119     TScrClient              clientArray[ SCR_CID_NUM_OF_CLIENTS ];  /**< array holding all clients' info */
120 } TScr;
121 
122 
123 /*
124  ***********************************************************************
125  *  External functions definitions
126  ***********************************************************************
127  */
128 /**
129  * \\n
130  * \date 01-Dec-2004\n
131  * \brief Searches the client database for a client with matching state, from startFrom to endAt\n
132  *
133  * Function Scope \e Private.\n
134  * \param hScr - handle to the SCR object.\n
135  * \param requiredState - the state to match.\n
136  * \param eResource - the resource to macth.\n
137  * \param startFrom - the highest priority to begin searching from.\n
138  * \param endAt - the lowest priority to include in the search.\n
139  * \return the client ID if found, SCR_CID_NO_CLIENT if not found.\n
140  */
141 EScrClientId scrFindHighest( TI_HANDLE hScr,
142                              EScrClientState requiredState,
143                              EScrResourceId eResource,
144                              TI_UINT32 startFrom,
145                              TI_UINT32 endAt );
146 
147 #endif /* __SCR_H__ */
148