0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于FreeRTOS和RISC-V的USB PD协议实现

广芯微电子 来源:广芯微电子 2023-03-07 10:39 次阅读

1 FreeRTOS简介

FreeRTOS 是市场领先的面向微控制器和小型微处理器的实时操作系统(RTOS),与世界领先的芯片公司合作开发。FreeRTOS 通过 MIT 开源许可免费分发,包括一个内核和一组不断丰富的库,适用于所有行业领域。FreeRTOS 的构建强调可靠性和易用性。FreeRTOS 的主要功能可以归结为以下几点:

优先级调度、相同优先级任务的轮转调度,同时可设成可剥夺内核或不可剥夺内核

任务可选择是否共享堆栈(co-routines& tasks),并且没有任务数限制

消息队列,二值信号量,计数信号量,递归互斥体

时间管理

内存管理

1.1 FreeRTOS特点:

FreeRTOS的特点:

小型节能内核 大小可扩展,可用程序内存占用低至 6KB。一些架构包括无滴答的节能模式;

支持 40 多种架构 代码库支持 40 多种 MCU 架构和15 多种工具链,包括最新RISC-VARMv8-M (Arm Cortex-M33) 微控制器;

模块化库 越来越多的加载项库,适用于所有行业领域,包括安全的本地或云连接;

AWS参考集成 利用经过测试的示例,其中包括安全连接到云所必需的所有库;

MIT许可,有选项 FreeRTOS 可根据MIT 许可用于任何目的。提供商业许可,以及安全认证

2 RISC V简介

RISC-V是加州大学伯克利分校(University of California at Berkeley)设计并发布的一种开源指令集架构,其目标是成为指令集架构领域的Linux,应用覆盖IoT(Internet of Things)设备、桌面计算机、高性能计算机等众多领域。

RISC-V读作RISC Five,意思是第五代精简指令处理器。取这个名字只是因为美国伯克利研究团队的David Patterson教授在此之前已经研制了四代精简指令处理器芯片。

RISC-V是由UC-Berkeley团队在历代RISC架构基础上,总结多个ISA 优缺点而重新创建的一种新式ISA, 它采取“开源”的模式对全世界开放,希望成为一切计算设备都可以采用的指令集架构。它的开放性允许它可以自由地被用于任何目的,允许任何人设计、制造和销售基于RISC-V的芯片或软件,这种彻底的开放性在处理器领域还是第一次。

2.1 RISC-V的特点

首先是开源的优势:

任何公司和个人不需任何费用就可以自由使用RISC-V,不像ARM指令集需要支付高昂授权费,也不像英特尔不开放内核,只允许用户基于微处理器进行应用开发。

RISC-V的开源会大大降低指令集修改和定制的门槛,在实现芯片差异化设计的同时降低成本,对发展自主可控处理器、摆脱垄断有着十分重要的意义。

其次是功能优势:

RISC-V架构的篇幅很短,不用背负向后兼容的历史包袱;

模块化的灵活设计,RISC-V可根据特定应用场景对指令集进行裁剪或修改;

RISC-V支持可扩展定制指令;

RISC-V硬件设计与编译器实现起来非常简单。

3 基于FreeRTOS & RISC V内核的PD协议的应用

3.1 UM3506 PD SoC

广芯微旗下双向PD快充控制器芯片UM3506 (TID: 2465), 采用软硬结合的灵活可编程架构,全面支持PD3.1 SRC, SNK, 双向DRP和 EMARK功能,其中包括SPR下的PPS和ERP下的AVS动态电压模式,同时还可支持EPR线缆中PD 3.1 EMARK模式。

UM3506芯片采用TCPM/TCPC分层架构,集成原生的TCPC-like前端模块,包括用于Type-C接口检测与控制的数字逻辑和模拟电路,PD PHY层的分组BMC编解码以及PD协议层中对时序有严格要求的关键功能,同时创新地集成了基于RISC-V 指令集的32位微处理器内核,大容量FLASH闪存/SRAM存储器、增强的外设接口和丰富的系统资源。

3.2 应用案例

USB PD EMARK数显线,自带0.96寸液晶屏幕,在内置EMARK功能从而支持100W功率传输的同时,还可通过屏幕显示电压电流参数,实时了解设备用电信息。通过内置16通道12位ADC配合采样电阻采集电流信息,并采集母线电压信息。

项目使用FreeRTOS, FreeRTOS 的实现主要由 list.c、queue.c、croutine.c 和 tasks.c 4 个文件组成。list.c 是一个链表的实现,主要供给内核调度器使用;queue.c 是一个队列的实现,支持中断环境和信号量控制;croutine.c 和 task.c 是两种任务的组织实现。协程(英文为 croutine)是采用各任务共享同一个堆栈, 使 RAM 的需求进一步缩小,但也正因如此,他的使用受到相对严格的限制。而 task 则是传统的实 现,各任务使用各自的堆栈,支持完全的抢占式调度。

3.2.1 FreeRTOS移植

3.2.1.1 portmacro.h 头文件

