
Include the current know issues in the documentation, so that they aren't hidden in a pull request.
4.5 KiB
Printer Demo with Zephyr
Known Issues
- Unlike the Espressif integration, we don't provide the platform integration as part of the Slint C++ API. In part, this is due to the way Zephyr OS handles device hardware. Zephyr uses the Device Tree to describe the hardware to the device driver model. In order to register an input event call back we need a pointer to a device obtained from a device tree node, and we also need to know how the driver behaves in order to write our callback function. The existing implementation is generic enough to cover the simulator and display shield drivers. A more general solution could be investigated in the future;
- Double buffering is not supported as neither the simulator or the hardware used for testing reported it as supported;
- In the simulator, we convert dirty regions to big-endian. However, where regions overlap, the intersections get converted more than once resulting in incorrect colors on the display. This is a general issue caused by overlapping dirty regions, and should be tackled separately as it also affects the Espressif demo;
- If there are active animations, we need to make sure to sleep for a fixed period of time, otherwise the event loop runs forever, never re-rendering and never getting to a state where there are no active animations;
- The example doesn't use the full screen on the hardware;
Prerequisites
Before you can run this example, make sure you have done the following:
-
Install Rust, with the nightly channel enabled:
# Install via rustup # See https://www.rust-lang.org/tools/install # Enable the nightly channel rustup toolchain install nightly rustup default nightly
-
Install the Zephyr dependencies;
-
Install West into a virtual environment:
# If Slint source is already checked out: python3 -m venv ../.venv source ../.venv/bin/activate # If you do not have Slint source yet: mkdir slint-zephyr python3 -m venv slint-zephyr/.venv source slint-zephyr/.venv/bin/activate # Install west pip install west
-
Get the Zephyr source code:
# If Slint source is already checked out (this adds the Zephyr source next to the Slint source): cd .. west init -l --mf examples/printerdemo_mcu/zephyr/west.yaml ./slint # If you do not have Slint source yet (this checks out Slint and Zephyr source into slint-zephyr): west init -m https://github.com/0x6e/slint --mr zephyr --mf examples/printerdemo_mcu/zephyr/west.yaml slint-zephyr cd slint-zephyr # Checkout the repositories: west update
-
Export a Zephyr CMake package. This allows CMake to automatically load boilerplate code required for building Zephyr applications.
west zephyr-export
-
Zephyr’s scripts/requirements.txt file declares additional Python dependencies. Install them with pip.
pip install -r ~/zephyrproject/zephyr/scripts/requirements.txt
-
Install the Zephyr SDK using version v0.16.5-1.
Build and Run the Example in the Simulator
Once you have the prerequisites, navigate to this directory and execute the following comands:
# Build
west build -b native_sim/native/64 -p always slint/examples/printerdemo_mcu/zephyr
# Run
./build/zephyr/zephyr.exe
The -p always
option of the build command forces a pristine build. The Zephyr documentation recommends this for new users.
Build and Run the Example on a Device
This sample has been tested on the NXP MIMXRT1170-EVKB with a RK055HDMIPI4MA0 MIPI display. The board/debug probe may require configuring as described here.
# Build
west build -b mimxrt1170_evk@B/mimxrt1176/cm7 -p always slint/examples/printerdemo_mcu/zephyr -- -DSHIELD=rk055hdmipi4ma0 -DCMAKE_BUILD_TYPE=Release
# Flash
west flash