• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #pragma once
18 
19 #include <system/audio.h>
20 #include <system/audio_policy.h>
21 #include <utils/Errors.h>
22 #include <utils/RWLock.h>
23 #include <list>
24 #include <map>
25 #include <string>
26 #include <vector>
27 
28 class CParameterMgrPlatformConnector;
29 class ISelectionCriterionInterface;
30 class ISelectionCriterionTypeInterface;
31 struct cnode;
32 
33 class ParameterMgrPlatformConnectorLogger;
34 
35 namespace android
36 {
37 namespace audio_policy
38 {
39 
40 class ParameterManagerWrapper
41 {
42 private:
43     typedef std::pair<int, const char *> CriterionTypeValuePair;
44 
45     typedef std::map<std::string, ISelectionCriterionInterface *> CriterionCollection;
46     typedef std::map<std::string, ISelectionCriterionTypeInterface *> CriterionTypeCollection;
47     typedef CriterionCollection::iterator CriterionMapIterator;
48     typedef CriterionCollection::const_iterator CriterionMapConstIterator;
49     typedef CriterionTypeCollection::iterator CriterionTypeMapIterator;
50     typedef CriterionTypeCollection::const_iterator CriteriaTypeMapConstIterator;
51 
52 public:
53     ParameterManagerWrapper();
54     ~ParameterManagerWrapper();
55 
56     /**
57      * Starts the platform state service.
58      * It starts the parameter framework policy instance.
59      *
60      * @return NO_ERROR if success, error code otherwise.
61      */
62     status_t start();
63 
64     /**
65      * The following API wrap policy action to criteria
66      */
67 
68     /**
69      * Checks if the platform state was correctly started (ie the policy parameter manager
70      * has been instantiated and started correctly).
71      *
72      * @todo: map on initCheck?
73      *
74      * @return true if platform state is started correctly, false otherwise.
75      */
76     bool isStarted();
77 
78     /**
79      * Set Telephony Mode.
80      * It will set the telephony mode criterion accordingly and apply the configuration in order
81      * to select the right configuration on domains depending on this mode criterion.
82      *
83      * @param[in] mode: Android Phone state (normal, ringtone, csv, in communication)
84      *
85      * @return NO_ERROR if criterion set correctly, error code otherwise.
86      */
87     status_t setPhoneState(audio_mode_t mode);
88 
89     audio_mode_t getPhoneState() const;
90 
91     /**
92      * Set Force Use config for a given usage.
93      * It will set the corresponding policy parameter framework criterion.
94      *
95      * @param[in] usage for which a configuration shall be forced.
96      * @param[in] config wished to be forced for the given shall.
97      *
98      * @return NO_ERROR if the criterion was set correctly, error code otherwise (e.g. config not
99      * allowed a given usage...)
100      */
101     status_t setForceUse(audio_policy_force_use_t usage, audio_policy_forced_cfg_t config);
102 
103     audio_policy_forced_cfg_t getForceUse(audio_policy_force_use_t usage) const;
104 
105     /**
106      * Set the available input devices i.e. set the associated policy parameter framework criterion
107      *
108      * @param[in] inputDevices mask of available input devices.
109      *
110      * @return NO_ERROR if devices criterion updated correctly, error code otherwise.
111      */
112     status_t setAvailableInputDevices(audio_devices_t inputDevices);
113 
114     /**
115      * Set the available output devices i.e. set the associated policy parameter framework criterion
116      *
117      * @param[in] outputDevices mask of available output devices.
118      *
119      * @return NO_ERROR if devices criterion updated correctly, error code otherwise.
120      */
121     status_t setAvailableOutputDevices(audio_devices_t outputDevices);
122 
123 private:
124     /**
125      * Apply the configuration of the platform on the policy parameter manager.
126      * Once all the criteria have been set, the client of the platform state must call
127      * this function in order to have the route PFW taking into account these criteria.
128      *
129      * OPENS: shall we expose this?
130      *      - Yes if atomic set operation.
131      *          In this case, abstract it behind the "STAGE AND COMMIT" pattern
132      *      - no if need to set more than one before triggering an apply configuration.
133      */
134     void applyPlatformConfiguration();
135 
136     /**
137      * Load the criterion configuration file.
138      *
139      * @param[in] path Criterion conf file path.
140      *
141      * @return NO_ERROR is parsing successful, error code otherwise.
142      */
143     status_t loadAudioPolicyCriteriaConfig(const char *path);
144 
145     /**
146      * Add a criterion type to AudioPolicyPfw.
147      *
148      * @param[in] typeName of the PFW criterion type.
149      * @param[in] isInclusive attribute of the criterion type.
150      */
151     void addCriterionType(const std::string &typeName, bool isInclusive);
152 
153     /**
154      * Add a criterion type value pair to AudioPolicyPfw.
155      *
156      * @param[in] typeName criterion type name to which this value pair is added to.
157      * @param[in] numeric part of the value pair.
158      * @param[in] literal part of the value pair.
159      */
160     void addCriterionTypeValuePair(const std::string &typeName, uint32_t numeric,
161                                    const std::string &literal);
162 
163     /**
164      * Add a criterion to AudioPolicyPfw.
165      *
166      * @param[in] name of the PFW criterion.
167      * @param[in] typeName criterion type name to which this criterion is associated to.
168      * @param[in] defaultLiteralValue of the PFW criterion.
169      */
170     void addCriterion(const std::string &name,
171                       const std::string &typeName,
172                       const std::string &defaultLiteralValue);
173     /**
174      * Parse and load the inclusive criterion type from configuration file.
175      *
176      * @param[in] root node of the configuration file.
177      */
178     void loadInclusiveCriterionType(cnode *root);
179 
180     /**
181      * Parse and load the exclusive criterion type from configuration file.
182      *
183      * @param[in] root node of the configuration file.
184      */
185     void loadExclusiveCriterionType(cnode *root);
186 
187     /**
188      * Parse and load the criteria from configuration file.
189      *
190      * @param[in] root node of the configuration file.
191      */
192     void loadCriteria(cnode *root);
193 
194     /**
195      * Parse and load a criterion from configuration file.
196      *
197      * @param[in] root node of the configuration file.
198      */
199     void loadCriterion(cnode *root);
200 
201     /**
202      * Parse and load the criterion types from configuration file.
203      *
204      * @param[in] root node of the configuration file
205      * @param[in] isInclusive true if inclusive, false is exclusive.
206      */
207     void loadCriterionType(cnode *root, bool isInclusive);
208 
209     /**
210      * Load the configuration file.
211      *
212      * @param[in] root node of the configuration file.
213      */
214     void loadConfig(cnode *root);
215 
216     /**
217      * Parse and load the chidren node from a given root node.
218      *
219      * @param[in] root node of the configuration file
220      * @param[out] defaultValue of the parameter manager element to retrieve.
221      * @param[out] type of the parameter manager element to retrieve.
222     */
223     void parseChildren(cnode *root, std::string &defaultValue, std::string &type);
224 
225     /**
226      * Retrieve an element from a map by its name.
227      *
228      * @tparam T type of element to search.
229      * @param[in] name name of the element to find.
230      * @param[in] elementsMap maps of elements to search into.
231      *
232      * @return valid pointer on element if found, NULL otherwise.
233      */
234     template <typename T>
235     T *getElement(const std::string &name, std::map<std::string, T *> &elementsMap);
236 
237     /**
238      * Retrieve an element from a map by its name. Const version.
239      *
240      * @tparam T type of element to search.
241      * @param[in] name name of the element to find.
242      * @param[in] elementsMap maps of elements to search into.
243      *
244      * @return valid pointer on element if found, NULL otherwise.
245      */
246     template <typename T>
247     const T *getElement(const std::string &name,
248                         const std::map<std::string, T *> &elementsMap) const;
249 
250     /**
251      * set the value of a component state.
252      *
253      * @param[in] value new value to set to the component state.
254      * @param[in] stateName of the component state.
255      */
256     void setValue(int value, const std::string &stateName);
257 
258     /**
259      * get the value of a component state.
260      *
261      * @param[in] name of the component state.
262      *
263      * @return value of the component state
264      */
265     int getValue(const std::string &stateName) const;
266 
267     bool isValueValidForCriterion(ISelectionCriterionInterface *criterion, int valueToCheck);
268 
269     CriterionTypeCollection mPolicyCriterionTypes; /**< Policy Criterion Type map. */
270     CriterionCollection mPolicyCriteria; /**< Policy Criterion Map. */
271 
272     CParameterMgrPlatformConnector *mPfwConnector; /**< Policy Parameter Manager connector. */
273     ParameterMgrPlatformConnectorLogger *mPfwConnectorLogger; /**< Policy PFW logger. */
274 
275 
276     /**
277      * provide a compile time error if no specialization is provided for a given type.
278      *
279      * @tparam T: type of the parameter manager element. Supported one are:
280      *                      - Criterion
281      *                      - CriterionType.
282      */
283     template <typename T>
284     struct parameterManagerElementSupported;
285 
286     static const char *const mPolicyPfwDefaultConfFileName; /**< Default Policy PFW top file name.*/
287 };
288 
289 } // namespace audio_policy
290 } // namespace android
291