LVGL on a TFT LCD Display with the nRF9160 DK

This blog post demonstrates how to get a LVGL sample up and running on the nRF9160 DK using Adafruit 1.3" 240x240 Wide Angle TFT LCD Display with MicroSD - ST7789. Follow the wiring guide and the steps in the blog post and get your display going! In an ideal world, we would be able to use the st7789v shield for waveshare 240x240, but since the nRF9160 DK does not have a device tree node label for arduino_spi, we need to implement a workaround. For the details on how the project configuration and overlay files were derived, check out my other blog post.

guide_result

Hardware

Components

Wiring

Important: The display operates with 3.3V logic, so on the nRF9160 DK, you must ensure that a tiny switch, SW9 (which sets VDD IO) is set at 3V!

Following the generic ST7789V shield pin assignment, we wire the connection as such:

nRF9160 DK pin Display pin
P0.08 RST
P0.09 D/C
P0.10 TCS
P0.11 SI
P0.12 SO
P0.13 SCK
GND GND
5V Vin


Software

After having wired up your DK, we need to perform some steps on the software side!

Prerequisites

nRF Connect SDK (NCS) installation. The attached project contains working files for both NCS v1.6.0 and NCS v2.2.0.

No guarantees can be made for other versions of NCS but it might work.

Steps

  1. Download the attached project
  2. Extract it into a valid west workspace (that is, a folder from which you can call the command west build from command line)
  3. Connect your nRF9160 DK (with the screen already wired up) to your computer
  4. Build and flash the project to the DK

Incorporating this into other projects

The process of making this display work with your own project is a bit different if you NCS v1.6.0 or NCS v2.2.0. The steps are given for each of the SDK versions below.

For reference, the new project you want to configure the display for is named YourProject.

Using the ncs v1.6.0 sample

  1. Ensure that the LVGL and display-specific settings from the provided ZIP's config file (prj.conf) is in YourProject's config file
  2. Ensure that the overlay from the provided ZIP is also included (that is, boards/nrf9160dk_nrf9160ns.overlay)
    1. If YourProject already has an overlay file (nrf9160dk_nrf9160ns.overlay), you could copy-paste the contents of the provided overlay file to YourProject's nrf9160dk_nrf9160ns.overlay
    2. If YourProject does not have an overlay file, then you could copy the whole file into YourProject folder. This will automatically be detected by CMake when you hit build!
  3. Be sure to include device.h, drivers/display.h and lvgl.h in the C-file in which you want to program using LVGL.

Using the NCS v2.2.0 sample

  1. Ensure that the LVGL and display-specific settings from the provided ZIP's config file (prj.conf) is in YourProject's config file
  2. Set the SHIELD variable for building by doing one of these things:
    1. Place the line set(SHIELD st7789v_waveshare_240x240) into YourProject's CMakeLists.txt
    2. Pass the st7789v shield as an argument to the build like this: 
      west build -- -DSHIELD=st7789v_waveshare_240x240

Note on the source code structure

The source code might not look like ordinary LVGL code (which uses lv_init, lv_disp_draw_buf_init etc) because this part of LVGL is abstracted away by Zephyr, as seen in lvgl.c in Zephyr. The source code is also based on the LVGL sample provided by Zephyr, with changes made so that it works with the nRF9160 DK when following this tutorial.

Attached files

lvgl_logo_sample_for_nrf9160_DK.zip
Parents Comment Children
  • Hi! Sorry for the late response. Thanks for the kind words :D

     

    I think it doesn’t work because of the pin wirings. On the nRF52dk_nrf52832 you may wire Vin and GND as you have already but you must change the wiring for the following pins:

    RST = P0.19
    D/C = P0.20
    TCS = P0.22
    SI = P0.23
    SO = P0.24
    SCK=P0.25


    How did I find these pins?

    st7789v_waveshare_240x240.overlay says RST = D8, D/C=D9 and TCS=D10.

    The display is also an extension of arduino_spi (defined here), which for this DK has SCK= P0.25,  MOSI=P0.23 and MISO=P0.24 (as seen in the pinctrl file for the DK)




    If you check out /nrf9160dk_nrf9160_common.dts you will see in arduino_header that D8=P0.08, D9 = P0.09 and D10=P0.10

     

    However this is not the case with nrf52dk_nrf52832. By opening nrf52dk_nrf52832.dts we see that in fact D8=P0.19, D9=P0.20 and D10=P0.22.

     

    I hope that this makes it at least somewhat clear how I came to these answers. I didn't get the chance to test this wiring, so double check the logic I wrote here if it still doesn't work! 

    Btw today is my last day at Nordic, so if you get stuck in the future I would suggest to do a discussion post in the forums rather than commenting here! This way it is easier for tech support people to see your question :D