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

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

3天内不再提示

广芯微电子UM3506 低功耗MCU芯片 基于FreeRTOS & RISC-V的USB PD协议实现

贞光科技 2023-02-28 10:51 次阅读

贞光科技是广芯微电子代理商和解决方案供应商,负责广芯微电子的低功耗MCU芯片,8位/32位微控制器芯片、无线射频收发器芯片,数字电源管理芯片和传感与信号调理专用芯片等产品的销售和技术服务。样品申请和订购联系我们。

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信息的及时响应和处理,又不影响显示屏幕的显示效果。

软件流程图如下:

图片

产品效果如下图:

图片

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

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

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

    关注

    146

    文章

    16991

    浏览量

    350310
收藏 人收藏

    评论

    相关推荐

    Si24R05:125K接收&2.4G收发SoC芯片资料

    Si24R05高度集成的低功耗SoC芯片 ● 具有低功耗、Low Pin Count、宽电压工作范围。 ● 内核:采用RISC-V RV32IMAC(2.6 CoreMark/MHz)
    发表于 10-31 16:27

    RISC-V国际人才培养认证中心举办“智能工控核心'RISC-V技术与工业网关应用前瞻'”沙龙活动

    超级星期六·共享开源,共谋”“篇在工业互联网与智能制造高速发展的背景下,RISC-V技术作为开源指令集架构的新星,正逐步成为推动工业控制领域技术变革的关键力量。9月21日下午,由RISC-V国际
    的头像 发表于 09-25 08:06 289次阅读
    <b class='flag-5'>RISC-V</b>国际人才培养认证中心举办“智能工控核心&<b class='flag-5'>amp</b>;apos;<b class='flag-5'>RISC-V</b>技术与工业网关应用前瞻&<b class='flag-5'>amp</b>;apos;”沙龙活动

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

    RISC-V+USB+Type-C PD Type-C接口特色MCU CH32X035,内置PDUSB接口,USB数据+PD功率传输“双管
    发表于 08-30 17:37

    2024 RISC-V 中国峰会:华秋电子助力RISC-V生态!

    &amp;gt;平台社区负责人刘勇在峰会现场分享了以“RISC-V芯片创新应用与生态”的主旨分享。 (华秋电子&amp;lt;
    发表于 08-26 16:46

    FS201资料(pcb &amp;amp; DEMO &amp;amp; 原理图)

    电子发烧友网站提供《FS201资料(pcb &amp; DEMO &amp; 原理图).zip》资料免费下载
    发表于 07-16 11:24 0次下载

    risc-vmcu对RTOS兼容性如何

    RISC-VMCU对RTOS(实时操作系统)的兼容性主要取决于多个因素,包括RTOS的版本、RISC-V指令集的实现、以及芯片制造商提供的
    发表于 05-27 16:26

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

    MCU实现高速USB通信时,通常需要外挂专业的高速USB PHY芯片,这不仅占用了MCU的多
    发表于 05-27 16:23

    RISC-VMCU与ARM对比

    开发者提供了丰富的资源和支持,降低了开发难度和成本。 成本 RISC-V :由于RISC-V是开源的,因此使用RISC-VMCU可以显著降低芯片
    发表于 05-27 15:58

    risc-v多核芯片在AI方面的应用

    RISC-V多核芯片在AI方面的应用主要体现在其低功耗、低成本、灵活可扩展以及能够更好地适应AI算法的不同需求等特点上。 首先,RISC-V适合用于高效设计
    发表于 04-28 09:20

    中国工程师最喜欢的10大RISC-V芯片

    RISC-V/ARM双核开发,支持跨内核芯片工程迁移。 沁恒微电子研发多款RISC-V内核IP,包括支持浮点运算V4F,并基于32位通用
    发表于 04-17 11:04

    国产RISC-V MCU推荐

    RISC-V MCU微控制器。片上集成2Mbps低功耗蓝牙BLE通讯模块、2个全速USB主机和设备控制器及收发器、2个SPI、4个串口、14路ADC、触摸按键检测模块、RTC等丰富的
    发表于 04-17 11:00

    瑞萨电子采用RISC-V技术MCU R9A02G021

    R9A02G021 48MHz 超低功耗 MCU标志着瑞萨电子进入 RISC-V 领域,拥有令人印象深刻的规格,例如高处理速度、低功耗和多功
    的头像 发表于 04-16 18:31 1752次阅读
    瑞萨<b class='flag-5'>电子</b>采用<b class='flag-5'>RISC-V</b>技术<b class='flag-5'>MCU</b> R9A02G021

    瑞萨推出采用自研CPU内核的通用32位RISC-V MCU 加强RISC-V生态系统布局

    瑞萨推出采用自研CPU内核的通用32位RISC-V MCU 加强RISC-V生态系统布局 RISC-V MCU为开发人员带来
    发表于 03-28 19:00 502次阅读

    来科技发布超低功耗嵌入式RISC-V处理器CPU IP—NS100系列内核

    本土RISC-V CPU IP领军企业——来科技正式发布针对信息安全的超低功耗嵌入式RISC-V处理器CPU IP——NS100系列内核,主要针超
    的头像 发表于 03-04 11:19 1268次阅读
    <b class='flag-5'>芯</b>来科技发布超<b class='flag-5'>低功耗</b>嵌入式<b class='flag-5'>RISC-V</b>处理器CPU IP—NS100系列内核

    全栈技术分享 | RISC-V技术交流会@珠海&amp;amp;@深圳

    12月,来科技将于华南两地举办RISC-V技术交流会。 本次两场活动由 珠海南方集成电路设计服务中心 、 深圳市高新技术产业促进中心 分别携手 来科技 在珠海及深圳两地举办。 期间,来自
    的头像 发表于 12-04 09:30 583次阅读
    全栈技术分享 | <b class='flag-5'>芯</b>来<b class='flag-5'>RISC-V</b>技术交流会@珠海&<b class='flag-5'>amp</b>;<b class='flag-5'>amp</b>;@深圳