<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
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

    文章

    4172

    瀏覽量

    69250
  • uart
    +關注

    關注

    22

    文章

    1159

    瀏覽量

    99956
  • 函數
    +關注

    關注

    3

    文章

    3868

    瀏覽量

    61308
收藏 人收藏

    評論

    相關推薦

    STM32CubeIDE中打印重定向報錯怎么解決?

    HAL_UART_Transmit( huart1 , (uint8_t *) ch, 1, 0xFFFF);報錯 printf重定向 報錯../Core/Src/main.c:42:21: error: \'huart1\' undeclared 已添加stdio.h頭
    發表于 04-03 07:33

    H7平臺如何重定向sqrtf函數到RAM中運行?

    如題,H7平臺如何重定向sqrtf函數到RAM中運行,這個函數是庫函數,不能使用__ramfunc前綴,有什么方法或是例程,網上找了很多icf配置的方法,都不行,要不就是只放置到RAM
    發表于 03-27 06:40

    2分鐘搞懂輸出重定向

    視頻最后我們通過重定向把標準輸出寫到了文件中,但是錯誤輸出還是留在了屏幕上。
    的頭像 發表于 01-15 16:41 ?296次閱讀

    C語言printf函數族學習筆記

    printf 應該是學習C語言的第一個函數,我們都知道它是用于字符串格式化輸出的。但是它的用法你真正了解了嗎?
    的頭像 發表于 11-24 11:15 ?539次閱讀
    C語言<b class='flag-5'>printf</b><b class='flag-5'>函數</b>族學習<b class='flag-5'>筆記</b>

    MDK在串口打印出的時候怎么進行重定向?

    MDK在串口打印出的時候怎么進行重定向
    發表于 10-11 07:45

    如何實現Printf()接口重定向到UART

    車規級MCU開發,不像PC端,包含stdio.h頭文件就可以使用Printf()函數。為了實現PC端Printf()接口功能,需要在MCU端實現Printf()接口的"
    的頭像 發表于 10-01 10:13 ?634次閱讀
    如何實現<b class='flag-5'>Printf</b>()接口<b class='flag-5'>重定向</b>到UART

    在bash中如何進行各種文件重定向呢?

    本文會用以下測試程序,來演示在bash中,如何進行各種文件重定向
    的頭像 發表于 08-25 09:31 ?685次閱讀
    在bash中如何進行各種文件<b class='flag-5'>重定向</b>呢?

    GD32VF103的相關例程中如何完成printf重定向到串口的?

    GD32VF103的相關例程中,如何完成printf重定向到串口的?
    發表于 08-16 07:54

    Splashtop:利用USB設備重定向實現無縫遠程辦公

    USB設備重定向不僅僅是一個巧妙的技巧,它是一個強大的工具,為遠程工作和娛樂開辟了廣泛的可能性。在這里,我們將探討一些真實的示例,說明如何在不同的任務和角色中充分發揮USB設備重定向的潛力。
    的頭像 發表于 07-31 14:53 ?672次閱讀

    STM32的printf函數重定向方法

    MicroLib提供了一個有限的stdio子系統,它僅支持未緩沖的stdin、stdout和stderr,那么也就是說勾選了Use MicroLib選項后,在代碼工程中就可以使用printf()函數咯?
    的頭像 發表于 07-10 16:22 ?1093次閱讀
    STM32的<b class='flag-5'>printf</b><b class='flag-5'>函數</b><b class='flag-5'>重定向</b>方法

    使用printf()函數時默認UART0輸出,請教如何重定向printf()到UART1?

    芯片:N76E003; 編譯環境:keil5 使用printf()函數時默認UART0輸出,請教如何重定向printf()到UART1?
    發表于 06-25 07:12

    【英飛凌PSoC 6 RTT開發板試用】串口測試標準輸入輸出重定向

    _write->cy_retarget_io_putchar實現發送_read->cy_retarget_io_getchar實現接收 總結Demo代碼實現了串口重定向可以直接使用printf等,進行了輸入輸出測試,測試OK方便后面使用串口打印調試。
    發表于 06-17 22:26

    esphttpd wifi連接和連接后重定向怎么處理?

    加載 esphttpd 固件后,一切正常,除了兩個(最重要的事情): 連接到 ESP 接入點后的重定向。它重定向但從未加載,我必須多次按下 chrome 瀏覽器上的重新加載按鈕,直到它加載索引頁面
    發表于 05-19 06:53

    printf輸出重定向的方法

    在 PC 上運行 C 語言時,prinf 輸出的內容會打印在電腦顯示器上,這是因為 prinf 默認的輸出設備就是顯示器。而當我們在單片機上,需要通過 printf 函數將信息打印到串口,就要對 printf
    的頭像 發表于 05-14 16:22 ?3775次閱讀
    <b class='flag-5'>printf</b>輸出<b class='flag-5'>重定向</b>的方法

    Linux I/O重定向詳解

    Linux I/O重定向可以定義為,更改從命令讀取輸入到命令發送輸出的方式。你可以重定向命令的輸入和輸出。對于重定向符號,可以是 或者 | 。
    的頭像 發表于 05-04 14:34 ?588次閱讀
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>