/*
* Copyright (C) 2015 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 ACTIVITY_H_
#define ACTIVITY_H_
#include <hardware/activity_recognition.h>
#include <media/stagefright/foundation/ABase.h>
#include <utils/KeyedVector.h>
#include <utils/Vector.h>
#include "activityeventhandler.h"
#include "hubconnection.h"
namespace android {
class ActivityContext : public ActivityEventHandler {
public:
activity_recognition_device_t device;
explicit ActivityContext(const struct hw_module_t *module);
~ActivityContext();
bool getHubAlive();
void registerActivityCallback(
const activity_recognition_callback_procs_t *callback);
int enableActivityEvent(uint32_t activity_handle,
uint32_t event_type, int64_t max_report_latency_ns);
int disableActivityEvent(uint32_t activity_handle, uint32_t event_type);
int flush();
// ActivityEventHandler interface.
virtual void OnActivityEvent(int sensorIndex, uint8_t eventIndex,
uint64_t whenNs) override;
virtual void OnFlush() override;
virtual void OnSensorHubReset() override;
private:
android::sp<android::HubConnection> mHubConnection;
android::Mutex mCallbackLock;
const activity_recognition_callback_procs_t *mCallback;
struct ActivityEvent {
uint8_t eventIndex;
int sensorIndex;
uint64_t whenNs;
};
// Whether or not the newest published event index is known. When the AR HAL
// is initially started this is set to false to allow any event index from
// the sensor hub. It is also set to false when a hub reset occurs.
bool mNewestPublishedEventIndexIsKnown;
// The index of the newest published event. The next event from the sensor
// hub must follow this event or else it will be pushed into a list of
// events to be published once the gap in events has been received.
uint8_t mNewestPublishedEventIndex;
// The timestamp of the most recently published event. If the absolute value
// of the delta of the next timestamp to the current timestamp is below some
// threshold, this timestamp will be reused. This is used to ensure that
// activity transitions share the same timestamp and works around agressive
// AP->ContextHub time synchronization mechansims.
uint64_t mNewestPublishedTimestamp;
// The list of unpublished events. These are published once the next
// event arrives and is greater than mNewestPublishedEventIndex by 1
// (wrapping across 255).
Vector<ActivityEvent> mUnpublishedEvents;
// Track the number of flush events sent to the sensor hub.
int mOutstandingFlushEvents;
// Publishes remaining unpublished events.
void PublishUnpublishedEvents();
// Publishes an AR event to the AR HAL client.
void PublishEvent(const ActivityEvent& event);
// Searches for very old AR events, discards them and publishes EVENT_EXIT
// transitions for all activities.
void DiscardExpiredUnpublishedEvents(uint64_t whenNs);
DISALLOW_EVIL_CONSTRUCTORS(ActivityContext);
};
} // namespace android
#endif // ACTIVITY_H_