資料介紹
描述
背景
Arduino IDE 附帶的 SD 庫很方便,但缺少 exFAT、LFN(長文件名)和非英文字符支持等功能。本文介紹了一種替代 SD 卡驅(qū)動程序(基于 RT-Thread)來解決這些問題。
RT-線程
RT-Thread是一個免費(fèi)的開源(Apache 許可證 2.0)RTOS,并以 Arduino 庫的形式提供。還有另一篇文章 ( Multitasking on Arduino ) 可用于了解 RT-Thread 的基本概念。
讓我們從通過 Arduino IDE 的庫管理器安裝庫開始。(本文基于 RT-Thread 庫版本 0.4.4 。)
SD 卡驅(qū)動程序 (TL;DR)
(如果您對實(shí)現(xiàn)不感興趣,只想知道如何使用它,請?zhí)^本節(jié)。)
RT-Thread 庫中的 SD 卡支持采用DFS(設(shè)備文件系統(tǒng))的形式,它是 RT-Thread 架構(gòu)的一部分。FAT 是 RT-Thread 支持的文件系統(tǒng)之一。(在 RT-Thread 庫的 0.4.4 版本中,F(xiàn)AT 是唯一支持的文件系統(tǒng)。)
FAT DFS 本??身就是基于ChaN 的 FatFs 項目的優(yōu)秀作品。
標(biāo)準(zhǔn)的 RT-Thread DFS 提供以下文件系統(tǒng)和文件接口:
/* File system operations */
struct dfs_filesystem_ops
{
const char *name;
uint32_t flags; /* flags for file system operations */
/* operations for file */
const struct dfs_file_ops *fops;
/* mount and unmount file system */
int (*mount) (struct dfs_filesystem *fs, unsigned long rwflag, const void *data);
int (*unmount) (struct dfs_filesystem *fs);
/* make a file system */
int (*mkfs) (rt_device_t devid);
int (*statfs) (struct dfs_filesystem *fs, struct statfs *buf);
int (*unlink) (struct dfs_filesystem *fs, const char *pathname);
int (*stat) (struct dfs_filesystem *fs, const char *filename, struct stat *buf);
int (*rename) (struct dfs_filesystem *fs, const char *oldpath, const char *newpath);
};
/* File operations */
struct dfs_file_ops
{
int (*open) (struct dfs_fd *fd);
int (*close) (struct dfs_fd *fd);
int (*ioctl) (struct dfs_fd *fd, int cmd, void *args);
int (*read) (struct dfs_fd *fd, void *buf, size_t count);
int (*write) (struct dfs_fd *fd, const void *buf, size_t count);
int (*flush) (struct dfs_fd *fd);
int (*lseek) (struct dfs_fd *fd, off_t offset);
int (*getdents) (struct dfs_fd *fd, struct dirent *dirp, uint32_t count);
int (*poll) (struct dfs_fd *fd, struct rt_pollreq *req);
}
一個特定的 DFS 可能會實(shí)現(xiàn)它們的全部或部分。當(dāng)掛載DFS時,例如dfs_mount("SD", "/", "elm", 0, 0),特定的DFS會綁定到一個設(shè)備上。在這種情況下,DFS "elm" (FatFs) 綁定到設(shè)備 "SD"。
標(biāo)準(zhǔn)的 RT-Thread 設(shè)備提供以下接口:
/* operations set for device object */
struct rt_device_ops
{
/* common device interface */
rt_err_t (*init) (rt_device_t dev);
rt_err_t (*open) (rt_device_t dev, rt_uint16_t oflag);
rt_err_t (*close) (rt_device_t dev);
rt_size_t (*read) (rt_device_t dev, rt_off_t pos, void *buffer, rt_size_t size);
rt_size_t (*write) (rt_device_t dev, rt_off_t pos, const void *buffer, rt_size_t size);
rt_err_t (*control)(rt_device_t dev, int cmd, void *args);
};
一個特定的設(shè)備可以實(shí)現(xiàn)它們的全部或全部(將函數(shù)指針設(shè)置為 NULL)。
在庫中,名為“SD”的設(shè)備實(shí)現(xiàn)了與SD卡訪問相關(guān)的功能,在MKRZERO板的情況下,它涉及到一個名為“SPI1”的低級設(shè)備。而 SPI 設(shè)備最終涉及到了 Arduino SPI 庫。
數(shù)據(jù)記錄器示例
Arduino SD 庫提供了一個名為“Datalogger”的示例。RT-Thread 庫中也提供了相同的示例,如下面的代碼部分所列。
不同之處在于,在下面的示例代碼中,采樣間隔為 1 秒,并且只執(zhí)行 10 次。
您可能已經(jīng)注意到上面的注釋open()功能。要打開現(xiàn)有文件并刪除其所有內(nèi)容,只需O_APPEND用O_TRUNC標(biāo)志替換即可。
當(dāng)使用 MKRZERO 板運(yùn)行以下示例時,您可能會觀察到串行監(jiān)視器的以下輸出:
\ | /
- RT - Thread Operating System
/ | \ 4.0.1 build Apr 17 2019
2006 - 2019 Copyright by rt-thread team
+ Mount SD to "/"
416,347,312
finsh />436,369,335
442,375,340
449,376,338
449,375,346
429,374,341
447,369,342
449,363,338
426,363,334
419,353,327
使用 Shell 進(jìn)行操作
使用 RT-Thread 庫的真正優(yōu)勢在于它使您能夠使用 (FinSH) shell 命令來操作文件。
在串行監(jiān)視器或其他串行終端工具中,輸入ls()命令將顯示當(dāng)前目錄(在本例中為“/”)中的文件列表,如下所示。
ls()
Directory /:
DATALOG.TXT 240
HI_UTF8.TXT 35
A_REAL~1.TXT 22
0, 0x00000000
文件名后面的數(shù)字是以字節(jié)為單位的文件大小。在上面的屏幕截圖中,“datalog.txt”的大小為 240 字節(jié),因?yàn)槲疫\(yùn)行了該示例兩次。
輸入cat("datalog.txt")命令會顯示“datalog.txt”的內(nèi)容,確認(rèn)有20條記錄。
finsh />cat("datalog.txt")
464,358,333
464,368,336
480,381,354
447,364,346
443,363,340
441,365,343
463,371,345
467,374,313
447,364,345
465,369,346
416,347,312
436,369,335
442,375,340
449,376,338
449,375,346
429,374,341
447,369,342
449,363,338
426,363,334
419,353,327
0, 0x00000000
還有copy()和rm()命令。
finsh />copy("datalog.txt", "copy.txt")
0, 0x00000000
finsh />ls()
Directory /:
COPY.TXT 240
DATALOG.TXT 240
HI_UTF8.TXT 35
A_REAL~1.TXT 22
0, 0x00000000
finsh />rm("copy.txt")
0, 0x00000000
finsh />ls()
Directory /:
DATALOG.TXT 240
HI_UTF8.TXT 35
A_REAL~1.TXT 22
0, 0x00000000
要列出所有可用命令,請輸入list()。
finsh />list()
--Function List:
hello -- say hello world
version -- show RT-Thread version information
list -- list available commands
list_mem -- list memory usage information
list_thread -- list thread
list_sem -- list semaphore in system
list_mutex -- list mutex in system
list_event -- list event in system
list_mb -- list mail box in system
list_mq -- list message queue in system
list_memp -- list memory pool in system
list_timer -- list timer in system
list_dev -- list device in system
mkfs -- make a file system
df -- get disk free
mkdir -- create a directory
cd -- change current working directory
ls -- list directory contents
rm -- remove files or directories
cat -- print file content
copy -- copy file or dir
list_sd -- show SD information
--Variable List:
dummy -- dummy variable for finsh
0, 0x00000000
ExFAT、LFN 和非英文字符支持
默認(rèn)情況下不啟用 ExFAT、LFN(長文件名)和非英文字符支持(以使示例更?。?。在“ rtconfig.h ”(位于 RT-Thread 庫目錄中)中打開以下配置以啟用這些功能。
#define RT_DFS_ELM_USE_EXFAT
#define RT_DFS_ELM_USE_LFN (2)
#define RT_DFS_ELM_MAX_LFN (255)
#define RT_DFS_ELM_CODE_PAGE 936
RT_DFS_ELM_MAX_LFN表示文件名的最大長度,可以在 12 到 255 的范圍內(nèi)。
RT_DFS_ELM_CODE_PAGE默認(rèn)設(shè)置為 437 用于美國,更改為 936 將啟用簡體中文支持,如下所示。
finsh />ls()
Directory /:
DATALOG.TXT 240
hi_utf8.txt 35
a_really_long_file_name.txt22
0, 0x00000000
finsh />cat("hi_utf8.txt")
Hello, world!
世界,你好! 0, 0x00000000
下一步
- RT-Thread Primer(即將推出)
- 帶有RT-Thread的Arduino應(yīng)用程序
- RT-Thread文檔_workqueue
- RT-Thread文檔_ringbuffer
- RT-Thread文檔_completion
- RT-Thread文檔_RT-Thread SMP 介紹與移植
- RT-Thread文檔_內(nèi)核基礎(chǔ)
- RT-Thread文檔_RT-Thread 潘多拉 STM32L475 上手指南
- RT-Thread文檔_RT-Thread 簡介
- RT-Thread Smart 上手指南
- 【RT-Thread開源作品秀】基于RT-Thread的星務(wù)平臺研究
- RT-Thread AI kit開源:輕松實(shí)現(xiàn)一鍵部署AI模型至 RT-Thread
- RT-Thread Studio驅(qū)動SD卡
- 嵌入式RT-Thread應(yīng)用與開發(fā) 72次下載
- RT-Thread用戶手冊 0次下載
- RT-Thread編程指南 0次下載
- 基于 RT-Thread專業(yè)版的EtherCAT主站方案 2.9k次閱讀
- BL808 RT-Thread Wi-Fi驅(qū)動適配 1.8k次閱讀
- RT-Thread qemu mps2-an385 bsp移植制作 :系統(tǒng)運(yùn)行篇 1.4k次閱讀
- i.MX RT1170:VGLite移植RT-Thread Nano過程講解(下) 1.9k次閱讀
- i.MX RT1170:VGLite移植RT-Thread Nano過程講解(上) 4.1k次閱讀
- rt-studio潘多拉開發(fā)板最新rt-thread不能運(yùn)行解決辦法 2.5k次閱讀
- RT-Thread記錄(八、理解RT-Thread內(nèi)存管理) 3.5k次閱讀
- RT-Thread自動初始化機(jī)制 3.9k次閱讀
- RT-Thread 4.1.0的CMake構(gòu)建教程 4.4k次閱讀
- 如何使用xmake工具來編譯rt-thread工程 2.8k次閱讀
- RT-Thread v4.1.0中FAL介紹 5.4k次閱讀
- 如何創(chuàng)建RT-Thread Nano工程 5.2k次閱讀
- RT-Thread NetUtils的使用方法 8.8k次閱讀
- 如何創(chuàng)建標(biāo)準(zhǔn)的RT-Thread項目工程?詳細(xì)過程分析概述 1w次閱讀
- RT-Thread軟件包定義和使用 1.2w次閱讀
下載排行
本周
- 1耗盡型MOS FET產(chǎn)品目錄選型表
- 0.14 MB | 2次下載 | 免費(fèi)
- 2TI系列-米爾TI AM62L核心板開發(fā)板-高能效低功耗嵌入式平臺
- 1.51 MB | 次下載 | 免費(fèi)
- 3WILLSEMI韋爾20年半年度報告由代理分銷經(jīng)銷一級代理分銷經(jīng)銷
- 3.30 MB | 次下載 | 免費(fèi)
- 4LRC 樂山無線電InTWSApplications家電由原廠代理分銷經(jīng)銷一級代理分銷經(jīng)銷供應(yīng)
- 85.84 KB | 次下載 | 免費(fèi)
- 5LAT1596 一文說明白 STM32G4 雙 Bank 啟動與升級
- 0.64 MB | 次下載 | 5 積分
- 6LAT1594_基于事件喚醒低功耗之介紹
- 0.37 MB | 次下載 | 5 積分
- 7PT8P2309 觸控 A/D 型 8-Bit MCU規(guī)格書
- 4.05 MB | 次下載 | 免費(fèi)
- 8PT8P2308 觸控 A/D 型 8-Bit MCU規(guī)格書
- 4.13 MB | 次下載 | 免費(fèi)
本月
- 1美的電磁爐電路原理圖資料
- 4.39 MB | 19次下載 | 10 積分
- 2反激式開關(guān)電源設(shè)計解析
- 0.89 MB | 11次下載 | 5 積分
- 3耗盡型MOS FET產(chǎn)品目錄選型表
- 0.14 MB | 2次下載 | 免費(fèi)
- 4簡易光伏控制器原理圖資料
- 0.07 MB | 1次下載 | 5 積分
- 52EDL05x06xx系列 600V半橋門驅(qū)動器帶集成自舉二極管(BSD)手冊
- 0.69 MB | 1次下載 | 免費(fèi)
- 6國產(chǎn)千兆網(wǎng)口芯片PT153S中文資料
- 1.35 MB | 次下載 | 免費(fèi)
- 7斯丹電子 | 用于芯片測試系統(tǒng)的射頻干簧繼電器
- 5.11 MB | 次下載 | 免費(fèi)
- 8SFI立昌ESD/TVS管原廠代理分銷經(jīng)銷一級代理分銷經(jīng)銷
- 294.76 KB | 次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233095次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191448次下載 | 10 積分
- 5十天學(xué)會AVR單片機(jī)與C語言視頻教程 下載
- 158M | 183360次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81605次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73829次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論