Name | Date | Size | #Lines | LOC | ||
---|---|---|---|---|---|---|
.. | - | - | ||||
include/ | 04-Jan-2025 | - | 18 | 8 | ||
src/ | 04-Jan-2025 | - | 101 | 71 | ||
CMakeLists.txt | D | 04-Jan-2025 | 306 | 12 | 8 | |
README.rst | D | 04-Jan-2025 | 4.4 KiB | 75 | 60 | |
prj.conf | D | 04-Jan-2025 | 114 | 8 | 6 | |
sample.yaml | D | 04-Jan-2025 | 817 | 29 | 28 |
README.rst
1.. zephyr:code-sample:: chre 2 :name: Android's Context Hub Runtime Environment (CHRE) 3 4 Run nanoapps on Zephyr using the Context Hub Runtime Environment (CHRE). 5 6Overview 7======== 8 9Android's context hub enables the use of nanoapps. A single nanoapp has 3 entry points seen in 10`chre_api/chre/nanoapp.h`_: 11 12* A ``nanoappStart`` function used to notify the nanoapp that it is now active. 13* A ``nanoappHandleEvent`` function used to notify the nanoapp tha an event of interest took place. 14* A ``nanoappEnd`` function used to notify the nanoapp that it is now deactivated. 15 16The CHRE connects to several frameworks called Platform Abstraction Layers (PAL)s. Note that 17currently, none of these are implemented for Zephyr, but they are scheduled to be added. These 18frameworks include: 19 20#. *Audio* - a framework allowing nanoapps to get audio events. See `pal/audio.h`_ for API details. 21#. *GNSS* - a framework allowing nanoapps to manage location and measurement sessions. See 22 `pal/gnss.h`_ for API details. 23#. *Sensor* - a framework allowing nanoapps to request changes to sensors configuration get 24 data/bias events. See `pal/sensor.h`_ for API details. 25#. *System* - a framework allowing nanoapps to make common system requests such as logging, clock, 26 and some basic memory allocation/deallocation. See `pal/system.h`_ for API details. 27#. *WiFi* - a framework allowing nanoapps to interact with the on board WiFi. See `pal/wifi.h`_ for 28 API details. 29#. *WWAN* - a framework allowing nanoapps to interact with the WWAN module such as getting the 30 current capabilities and info. See `pal/wwan.h`_ for API details. 31 32Building and expectations 33========================= 34 35To build the sample use the following west command: 36 37.. zephyr-app-commands:: 38 :zephyr-app: samples/modules/chre 39 :board: native_sim 40 :goals: build 41 42Once built and run, the sample application should: 43 44#. Print a hello message 45#. Notify that the event loop started via an ``inf`` level log 46#. Notify that a nanoapp was started and assigned an instance/app ID of 1 via a ``dbg`` level log 47#. Print a message saying that the nanoapp's start callback was called 48#. Send an event of type ``1`` and no data to the nanoapp 49#. Notify that the event was processed 50#. Call the ``nanoappEnd`` function of the nanoapp 51#. Print a message notifying that it's not possible to remove a system level nanoapp 52#. Exit the event loop 53 54Roadmap 55======= 56 57#. Add an implementation of the `pal/sensor.h`_ and `pal/system.h`_ to Zephyr. These will be 58 standalone modules that can be used independently of CHRE, but when ``CONFIG_CHRE`` is enabled 59 will also provide an implementation of ``chrePalSensorGetApi()`` and ``struct chrePalSystemApi``. 60#. Add a directory ``chre/nanoapps`` which will host various nanoapps to be used by the Zephyr 61 community. These should each have their own Kconfig to enable them and set the appropriate 62 dependencies. The first nanoapp will be a lid angle calculator which will use 2 accelerometers. 63#. Update the ``overlay.dts`` of this sample application to include 2 emulated accelerometers and 64 configure them to return scripted data. 65#. Run this sample application and watch the nanoapp provide lid angle calculations based on 2 66 accelerometers provided by the sensors PAL framework. 67 68.. _`chre_api/chre/nanoapp.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/chre_api/include/chre_api/chre/nanoapp.h;drc=7c60a553288d63e6e3370d679803da46dac723a4 69.. _`pal/audio.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/audio.h;l=69;drc=6ca547ad175f80ce9f09f5b7b14fcc6f14565f5c 70.. _`pal/gnss.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/gnss.h;l=152;drc=830255234157cc7afe5201dca19a7fb71ea850fe 71.. _`pal/sensor.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/sensor.h;l=51;drc=23207906add05054a94dfab41b95bcfc39bedfe4 72.. _`pal/system.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/system.h;l=49;drc=6ca547ad175f80ce9f09f5b7b14fcc6f14565f5c 73.. _`pal/wifi.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/wifi.h;l=153;drc=b673b80ed98e1b6e6360bee4ba98e2cd8f4e0935 74.. _`pal/wwan.h`: https://cs.android.com/android/platform/superproject/+/master:system/chre/pal/include/chre/pal/wwan.h;l=69;drc=629361a803cb305c8575b41614e6e071e7141a03 75