码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • STM32 printf 重定向到CAN


    最近在调试一款电机驱动板 使用的是CAN总线而且板子上只有一个CAN
    想移植Easylogger到上面试试easylogger的效果,先实现pritnf的重定向功能来打印输出
    只需要添加以下代码即可实现

    代码

    #include 
    uint8_t FDCAN_UserTxBuffer[512];
    void FDCAN_printf(const char *format, ...)
    {
    	va_list args;
    	uint32_t length;
    
    	va_start(args, format);
    	length = vsnprintf((char *)FDCAN_UserTxBuffer, 512, (char *)format, args);
    	va_end(args);
        FDCAN_Send_Data(0x100,FDCAN_UserTxBuffer,length);
    }
    
    
    /* CAN 发送一帧数据 */
    void FDCAN_Send_Message(uint32_t id, uint8_t *buf, uint8_t len)
    {
      FDCAN_TxHeaderTypeDef TxHeader;
      /* 配置Tx缓冲区消息 */
      TxHeader.Identifier = id;                /* 报文ID */
      TxHeader.IdType = FDCAN_EXTENDED_ID;     /* 扩展ID模式  */
      TxHeader.TxFrameType = FDCAN_DATA_FRAME; /* 数据帧 */
    
    #if defined(CLASSIC_CAN)
      if (len >= 8)
        len = 8;
      uint32_t CAN_FRAME_DL = len ;
    #else
      uint32_t CAN_FRAME_DL = FDCAN_DLC_BYTES_64; /* FDCAN 默认使用64*/
    #endif
    
      TxHeader.DataLength = CAN_FRAME_DL;              /* 数据帧长度 */
      TxHeader.ErrorStateIndicator = FDCAN_ESI_ACTIVE; /*发送节点错误 */
      TxHeader.BitRateSwitch = FDCAN_BRS_OFF;          /* 无波特率切换 */
      TxHeader.FDFormat = CAN_MODE;                    /* CAN模式*/
      TxHeader.TxEventFifoControl = FDCAN_STORE_TX_EVENTS;
      TxHeader.MessageMarker = 0x01;
    
      /* 发送缓冲区消息 */
      HAL_FDCAN_AddMessageToTxFifoQ(&hfdcan1, &TxHeader, buf);
      while (HAL_FDCAN_GetTxFifoFreeLevel(&hfdcan1) != 3)
        ; /*等待发送完成*/
    }
    /* CAN发送多帧数据 */
    void FDCAN_Send_Data(uint32_t id, uint8_t *buf, uint32_t len)
    {
      uint32_t transmission_times = 0; /* 发送次数 */
      uint32_t remian_bytes = 0;       /* 剩余字节 */
      uint32_t frame_length = 0;       /* 帧长度 */
    
    #if defined(CLASSIC_CAN)
      frame_length = 8;
    #else
      frame_length = 64;
    #endif
    
      transmission_times = len / frame_length;
      remian_bytes = len % frame_length;
    
      int i = 0;
      while (i < transmission_times)
      {
        FDCAN_Send_Message(id, buf + i * frame_length, len);
        i++;
      }
      if (remian_bytes > 0)
      {
        FDCAN_Send_Message(id, buf + transmission_times * frame_length, remian_bytes);
      }
    }
    

    定义了一个宏定义来实现log测试和应用的分离

    /**
     * @brief 输出日志任务
     * @param argument 
     */
    void USER_LOG_Task(void *argument)
    {
        for (;;)
        {
            #ifdef USER_LOG_ENABLE
            FDCAN_printf("\n Hellow world!\n");
            #endif
            osDelay(1000);
    
    	
        }
    }
    

    实验效果

    在这里插入图片描述

    参考文章

    STM32 printf 重定向到USB-CDC

  • 相关阅读:
    合同管理怎么做?套用Excel合同管理台账模板,真可以省心省力!
    叶酸/羧基/阿霉素/叠氮化合物氮杂苯甲酸/聚多巴胺/PEI修饰二硫化钨(WS2-FA)
    ElementUI入门及nodejs环境的搭建
    【数据分析入门】【淘宝电商API接入与电商数据分析】初识Web API(一)
    借秋说愁卖产品
    DDR3 功能测试记录
    线段树——你能回答这些问题吗?(经典应用)
    YOLOv8改进Swin Transformer:在基础SwinTransformer结构的基础上进行多种改进结构,集成Transformer和CNN的优势
    理解实现搜索二叉树
    React源码分析4-深度理解diff算法
  • 原文地址:https://blog.csdn.net/cat_milk/article/details/139473685
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号