blob: 1c02d159baa57e395d44820394d7043b66ffd1b1 [file] [log] [blame]
/*
* 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.
*/
#include <stdlib.h>
#include <string.h>
#include <seos.h>
#include <timer.h>
#include <syscallDo.h>
static uint32_t mMyTid;
static int cnt;
struct ExtMsg
{
struct HostHubRawPacket hdr;
uint8_t msg;
uint32_t val;
} __attribute__((packed));
static bool start_task(uint32_t myTid)
{
mMyTid = myTid;
cnt = 100;
return eOsEventSubscribe(myTid, EVT_APP_START);
}
static void end_task(void)
{
eOsLog(LOG_DEBUG, "App 0 terminating");
}
static void handle_event(uint32_t evtType, const void* evtData)
{
const struct TimerEvent *te;
const struct AppEventFreeData *aefd;
uint32_t timerId;
struct ExtMsg *extMsg;
if (evtType == EVT_APP_START) {
timerId = eOsTimTimerSet(1000000000ULL, 50, 50, mMyTid, (void *)&cnt, false);
eOsLog(LOG_INFO, "App 0 started with tid %u timerid %u\n", mMyTid, timerId);
} else if (evtType == EVT_APP_TIMER) {
te = evtData;
eOsLog(LOG_INFO, "App 0 received timer %u callback: %d (TIM: %lld, RTC: %lld, SENSOR: %lld, HOST: %lld)\n", te->timerId, *(int *)te->data, eOsTimGetTime(), eOsRtcGetTime(), eOsSensorGetTime(), eOsHostGetTime());
extMsg = eOsHeapAlloc(sizeof(*extMsg));
extMsg->hdr.appId = APP_ID_MAKE(NANOHUB_VENDOR_GOOGLE, 0x548000);
extMsg->hdr.dataLen = 5;
extMsg->msg = 0x01;
extMsg->val = *(int *)te->data;
if (!(eOsEnqueueEvt(EVT_APP_TO_HOST, extMsg, mMyTid)))
eOsHeapFree(extMsg);
if (cnt-- <= 0)
eOsTimTimerCancel(te->timerId);
} else if (evtType == EVT_APP_FREE_EVT_DATA) {
aefd = evtData;
if (aefd->evtType == EVT_APP_TO_HOST)
eOsHeapFree(aefd->evtData);
}
}
APP_INIT(0, start_task, end_task, handle_event);