在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

AWorksLP應用筆記:重定向printf函數

ZLG致遠電子 ? 2023-11-25 08:24 ? 次閱讀

printf函數作為標準庫定義的格式化輸出方式,本文將介紹其在AWorksLP下默認適配以及重映射至熱拔插設備端口的實現。

默認適配

AWorksLP中默認已經對printf函數完成相關適配工作,且默認被適配在UART設備。用戶可以在圖形化配置界面中使能 support the stdio functions ,并選擇期望UART設備進行輸出,具體配置如下圖所示。

0745adc0-8b29-11ee-9788-92fbcf53809c.png

注:若用戶未使能 stdio function 時,調用printf函數時,將不會有任何輸出。

本文將使用 EPC6450-AWI 平臺,選擇標有絲印為DUART的調試串口(UART0設備)進行printf功能演示測試。將TTL轉USB串口模塊的TXD與板子的RXD絲印連接,RXD與板子的TXD絲印,將另一端的USB口接入電腦07591f5e-8b29-11ee-9788-92fbcf53809c.png啟動串口調試助手,搜索并打開串口模塊的設備端口號后,在工程中調用printf函數,根據下圖可知,printf函數適配UART0設備成功。076d89e4-8b29-11ee-9788-92fbcf53809c.png

重定向至其他設備嵌入式的諸多應用在UART設備資源受限的情況下,可能存在將printf函數重定向到其他設備需求。為此,筆者將以EPC6450-AWI平臺的USB串口設備為例進行說明。077d1c56-8b29-11ee-9788-92fbcf53809c.png1.實施步驟

與UART設備不同,USB設備為動態設備,因此重定向printf函數時,需要注意以下幾個關鍵步驟:

1.1 支持NEWLIB標準庫函數

由于AWorksLP中利用posix file相關操作接口對printf函數進行適配,故在重映射端口時,需將 support libc file operations 使能,并取消默認選擇UART設備作為printf函數的適配,具體如下圖所示。

08005670-8b29-11ee-9788-92fbcf53809c.png1.2 檢測動態設備

USB設備為動態設備,因此需要持續檢測設備的是否存在情況。可通過初始化一個動態設備檢測任務,對設備的是否存在情況進行周期性檢測。

while true: access (device) delay()

1.3 關聯標準文件流

在檢測到USB設備存在時,僅需將設備與標準文件流(stdio中的stdin、stdout、stderr,且在C庫中被假定為交互設備,并約定了這些設備的文件描述符依次為0、1、2)關聯起來。故在使用時,我們僅需將描述符0、1、2與USB串口設備即可,其偽代碼如下所示。

while true: if access (device): 0 = open (device) duplicate 1 to 0 duplicate 2 to 0 delay()

1.4 清理文件描述符

檢測到USB設備不存在時,需及時取消設備與標準文件流的關聯。即根據設備的打開情況,對文件描述符進行清理,以便之后重新關聯標準文件流。

while true: if access (device): 0 = open (device) duplicate 1 to 0 duplicate 2 to 0 else: close (device) delay()

2. 基礎配置在EPC6450-AWI平臺標有絲印為Type-C的接口處,插上Type-C線,將Type-C線的另一端USB口連接電腦。并在圖形化配置界面,將USB設備選擇為CDC串口設備。

0812e6e6-8b29-11ee-9788-92fbcf53809c.png

3.簡單示例

