blob: 8eb0570b2428501e734724fd542232d3ae50c2d5 [file] [log] [blame]
/*
* Copyright (c) 2017, The Linux Foundation. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of The Linux Foundation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
* IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#define LOG_TAG "IPAHALService/IpaEventRelay"
/* External Includes */
#include <cutils/log.h>
//#include <hidl/Status.h> //TODO: Might be easier to return Status
/* HIDL Includes */
#include <android/hardware/tetheroffload/control/1.1/ITetheringOffloadCallback.h>
/* Internal Includes */
#include "IpaEventRelay.h"
/* Namespace pollution avoidance */
using ::android::hardware::Return;
// using ::android::hardware::Status;
using ::android::hardware::tetheroffload::control::V1_1::ITetheringOffloadCallback;
IpaEventRelay::IpaEventRelay(
const ::android::sp<V1_0::ITetheringOffloadCallback>& cb,
const ::android::sp<V1_1::ITetheringOffloadCallback>& cb_1_1) : mFramework(cb), mFramework_1_1(cb_1_1) {
} /* IpaEventRelay */
using OnEventVersion = std::function<Return<void>()>;
void IpaEventRelay::sendEvent(OffloadCallbackEvent event) {
// Events need to be sent for the version passed in and all versions defined after that.
// This ensures all new versions get the correct events, but vrsion where events where not
// defined do not.
Return<void> ret;
if(mFramework_1_1 != nullptr) {
ALOGI("Triggering onEvent_1_1");
ret = mFramework_1_1->onEvent_1_1(event);
}
else { // Fallback to V1_0
ALOGI("Triggering onEvent");
ret = mFramework->onEvent(
(::android::hardware::tetheroffload::control::V1_0::OffloadCallbackEvent) event);
}
if (!ret.isOk()) {
ALOGE("Triggering onEvent Callback failed.");
}
}
void IpaEventRelay::onOffloadStarted() {
ALOGI("onOffloadStarted()");
sendEvent(OffloadCallbackEvent::OFFLOAD_STARTED);
} /* onOffloadStarted */
void IpaEventRelay::onOffloadStopped(StoppedReason reason) {
ALOGI("onOffloadStopped(%d)", reason);
if( reason == StoppedReason::REQUESTED ) {
/*
* No way to communicate this to Framework right now, they make an
* assumption that offload is stopped when they remove the
* configuration.
*/
}
else if ( reason == StoppedReason::ERROR ) {
sendEvent(OffloadCallbackEvent::OFFLOAD_STOPPED_ERROR);
}
else if ( reason == StoppedReason::UNSUPPORTED ) {
sendEvent(OffloadCallbackEvent::OFFLOAD_STOPPED_UNSUPPORTED);
}
else {
ALOGE("Unknown stopped reason(%d)", reason);
}
} /* onOffloadStopped */
void IpaEventRelay::onOffloadSupportAvailable() {
ALOGI("onOffloadSupportAvailable()");
sendEvent(OffloadCallbackEvent::OFFLOAD_SUPPORT_AVAILABLE);
} /* onOffloadSupportAvailable */
void IpaEventRelay::onLimitReached() {
ALOGI("onLimitReached()");
sendEvent(OffloadCallbackEvent::OFFLOAD_STOPPED_LIMIT_REACHED);
} /* onLimitReached */
/** V1_1 API's **/
void IpaEventRelay::onWarningReached() {
ALOGI("onWarningReached()");
sendEvent(OffloadCallbackEvent::OFFLOAD_WARNING_REACHED);
} /* onWarningReached */