blob: 9a6db4c8cd2625cc9e4af627bb403eb3f049dd38 [file] [log] [blame]
Ashutosh Joshi6104b272016-10-27 11:06:23 -07001/*
2 * Copyright (C) 2016 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
17package android.hardware.contexthub@1.0;
18
19interface IContexthubCallback {
20 /*
21 * This callback is passed by the Contexthub service to the HAL
22 * implementation to allow the HAL to send asynchronous messages back
23 * to the service and registered clients of the ContextHub service.
24 *
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080025 * @params msg : message
Ashutosh Joshi6104b272016-10-27 11:06:23 -070026 *
27 */
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080028 handleClientMsg(ContextHubMsg msg);
Ashutosh Joshi6104b272016-10-27 11:06:23 -070029
30 /*
31 * This callback is passed by the Contexthub service to the HAL
32 * implementation to allow the HAL to send the response for a
33 * transaction.
34 *
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080035 * @params txnId : transaction id whose result is being sent
Ashutosh Joshi6104b272016-10-27 11:06:23 -070036 * passed in by the service at start of transacation.
37 * result: result of transaction.
38 *
39 */
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080040 handleTxnResult(uint32_t txnId, TransactionResult result);
Ashutosh Joshi6104b272016-10-27 11:06:23 -070041
42 /*
43 * This callback is passed by the Contexthub service to the HAL
44 * implementation to allow the HAL to send an asynchronous event
45 * to the ContextHub service.
46 *
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080047 * @params msg : message
Ashutosh Joshi6104b272016-10-27 11:06:23 -070048 *
49 */
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080050 handleHubEvent(AsyncEventType evt);
Ashutosh Joshi6104b272016-10-27 11:06:23 -070051
Ashutosh Joshi8b268252017-01-10 13:55:20 -080052 /*
53 * This callback is passed by the Contexthub service to the HAL
54 * implementation to allow the HAL to send a notification to the service
55 * that a nanp-app has aborted.
56 * This method must be called when a nanoapp invokes chreAbort(...)).
57 *
58 * @params appId : app identifier
59 * : abortCode code passed by the nanoApp.
60 *
61 * Also see chreAbort(...)
62 *
63 */
64 handleAppAbort(uint64_t appId, uint32_t abortCode);
65
Ashutosh Joshi6104b272016-10-27 11:06:23 -070066 /*
67 * This callback is passed by the Contexthub service to the HAL
68 * implementation to allow the HAL to send information about the
69 * currently loaded and active nanoapps on the hub.
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080070 *
71 * @params appInfo : vector of HubAppinfo structure for each nanoApp
72 * on the hub that can be enabled, disabled and
73 * unloaded by the service. Any nanoApps that cannot
74 * be controlled by the service must not be reported.
75 * All nanoApps that can be controlled by the service
76 * must be reported.
Ashutosh Joshi6104b272016-10-27 11:06:23 -070077 */
Ashutosh Joshi69e3aa32016-11-22 14:08:20 -080078 handleAppsInfo(vec<HubAppInfo> appInfo);
Ashutosh Joshi6104b272016-10-27 11:06:23 -070079};