portmacro.h头文件主要包括两部分内容。第一部分定义了一系列内核代码中用到的数据类型,第二部分包含了实现 FreeRTOS 移植所需要定义的函数。包括与架构相关的定义、内核调度、临界区管理、任务优化等。

1.数据类型定义

定义编译器相关的各种数据类型。

#define portCHAR char

#define portFLOAT float

#define portDOUBLE double

#define portLONG long

#define portSHORT short

#define portSTACK_TYPE unsigned portLONG

#define portBASE_TYPE long

2.架构相关的定义

定义与处理器或控制器架构相关的宏定义。

#define configUSE_16_BIT_TICKS 0 //处理器字长为32 位

#define portSTACK_GROWTH -1 //定义堆栈的生长方向逆向生长

//定义心跳时钟周期,表示的是相邻Tick间间隔多少ms

#define portTICK_RATE_MS((portTickType)1000/configTICK_RATE_HZ)

//访问SRAM的字节对齐

#define portBYTE_ALIGNMENT 8

3.内核调度函数

/* 声明该函数定义在其它文件中,实现强制上下文切换,用在任务环境中调用 */

extern void vPortYieldFromISR( void );

#define portYIELD() vPortYieldFromISR()

/* 强制上下文切换,在中断处理环境中调用 */

#define portEND_SWITCHING_ISR(xSwitchRequired)if(xSwitchRequired)

vPortYieldFromISR()

3.2.1.2port.c 源文件

1.堆栈初始化

进行堆栈的初始化,使堆栈处于预知的确定状态。下面是堆栈初始化的代码实现。

StackType_t*pxPortInitialiseStack( StackType_t *pxTopOfStack, TaskFunction_t pxCode, void*pvParameters )

{

/* 计算存储程序状态寄存器xPSR的堆址,用于MCU在进入或退出中断时恢复现场*/ register int *tp asm("x4");

pxTopOfStack--;

/* 程序状态寄存器的值保存于堆栈中 */

*pxTopOfStack = (portSTACK_TYPE)pxCode;

pxTopOfStack -= 22;

*pxTopOfStack = (portSTACK_TYPE)pvParameters;

pxTopOfStack -= 6;

*pxTopOfStack = (portSTACK_TYPE)tp;

pxTopOfStack -= 3;

*pxTopOfStack = (portSTACK_TYPE)prvTaskExitError;

return pxTopOfStack;

}

2.启动任务调度

portBASE_TYPE xPortStartScheduler( void )

{

/* 让任务切换中断和心跳中断位于最低的优先级,使更高优先级可以抢占MCU */

*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;

*(portNVIC_SYSPRI2) |=portNVIC_SYSTICK_PRI;

/* 启动定时器,开始产生系统的心跳时钟,此处中断已被关闭 */

prvSetupTimerInterrupt();

/* 初始化临界区的嵌套的个数,准备启动第一个任务 */

uxCriticalNesting = 0;

/* 启动第一个任务 */

vPortStartFirstTask();

/* 执行到vPortStartFirstTask函数,内核已经开始正常的调度 */

return 0;

}

FreeRTOS首先为刚创建的任务分配所需内存,若分配成功,则初始化任务名称、堆栈深度和任务优先级,然后根据堆栈的增长方向初始化任务控制块的堆栈。接着,FreeRTOS把当前创建的任务加入到就绪任务链表。当进行任务调度时,调度算法首先实现优先级调度。系统按照优先级从高到低的顺序从就绪任务链数组中选择当前最高就绪优先级,据此实现优先级调度。若此优先级下只有一个就绪任务,则该任务进入运行状态,若此优先级下有多个就绪任务 则需采用轮换调度算法实现多任务轮流执行。

3.2.2 项目软件实现

本项目采用Eclipse IDE,系统上电之后,系统进行硬件和时钟初始化,MCU和操作系统的工作方式和工作状态进入准备阶段,除了空闲任务,还创建了三个任务:

(1)vUSBPDTask应用于处理PD协议,EMARK信息处理,充电方向,电压、电流数据采集并计算功率,耗电功率等数据,最高优先级;

(2)vUartRxTask串口数据接收任务,用于系统调试,第二优先级;

(3)vSysLcdHandlerTask显示任务,可以通过按键切换各个显示界面,为了在各个状态下显示界面不被打乱,创建 了g_sys_lcd_info.bus_lock互斥信号量,显示电压、电流、功率、充电方向、用电功率等信息,第三优先级;

显示任务执行耗时最长,vUSBPDTask需要快速响应,可以抢占其他任务从而确保PD信息的及时响应和处理,又不影响显示屏幕的显示效果。

软件流程图如下:

b68e21c8-bc25-11ed-bfe3-dac502259ad0.png

本项目产品已经批量生产,实现实时多任务操作的同时缩短开发周期,保证了产品实时处理EMARK信号、准确快速采集电压电流等信息、显示流畅,广受客户欢迎。