static int __dynamic_stdin_fd = -1;static aw_err_t __dynamic_stdout_ret = -AW_EBADF;static aw_err_t __dynamic_stderr_ret = -AW_EBADF;
aw_err_t aw_printf_redirect_dynamic_dev(void){ int find = -AW_ENODEV;
// 檢測動態設備 find = aw_access(AW_DYNAMIC_DEV_PATH, AW_F_OK);
if(find == AW_OK) { // 關聯標準文件流 if(__dynamic_stdin_fd < 0) ? ? ? ?{ ? ? ? ? ? ?__dynamic_stdin_fd = \ ? ? ? ? ? ? aw_open_at(AW_DYNAMIC_DEV_PATH,AW_O_RDWR,0,0); ? ? ? ? ? ?__dynamic_stdout_ret = aw_dup2(0, 1); ? ? ? ? ? ?__dynamic_stderr_ret = aw_dup2(0, 2); ? ? ? ? ? ?return AW_OK; ? ? ? ?} ? ?} ? ?else { ? ? ? ?// 清理文件描述符 ? ? ? ?if(__dynamic_stdin_fd >= 0) { aw_close(0); __dynamic_stdin_fd = -1; } if (__dynamic_stdout_ret == AW_OK) { aw_close(1); __dynamic_stdout_ret = -AW_EBADF; } if (__dynamic_stderr_ret == AW_OK) { aw_close(2); __dynamic_stderr_ret = -AW_EBADF; } }
return -AW_ENODEV;}
int aw_main(void){ int ret;
aw_kprintf("hello world\n"); printf("hello world\n");
while(1) { ret = aw_printf_redirect_dynamic_dev(); if (AW_OK == ret) break;
// 設置檢測周期 AW_TASK_DELAY(100); }
aw_kprintf("hello world, ZLG\n"); printf("hello world, ZLG\n");
return 0;}

啟動串口調試助手,搜索并打開DEBUG UART設備與CDC串口設備的端口號后,運行上文示例程序。根據下圖可知,USB設備枚舉后,printf函數成功重定向到了CDC串口設備。0825bf28-8b29-11ee-9788-92fbcf53809c.png

0831239a-8b29-11ee-9788-92fbcf53809c.png


07799d06-8b29-11ee-9788-92fbcf53809c.jpg 總結實現重定向printf函數時主要關注以下兩個關鍵點:

  1. 重寫NEWLIB標準庫中printf函數的底層實現;
  2. 將指定設備以標準文件流約定的文件描述符打開。


07799d06-8b29-11ee-9788-92fbcf53809c.jpg 擴展閱讀

本文所演示平臺使用的是GCC編譯器,其對應C庫為NEWLIB標準庫。在AWorksLP中printf函數的底層輸出接口在AWorksLP中實現為_write_r 函數,其具體代碼實現如下所示。

__attribute__((__used__)) _ssize_t_write_r(struct _reent *ptr, int fd, const void *buf, size_t nbytes){ return aw_write(fd,buf,nbytes);}

需要值得注意的是,上述適配方式僅兼容NEWLIB,若是其他編譯器,其實現以及接口不盡相同,下表僅給出部分以供參考,在使用時需根據實際情況進行調整。

工具鏈

標準庫

底層接口

GCC

NEWLIB

_write_r

ARMCC

ARMCLIB

_sys_write

ARMCLANG

ARMCLIB

_sys_write

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 設備
    +關注

    關注

    2

    文章

    4644

    瀏覽量

    71545
  • uart
    +關注

    關注

    22

    文章

    1271

    瀏覽量

    103440
  • 函數
    +關注

    關注

    3

    文章

    4374

    瀏覽量

    64385
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    GPDV6624C應用筆記1.0版

    電子發燒友網站提供《GPDV6624C應用筆記1.0版.pdf》資料免費下載
    發表于 06-06 17:20 ?0次下載

    無傳感器磁場定向控制

    控制,FOC 控制降低了轉矩脈動,從而消除了轉矩脈動所產生的噪聲,降低了電機發熱,同時提高了系統效率,增大了最大轉矩。本應用筆記討論了使用 JMT1808R 控制芯片對無刷直流電機(Brushless Direct Current Motor, BLDC)進行無感 FOC 的算法控制。 點擊免費下載~~~~
    發表于 03-14 16:26

    CDK應用筆記

    電子發燒友網站提供《CDK應用筆記.pdf》資料免費下載
    發表于 01-16 16:17 ?0次下載
    CDK應<b class='flag-5'>用筆記</b>

    ES32VF2264應用筆記

    電子發燒友網站提供《ES32VF2264應用筆記.pdf》資料免費下載
    發表于 01-16 16:14 ?0次下載
    ES32VF2264應<b class='flag-5'>用筆記</b>

    ES7P0214應用筆記

    電子發燒友網站提供《ES7P0214應用筆記.pdf》資料免費下載
    發表于 01-16 16:06 ?0次下載
    ES7P0214應<b class='flag-5'>用筆記</b>

    ES7P0213應用筆記

    電子發燒友網站提供《ES7P0213應用筆記.pdf》資料免費下載
    發表于 01-16 15:26 ?0次下載
    ES7P0213應<b class='flag-5'>用筆記</b>

    AT32F423 PWC應用筆記

    電子發燒友網站提供《AT32F423 PWC應用筆記.pdf》資料免費下載
    發表于 01-15 15:30 ?0次下載
    AT32F423 PWC應<b class='flag-5'>用筆記</b>

    全面掌握Linux重定向技巧:讓命令行操作效率翻倍的秘密

    #1 linux輸出重定向 $ command > file 2>1 這里的 ,表示重定向的目標不是一個 文件 ,而是一個 文件描述符 ,內置的文件描述符如下 1 => stdout2
    的頭像 發表于 01-08 10:19 ?483次閱讀

    S32K3xxICU應用筆記

    S32K3xxICU應用筆記
    發表于 12-30 15:38 ?2次下載

    stdio.h實現了printf函數?

    我們平時包含的 stdio.h 頭文件,里面是不是實現了 printf 函數? 為什么會有這個疑問?因為每次使用 printf,就得包含 stdio.h ,這就導致很多同學誤以為,stdio.h
    的頭像 發表于 12-18 10:28 ?565次閱讀

    嵌入式 學習-飛凌嵌入式ElfBoard ELF 1板卡-shell腳本編寫之輸入輸出重定向

    shell腳本編寫之輸入輸出重定向shell輸出重定向通常是指將執行命令的輸出信息從默認的標準輸出(即當前終端)重新定向到指定文件中。輸入重定向通常是指將命令所需的輸入數據的來源,從標
    發表于 09-24 10:06

    飛凌嵌入式ElfBoard ELF 1板卡-shell腳本編寫之輸入輸出重定向

    shell輸出重定向通常是指將執行命令的輸出信息從默認的標準輸出(即當前終端)重新定向到指定文件中。輸入重定向通常是指將命令所需的輸入數據的來源,從標準輸入(即當前終端)更改為從指定文件中獲取。輸出
    發表于 09-23 10:23

    重定向了fputc及putchar函數,但printf沒有輸出,為什么?

    重定向了fputc及putchar函數,但printf沒有輸出 刪除了drivers/drv_uart.c drv_uart.h 刪除了文件rt-thread\\components
    發表于 07-18 07:44

    在ESP8266_RTOS_SDK中應該怎么把ESP_LOGI重定向到UART1?

    如題,請問在ESP8266_RTOS_SDK中應該怎么把ESP_LOGI重定向到UART1? 在Esp_log.h文件中找到 /** * @brief Set function used
    發表于 07-15 06:21

    esp32c3能不能將串口打印函數重定向到自己軟件模擬的uart上?

    模擬uart,用于打印日志;請問這種做法可以實現嗎?可以將打印函數重定向到該模擬uart嗎?如果可以,麻煩指導一下重定向需要修改哪幾個函數? ps:打印的
    發表于 06-20 06:32
    主站蜘蛛池模板: 色老头免费视频 | 日韩一卡 二卡 三卡 四卡 免费视频 | 国产美女流出白浆在线观看 | 国产白白白在线永久播放 | 四虎永久在线观看视频精品 | 日本aaaaa特黄毛片 | 网站免费黄 | 欧美色图日韩 | 真人实干一级毛片aa免费 | 午夜视频在线免费观看 | 天天操天天看 | 日本一区视频在线播放 | 日本黄色大片免费 | 三级毛片在线播放 | 91老色批网站免费看 | 美国色天使| 国产三级日本三级日产三级66 | 免费一区二区视频 | 五月婷婷丁香色 | 国产一级特黄高清在线大片 | 亚洲一级毛片免费观看 | 亚洲色图日韩精品 | 97超频国产在线公开免费视频 | 婷婷香蕉 | 2015xxxx欧美| 看一级特黄a大片日本片 | 国产小视频在线观看 | 88影视在线观看污污 | 免费永久视频 | 国产专区日韩精品欧美色 | 天天综合天天看夜夜添狠狠玩 | 欧美zooz人与禽交 | 网站毛片 | 噜噜噜色 | 天天做天天爱天天综合网2021 | 欧美一级特黄视频 | 亚洲午夜精品久久久久久人妖 | 亚洲成a人片在线观看88 | 五月婷婷丁香综合网 | 亚洲第成色999久久网站 | 国产精品亚洲玖玖玖在线靠爱 |