/*
* Copyright (C) 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _CHRE_NANOAPP_H_
#define _CHRE_NANOAPP_H_
/**
* Methods in the Context Hub Runtime Environment which must be implemented
* by the nanoapp.
*/
#include <stdbool.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* Method invoked by the CHRE when loading the nanoapp.
*
* Every CHRE method is legal to call from this method.
*
* @returns 'true' if the nanoapp successfully started. 'false' if the nanoapp
* failed to properly initialize itself (for example, could not obtain
* sufficient memory from the heap). If this method returns 'false', the
* nanoapp will be unloaded by the CHRE (and nanoappEnd will
* _not_ be invoked in that case).
* @see nanoappEnd
*/
bool nanoappStart(void);
/**
* Method invoked by the CHRE when there is an event for this nanoapp.
*
* Every CHRE method is legal to call from this method.
*
* @param senderInstanceId The Instance ID for the source of this event.
* Note that this may be CHRE_INSTANCE_ID, indicating that the event
* was generated by the CHRE.
* @param eventType The event type. This might be one of the CHRE_EVENT_*
* types defined in this API. But it might also be a user-defined event.
* @param eventData The associated data, if any, for this specific type of
* event. From the nanoapp's perspective, this eventData's lifetime ends
* when this method returns, and thus any data the nanoapp wishes to
* retain must be copied. Note that interpretation of event data is
* given by the event type, and for some events may not be a valid
* pointer. See documentation of the specific CHRE_EVENT_* types for how to
* interpret this data for those. Note that for user events, you will
* need to establish what this data means.
*/
void nanoappHandleEvent(uint32_t senderInstanceId, uint16_t eventType,
const void* eventData);
/**
* Method invoked by the CHRE when unloading the nanoapp.
*
* It is not valid to attempt to send events or messages, or to invoke functions
* which will generate events to this app, within the nanoapp implementation of
* this function. That means it is illegal for the nanoapp invoke any of the
* following:
* - chreSendEvent()
* - chreSendMessageToHost()
* - chreSensorConfigure()
* - chreSensorConfigureModeOnly()
* - chreTimerSet()
*
* @see nanoappStart
*/
void nanoappEnd(void);
#ifdef __cplusplus
}
#endif
#endif /* _CHRE_NANOAPP_H_ */