UM3506的DEMO软件已经做好了FreeRTOS的移植,客户可以很方便地根据需求创建自己的任务,快速开发产品。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • usb
    usb
    +关注

    关注

    60

    文章

    7947

    浏览量

    264734
  • 操作系统
    +关注

    关注

    37

    文章

    6829

    浏览量

    123338
  • PD
    PD
    +关注

    关注

    4

    文章

    473

    浏览量

    43997
  • FreeRTOS
    +关注

    关注

    12

    文章

    484

    浏览量

    62191
  • RISC-V
    +关注

    关注

    45

    文章

    2283

    浏览量

    46174
  • 广芯微电子
    +关注

    关注

    0

    文章

    33

    浏览量

    196

原文标题:基于FreeRTOS & RISC-V的USB PD协议实现

文章出处:【微信号:广芯微电子,微信公众号:广芯微电子】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    青稞RISC-V通用系列MCU一览

    内核技术的授权费和提成费,通过内置和组合USBPD、低功耗蓝牙、以太网等专业接口外设,构建了既有全球未来生态又能自主可控、且极具长期竞争力的MCU产品线。 产品阵容产品选型 在线选型 [青稞RISC-V通用系列 -(wch.
    发表于 10-11 09:56

    RISC-V的MCU关于USB高速通信设计的难点

    的MCU在实现高速USB通信时,通常需要外挂专业的高速USB PHY芯片,这不仅占用了MCU的多个GPIO,还增加了PCB面积。RISC-V MCU在设计上需要解决内置高速
    发表于 05-27 16:23

    rIsc-v的缺的是什么?

    通过软件模拟或复杂的指令序列来实现一些高级功能,这可能会增加执行时间和功耗。 2. 生态系统支持不足 软件和工具链的可用性:尽管RISC-V社区在快速发展,但与成熟的ARM等架构相比,其生
    发表于 07-29 17:18

    RISC-V Summit China 2024 | 青稞RISC-V+接口PHY,赋能RISC-V高效落地

    RISC-V+USB+Type-C PD Type-C接口特色MCU CH32X035,内置PDUSB接口,USB数据+PD功率传输“双管齐下”。芯片内置多运放/比较器、触摸按键、P
    发表于 08-30 17:37

    如何在RISC-V处理器上使用FreeRTOS

    RISC-V指令集体系结构(ISA)易于扩展,并且没有指定关于特定RISC-V微控制器或片上系统(SoC)实现的所有内容。因此,FreeRTOS R
    发表于 11-29 15:54

    为什么选择RISC-V

    。例如,如果工程师在FPGA中实现RISC-V内核,则通常可以使用RTL源代码。由于RISC-V免版税,这为将基于RISC-V的设计从FPGA移植到ASIC或另一个FPGA带来了极大
    发表于 07-27 17:38

    科普RISC-V生态架构(认识RISC-V)

    RISC-V指令集基于这一开源领域非常自由的开源协议发布时,我们暂且相信这一指令集如该协议声明的那样开放。在RISC-V发展进程中,去拥抱它,发展它,合作构建一套自主可控且全球公认的指
    发表于 08-02 11:50

    RISC-V架构简介

    【摘要】 本文首先对RISC-V的架构做了简要的介绍,在此基础上实现了LiteOS在RISC-V架构上的适配过程的具体步骤,希望对你有所帮助。1 RISC-V架构简介
    发表于 07-28 07:46

    RISC-V MCU开发相关资料分享

    RISC-V MCU开发 (二):工程创建与管理MounRiver® Studio(MRS)内置了GD、WCH等芯片厂家的RISC-V/ARM以及RISC-V通用指令集系列的芯片工程模板,支持
    发表于 12-09 08:14

    RISC-V简介

    RISC-V简介  RISC-V 是一个自由和开放的 ISA(开源指令集架构),通过开放的标准协作实现处理器创新的新时代。RISC-V ISA在架构上提供了一个新的自由、可扩展的软件和
    发表于 02-27 19:56

    我了解的RISC-V

    )、RISC-V 统一可扩展固件接口(UEFI)规格,以及 RISC-V Zmmul 纯乘法扩展。完全开源 对指令集使用,RISC-V基金会不收取高额的授权费。开源采用宽松的BSD协议
    发表于 03-19 10:52

    FreeRTOSRISC-V——适用于RISC-VFreeRTOS概述

    1.1简介FreeRTOS中面向RISC-V的接口是易于拓展的,其提供了一系列基本的接口,用于操作适用于所有RISC-V实现中的通用寄存器,以及一系列的宏来处理特定的硬件
    发表于 04-09 09:26

    RISC-V规范的演进 RISC-V何时爆发?

    RISC-V的关注度越来越高,开源的理念也正在被越来越多的开发者和公司接受。对于尚不成熟的RISC-V而言,无论是规范和技术的演进还是生态的建设,还有人才和专利都还有不小挑战。2021年RISC-V
    的头像 发表于 02-11 10:10 3188次阅读

    RISC-VRISC-V AI的未来(特邀讲座)

    主题演讲:RISC-VRISC-V AI的未来(特邀讲座)ppt分享
    发表于 07-14 17:15 16次下载

    RISC-V设计支持工具,支持RISC-V技术的基础

    RISC-V设计支持工具,支持RISC-V技术的基础 ppt分享
    发表于 07-14 17:15 12次下载