4. CLA(可编程控制律加速器)

2024-01-03 00:40
文章标签 控制 加速器 可编程 cla

本文主要是介绍4. CLA(可编程控制律加速器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

4.1 CLA介绍

        CLA 是一款独立的 32 位浮点处理器,运行速度与主CPU 相同。该 CLA 对外设触发器作出响应,并与主 C28x CPU 同时执行代码。这种并行处理功能可以有效地将实时控制系统的计算性能提高一倍。通过利用 CLA 为时间关键型功能提供服务,主 C28x CPU 可以自由地执行其他任务,如通信和诊断。

4.2 触发机制

        CLA程序代码可包含多大8个任务或中断服务程序,每个任务有两种触发机制,主CPU触发和外设中断信号触发。

        主CPU触发:C28x CPU通过IACK指令来触发任务执行,可以通过主CPU软件控制。

        外设中断触发:来自连接到共享总线的外设的多达256个可能的触发源,CLA在共享总线上承担次要所有权。

4.3 CLA与CPU的消息RAM

        CLA和CPU之间有两个内存块用于数据共享和通信。消息RAM总是映射到CPU和CLA内存空间,并且只允许数据访问;不能执行任何程序获取。

        CLA to CPU Message RAM:CLA可以使用这个块将数据传递给CPU。该块可由CLA读取和写入。该块可由CPU读取,但CPU的写入被忽略。

        CPU to CLA Message RAM:CPU可以使用该块向CLA传递数据和消息。这个消息RAM是CPU可读可写的。CLA可以执行读取,但CLA的写入将被忽略

4.4 CLA配置过程

4.4.1 CMD文件

        4.3小节中讲到两个消息RAM,需要配置RAM作为CLA与主CPU进行数据通讯的RAM空间,CLA1_MSGRAMLOW和CLA1_MSGRAMHIGH用于存放交互数据。将两个块放在CMD文件的page1中。

                CLA1_MSGRAMLOW  : origin = 0x001200, length = 0x000080

                CLA1_MSGRAMHIGH  : origin = 0x001280, length = 0x000080

        到SECTION块为CLA块分配地址,对应空间为PAGE中分配的CLA空间。

                Cla1ToCpuMsgRAM  : > CLA1_MSGRAMLOW,   PAGE = 1

                CpuToCla1MsgRAM  : > CLA1_MSGRAMHIGH,  PAGE = 1

        RAMLS0和RAMLS1作为CLA的代码存储空间和数据存放空间。

                Cla1Data                   : > RAMLS0, PAGE=1

                Cla1Prog         : LOAD = FLASH_APP,

                RUN = RAMLS1,

                LOAD_START(_Cla1funcsLoadStart),

                LOAD_END(_Cla1funcsLoadEnd),

                RUN_START(_Cla1funcsRunStart),

                LOAD_SIZE(_Cla1funcsLoadSize),

                PAGE = 0, ALIGN(4)

CLAscratch       :

                { *.obj(CLAscratch)

                . += CLA_SCRATCHPAD_SIZE;

                *.obj(CLAscratch_end) } >  RAMLS0,  PAGE = 1

                .scratchpad      : > RAMLS0,       PAGE = 1

                bss_cla             : > RAMLS0,       PAGE = 1

                const_cla         :  LOAD = FLASH_APP,

                RUN = RAMLS1,

                RUN_START(_Cla1ConstRunStart),

                LOAD_START(_Cla1ConstLoadStart),

                LOAD_SIZE(_Cla1ConstLoadSize),

                PAGE = 0

4.4.2 程序配置步骤

        (1)使能CLA的时钟,此为系统初始化函数,使能所有外设时钟。

                InitSysCtrl();

        (2)初始化CLA:

        

                //开始RAM初始化

                MemCfgRegs.MSGxINIT.bit.INIT_CLA1TOCPU = 1;

                while(MemCfgRegs.MSGxINITDONE.bit.INITDONE_CLA1TOCPU != 1){};

                MemCfgRegs.MSGxINIT.bit.INIT_CPUTOCLA1 = 1;

                while(MemCfgRegs.MSGxINITDONE.bit.INITDONE_CPUTOCLA1 != 1){};

                //初始化LS0和LS1并选择两个作为CLA和CPU的共享RAM

                MemCfgRegs.LSxMSEL.bit.MSEL_LS1 = 1;

                MemCfgRegs.LSxCLAPGM.bit.CLAPGM_LS1 = 1;

                MemCfgRegs.LSxMSEL.bit.MSEL_LS0 = 1;

                MemCfgRegs.LSxCLAPGM.bit.CLAPGM_LS0 = 0;

(3)配置CLA每个任务的向量地址,将程序代码搬移到CLA的RAM中运行。

                EALLOW;

                Cla1Regs.MVECT1 = (uint16_t)(&Cla1Task1);

                Cla1Regs.MVECT2 = (uint16_t)(&Cla1Task2);

                Cla1Regs.MVECT3 = (uint16_t)(&Cla1Task3);

                Cla1Regs.MVECT4 = (uint16_t)(&Cla1Task4);

                Cla1Regs.MVECT5 = (uint16_t)(&Cla1Task5);

                Cla1Regs.MVECT6 = (uint16_t)(&Cla1Task6);

                Cla1Regs.MVECT7 = (uint16_t)(&Cla1Task7);

                Cla1Regs.MVECT8 = (uint16_t)(&Cla1Task8);

                /*数据的初始化工作和函数需要在程序启动后主动运行一次,因此在配置CLA时,使能CLA应答IACK,并且强行执行一次CLA任务。*/

                Cla1Regs.MCTL.bit.IACKE = 1;       //Enable the IACK instruction

                Cla1Regs.MIER.all       = (M_INT1 | M_INT8);  //使能Task1、Task8

                PieVectTable.CLA1_1_INT = &cla1Isr1;

                PieVectTable.CLA1_2_INT = &cla1Isr2;

                PieVectTable.CLA1_3_INT = &cla1Isr3;

                PieVectTable.CLA1_4_INT = &cla1Isr4;

                PieVectTable.CLA1_5_INT = &cla1Isr5;

                PieVectTable.CLA1_6_INT = &cla1Isr6;

                PieVectTable.CLA1_7_INT = &cla1Isr7;

                PieVectTable.CLA1_8_INT = &cla1Isr8;

                PieCtrlRegs.PIEIER11.all = 0xFFFF;

                IER |= (M_INT11 );  //PIE中断11组全部使能

                EDIS;

(4)中断程序编写

                __interrupt void cla1Isr1 ()

                {

                       EPwm12Regs.ETCLR.bit.INT = 1;              //清除中断标志,以便接收新的中断

                       PieCtrlRegs.PIEACK.all = M_INT11;

                }

        /*因为在程序中使能了Task1和8和PIE中断11组全部。CLA中断1清除标志位,在Task8中进行函数处理,我使用的是CPU触发,命令为Cla1ForceTask8(),放在定时器中断里,位置不限定,自己想放哪里放哪里*/

                __interrupt void Cla1Task8 ( void )

                {

                       Control_Task_RealTimeDone();//此处为自定义功能

                }

4.4.3 CLA程序映射

        注意CLA中使用的数据进行声明时,需要存放在CLA映射的RAM区域中。例如:

                #pragma CODE_SECTION(Control_Task_RealTimeDone,"Cla1Prog");

                void Control_Task_RealTimeDone(void)

                {

                //自定义功能

                }

                #pragma CODE_SECTION(Control_PWMControl,"Cla1Prog");

                void Control_PWMControl(void)

                {

                //自定义功能

                }

        因为这一节涉及到CMD文件,下一节准备学习CMD文件。

这篇关于4. CLA(可编程控制律加速器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/564102

相关文章

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

控制反转 的种类

之前对控制反转的定义和解释都不是很清晰。最近翻书发现在《Pro Spring 5》(免费电子版在文章最后)有一段非常不错的解释。记录一下,有道翻译贴出来方便查看。如有请直接跳过中文,看后面的原文。 控制反转的类型 控制反转的类型您可能想知道为什么有两种类型的IoC,以及为什么这些类型被进一步划分为不同的实现。这个问题似乎没有明确的答案;当然,不同的类型提供了一定程度的灵活性,但

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理

深入解析秒杀业务中的核心问题 —— 从并发控制到事务管理 秒杀系统是应对高并发、高压力下的典型业务场景,涉及到并发控制、库存管理、事务管理等多个关键技术点。本文将深入剖析秒杀商品业务中常见的几个核心问题,包括 AOP 事务管理、同步锁机制、乐观锁、CAS 操作,以及用户限购策略。通过这些技术的结合,确保秒杀系统在高并发场景下的稳定性和一致性。 1. AOP 代理对象与事务管理 在秒杀商品

PostgreSQL中的多版本并发控制(MVCC)深入解析

引言 PostgreSQL作为一款强大的开源关系数据库管理系统,以其高性能、高可靠性和丰富的功能特性而广受欢迎。在并发控制方面,PostgreSQL采用了多版本并发控制(MVCC)机制,该机制为数据库提供了高效的数据访问和更新能力,同时保证了数据的一致性和隔离性。本文将深入解析PostgreSQL中的MVCC功能,探讨其工作原理、使用场景,并通过具体SQL示例来展示其在实际应用中的表现。 一、

vue2实践:el-table实现由用户自己控制行数的动态表格

需求 项目中需要提供一个动态表单,如图: 当我点击添加时,便添加一行;点击右边的删除时,便删除这一行。 至少要有一行数据,但是没有上限。 思路 这种每一行的数据固定,但是不定行数的,很容易想到使用el-table来实现,它可以循环读取:data所绑定的数组,来生成行数据,不同的是: 1、table里面的每一个cell,需要放置一个input来支持用户编辑。 2、最后一列放置两个b

【电机控制】数字滤波算法(持续更新)

文章目录 前言1. 数字低通滤波 前言 各种数字滤波原理,离散化公式及代码。 1. 数字低通滤波 滤波器公式 一阶低通滤波器的输出 y [ n ] y[n] y[n] 可以通过以下公式计算得到: y [ n ] = α x [ n ] + ( 1 − α ) y [ n − 1 ] y[n] = \alpha x[n] + (1 - \alpha) y[n-1]

OpenStack离线Train版安装系列—3控制节点-Keystone认证服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack离线Train版安装系列—1控制节点-环境准备

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack离线Train版安装系列—10.控制节点-Heat服务组件

本系列文章包含从OpenStack离线源制作到完成OpenStack安装的全部过程。 在本系列教程中使用的OpenStack的安装版本为第20个版本Train(简称T版本),2020年5月13日,OpenStack社区发布了第21个版本Ussuri(简称U版本)。 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版

OpenStack Victoria版——7.1控制节点-Neutron网络服务组件

7.1控制节点-Neutron网络服务组件 更多步骤:OpenStack Victoria版安装部署系列教程 OpenStack部署系列文章 OpenStack Victoria版 安装部署系列教程 OpenStack Ussuri版 离线安装部署系列教程(全) OpenStack Train版 离线安装部署系列教程(全) 欢迎留言沟通,共同进步。 文章目录 一、创建n