1.概述
本文主要講述了Linux的QSPI驅(qū)動移植方法及驗證方法。
示例Linux內(nèi)核版本:6.8.2。硬件平臺:ARM SOC。
2.原理
Linux內(nèi)核的SPI驅(qū)動子系統(tǒng)集成了主流廠家的QSPI控制器驅(qū)動,驅(qū)動源碼位于目錄linux-6.2.8/drivers/spi。本文以移植Cadence QSPI控制器驅(qū)動為例,通過使能CONFIG_SPI_CADENCE_QUADSPI開關(guān),即可將Cadence QSPI控制器驅(qū)動spi-cadence-quadspi.c編譯進內(nèi)核。在設(shè)備樹,添加QSPI控制器設(shè)備節(jié)點及其Flash設(shè)備子節(jié)點,以加載相應(yīng)的驅(qū)動。
Linux內(nèi)核的MTD子系統(tǒng)是一個抽象層,提供統(tǒng)一的API對Flash設(shè)備進行訪問操作。Linux內(nèi)核提供了MTD tests模塊工具,可以用來對Flash進行操作,完成QSPI設(shè)備驅(qū)動的測試和驗證。
3.移植方法
(1)配置內(nèi)核

圖1 Cadence QSPI驅(qū)動配置選項說明
(2)設(shè)備樹添加QSPI控制器和Flash節(jié)點
在設(shè)備樹添加Cadence QSPI控制器節(jié)點及其Flash節(jié)點。添加方法可參考如下文件:
./Documentation/devicetree/bindings/spi/cdns,qspi-nor.yaml
./Documentation/devicetree/bindings/spi/cdns,qspi-nor-peripheral-props.yaml
4.驗證方法
(1)編譯MTD tests工具
為編譯MTD tests工具,應(yīng)配置內(nèi)核,使能CONFIG_MTD_TESTS,以編譯出MTD tests模塊。

圖2 MTD tests工具配置選項說明
MTD tests模塊隨內(nèi)核一起完成編譯,編譯完成后在linux-6.2.8/drivers/mtd/tests下生成*.ko測試模塊。其中,mtd_stresstest.ko模塊內(nèi)包含了擦除、讀、寫等操作,選取該模塊作為測試工具。mtd_stresstest.ko對應(yīng)的源碼為stresstest.c,原始代碼中讀、寫操作通過do_operation()函數(shù)隨機選擇,do_read()函數(shù)包括讀操作,do_write()函數(shù)包括擦除和寫操作,操作的目標扇區(qū)是隨機選擇的,為便于測試,可在編譯前手動修改操作的目標扇區(qū)號,即變量int eb值。
(2)使用mtd_stresstest.ko測試
內(nèi)核啟動后,通過查看,可以發(fā)現(xiàn)生成了/sys/class/mtd/mtd0設(shè)備,即可使用mtd_stresstest.ko通過mtd0設(shè)備對Flash進行擦除、讀、寫操作,以測試驅(qū)動功能的正確性。加載測試模塊的命令如下,表示測試的目標設(shè)備為mtd0,次數(shù)為1。
insmod mtd_stresstest.ko dev=0 count=1
-
控制器
+關(guān)注
關(guān)注
114文章
17526瀏覽量
188994 -
Linux
+關(guān)注
關(guān)注
88文章
11581瀏覽量
217103 -
移植
+關(guān)注
關(guān)注
1文章
406瀏覽量
29116 -
SPI
+關(guān)注
關(guān)注
17文章
1840瀏覽量
98971 -
QSPI
+關(guān)注
關(guān)注
0文章
47瀏覽量
13163
發(fā)布評論請先 登錄
RTOS和Linux中的內(nèi)存映射及移植方法
stm32移植linux方法
快速驗證移植QSPI的操作方法
《Linux設(shè)備驅(qū)動開發(fā)詳解》第23章、Linux設(shè)備驅(qū)動的移植
U-boot的SPLASH_SCREEN(啟動畫面)驅(qū)動移植方法
Linux中常用的6種SSH身份驗證方法
Linux驅(qū)動移植 Linux系統(tǒng)架構(gòu)優(yōu)點

Linux的QSPI驅(qū)動移植方法及驗證方法
評論