1 /* Copyright (c) 2021 Google LLC
2 * SPDX-License-Identifier: Apache-2.0
3 */
4
5 #include <zephyr/kernel.h>
6 #include <zephyr/sys/printk.h>
7 #include <zephyr/logging/log_ctrl.h>
8
9 #include "apps.hpp"
10 #include "chre/core/event_loop_manager.h"
11 #include "chre/target_platform/init.h"
12
boolToString(bool cond)13 inline const char *boolToString(bool cond)
14 {
15 return cond ? "SUCCESS" : "FAIL";
16 }
17
main(void)18 int main(void)
19 {
20 auto echo_app = chre::initializeStaticNanoappEchoApp();
21 auto& eventLoop = chre::EventLoopManagerSingleton::get()->getEventLoop();
22 uint32_t instanceId;
23
24 if (chre::zephyr::init()) {
25 printk("Failed to initialize!\n");
26 return -1;
27 }
28
29 printk("Hello CHRE!\n");
30
31 k_msleep(500);
32 /*
33 * Flush all log messages that resulted from initialization to avoid
34 * getting them mingled with those printk messages below.
35 */
36 while (IS_ENABLED(CONFIG_LOG_PROCESS_THREAD) && log_data_pending()) {
37 k_msleep(100);
38 }
39 printk("Starting EchoApp... %s\n", boolToString(eventLoop.startNanoapp(echo_app)));
40 printk("Nanoapp count=%zu\n", eventLoop.getNanoappCount());
41 printk("Finding instance ID... %s\n", boolToString(eventLoop.findNanoappInstanceIdByAppId(1, &instanceId)));
42 printk("Nanoapp count=%zu\n", eventLoop.getNanoappCount());
43 printk("Instance ID: %u\n", instanceId);
44
45 printk("Sending event %zu...\n", eventLoop.getNanoappCount());
46 eventLoop.postEventOrDie(CHRE_EVENT_MESSAGE_FROM_HOST, nullptr, [](uint16_t eventType, void *eventData) {
47 printk("Event (%u) complete!\n", eventType);
48 });
49
50 k_sleep(K_MSEC(500));
51 printk("Ending EchoApp... %s\n",
52 boolToString(eventLoop.unloadNanoapp(instanceId, false)));
53 chre::zephyr::deinit();
54 printk("Goodbye!\n");
55 return 0;
56 }
57