本篇是《《Zephyr應(yīng)用的代碼結(jié)構(gòu)》》系列的終篇和下面兩篇文章一起可以構(gòu)建出一個有app獨立管理的zephyr項目
Zephyr應(yīng)用的代碼結(jié)構(gòu)--West提貨單: zephyr和zephyr外部項目納入到應(yīng)用代碼目錄管理
Zephyr應(yīng)用的代碼結(jié)構(gòu)--自定義開發(fā)板: 將自定義board納入到應(yīng)用代碼目錄管理
除了上面兩個場景外,我們的硬件可能也有新的驅(qū)動需求,而該驅(qū)動不被Zephyr支持,如果不想將驅(qū)動放入Zephyr中,就需要將驅(qū)動納入到應(yīng)用代碼目錄。
Zephyr驅(qū)動的添加可以分為3個級別:
有驅(qū)動API抽象,有設(shè)備樹綁定:只用添加驅(qū)動代碼
有驅(qū)動API抽象,無設(shè)備樹綁定:添加設(shè)備樹綁定文件和驅(qū)動代碼
無驅(qū)動API抽象,無設(shè)備樹綁定:添加抽象API頭文件,添加設(shè)備樹綁定文件,添加驅(qū)動代碼
驅(qū)動代碼目錄
驅(qū)動代碼目錄添加
在app/目錄下添加drivers目錄,如下
app
├── drivers
│ └── zephyr
│ ├── CMakeLists.txt
│ ├── Kconfig
│ └── sensor
│ ├── CMakeLists.txt
│ ├── Kconfig
│ └── rotary_encoder
├── CMakeLists.txt
├── Kconfig
├── rotary_encoder.c
└── rotary_encoder.h
在drivers/zephyr下的將要添加的驅(qū)動類型分類,例如我需要添加傳感器類型的驅(qū)動,就增加一個sensor文件夾
zephyr/CMakeLists.txt中指定該文件夾, 如果有其它驅(qū)動類型的文件夾也加入到該文件中
1
zephyr/Kconfig包含各個驅(qū)動類型文件夾的Kconfig
1
rsource “sensor/Kconfig”
zephyr/sensor/CMakeLists.txt中指定要使用的驅(qū)動文件夾,例如這里要指定選擇編碼器
1
add_subdirectory_ifdef(CONFIG_ROTARY_ENCODER rotary_encoder)
zephyr/sensor/Kconfig包含該類型下各個驅(qū)動的Kconfig
1
rsource “rotary_encoder/Kconfig”
zephyr/sensor/rotary_encoder/CMakeLists.txt指定驅(qū)動的源代碼
zephyr_include_directories(。)
zephyr_library()
zephyr_library_sources(rotary_encoder.c)
zephyr/sensor/rotary_encoder/Kconfig則是該驅(qū)動代碼rotary_encoder.c要使用的配置選項
menuconfig ROTARY_ENCODER
bool “Rotary Encoder Sensor”
depends on GPIO
help
Enable driver for Rotary encoder sensors.
if ROTARY_ENCODER
config ROTARY_ENCODER_THREAD_PRIORITY
int “Thread priority”
default 10
help
Priority of thread used by the driver to handle interrupts.
config ROTARY_ENCODER_THREAD_STACK_SIZE
int “Thread stack size”
default 1024
help
Stack size of thread used by the driver to handle interrupts.
驅(qū)動代碼由rotary_encoder.c和rotary_encoder.h組成,不是本文說明重點,如何實現(xiàn)驅(qū)動可以參考Zephyr驅(qū)動實現(xiàn)方式
指定使用驅(qū)動目錄
Zephyr建議將外部目錄的驅(qū)動作為module添加,在app/CMakeLists.txt中添加下面內(nèi)容,構(gòu)建時就會編譯app/drivers
list(APPEND ZEPHYR_EXTRA_MODULES
${CMAKE_CURRENT_SOURCE_DIR}/drivers
)
設(shè)備樹綁定文件目錄
為了硬件上的靈活性,Zephyr引入了設(shè)備樹,通過設(shè)備樹綁定的方式將設(shè)備樹轉(zhuǎn)換為C宏來使用。Zephyr的設(shè)備樹綁定文件可能不包含我們要用的硬件設(shè)備,這就需要我們自己添加。同樣設(shè)備樹綁定文件也可以納入app的目錄進行管理,在app目錄下添加dts目錄,里面放置設(shè)備樹綁定文件
app
├── dts
│ └── bindings
│ └── sensor
│ └── rotary-encoder.yaml
rotary-encoder.yaml的編寫和使用方法不是本文重點,詳細可以參考Zephyr添加旋轉(zhuǎn)編碼器驅(qū)動
在app/CMakeLists.txt中添加下面內(nèi)容,構(gòu)建時編譯設(shè)備樹會查找到app/dts目錄
1
list(APPEND DTS_ROOT ${CMAKE_SOURCE_DIR})
設(shè)備驅(qū)動API頭文件目錄
對于個人項目開發(fā)來說,設(shè)備驅(qū)動API一般是項目內(nèi)使用,API抽象的普遍覆蓋性并不一定要非常全,此外使用的人員也不需要大范圍討論,根據(jù)需求進行自定義就可以, 所形成的頭文件放到對應(yīng)的驅(qū)動目錄即可,例如zephyr/sensor/rotary_encoder/rotary_encoder.h, 為了方便應(yīng)用直接使用,可以在app/CMakeLists中添加
1
include_directories(drivers/zephyr/sensor/rotary_encoder/)
之后應(yīng)用代碼中就可以直接”#include “rotary_encoder.h”
結(jié)束語
到此為止我們通過三篇文章可以將Zephyr代碼, Zephyr外部項目,自定義board, 驅(qū)動都納入到一個app的倉庫進行管理,通過一個獨立的app倉庫可以驅(qū)動編譯所必須的代碼,既方便管理,又十分精簡。
如果你使用的SOC都還未被Zephyr支持,也可以將soc的移植納入到應(yīng)用目錄下進行管理,這部分目前我并沒有使用過無法做實例解釋可以參考https://docs.zephyrproject.org/latest/application/index.html#soc-definitions進行操作。
參考
https://github.com/zephyrproject-rtos/zephyr/tree/main/samples/application_development/out_of_tree_driver
https://docs.zephyrproject.org/latest/samples/application_development/out_of_tree_driver/README.html
編輯:jq
-
驅(qū)動
+關(guān)注
關(guān)注
12文章
1994瀏覽量
88728 -
API
+關(guān)注
關(guān)注
2文章
2481瀏覽量
67058 -
代碼
+關(guān)注
關(guān)注
30文章
4977瀏覽量
74417
原文標題:Zephyr應(yīng)用的代碼結(jié)構(gòu)--自定義驅(qū)動
文章出處:【微信號:智芯原動ICETech,微信公眾號:智芯原動ICETech】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
自定義卡片編輯組件
使用Python/MyHDL創(chuàng)建自定義FPGA IP
MCUXpresso SDK創(chuàng)建自定義清單
極海APM32F427如何實現(xiàn)自定義USB HID設(shè)備與PC進行通信
如何為 Vision Five 2 編譯自定義 Linux 內(nèi)核?
無圖形界面模式下自定義檢查工具的應(yīng)用
采用匯編指示符來使用自定義指令
如何在e203 SOC中添加自定義外設(shè)
零代碼實現(xiàn)茶吧機自定義語音控制定制
如何使用SDK進行自定義音頻播放功能
LOTO示波器自定義解碼功能—CANFD解碼
KiCad 中的自定義規(guī)則(KiCon 演講)
淺析Zephyr應(yīng)用的代碼結(jié)構(gòu)中的自定義驅(qū)動
評論