当前位置:首页 > 嵌入式 > 嵌入式软件
[导读] 1. Vxworks下的高速缓冲存储器一致性问题美国风河(WindRiver)公司的VxWorks是目前最先进的实时嵌入式操作系统。Tornade是它的集成一体开发环境。然而,vxWorks下编程硬件驱

 1. Vxworks下的高速缓冲存储器一致性问题

美国风河(WindRiver)公司的VxWorks是目前最先进的实时嵌入式操作系统。Tornade是它的集成一体开发环境。然而,vxWorks下编程硬件驱动程序时却存在着高速缓冲存储器一致性(Cache Coherence)的问题。该系统下有两个cache区:数据高速缓冲存储器和指令高速缓冲存储器 本文讨论的高速缓冲存储器问题均指数据高速缓冲存储器。

高速缓冲存储器一致性问题是指高速缓冲存储器中的数据必须与内存中的数据保持同步(一致) 这个问题常发生在CPU内核与另一个设备异步访问内存时。

高速缓冲存储器可以工作在Write-through或copyback模式。在Write-through模式下,数据输出时.系统会把数据同时写入高速缓冲存储器和内存中.这样.就保证了输出时的高速缓冲存储器一致性。但该模式却无法解决输入时的高速缓冲存储器一致性问题.在Copyback模式下。系统只写数据到高速缓冲存储器中,因此对于数据输入和输出都存在高速缓冲存储器一致性问题。

VxWorks下通常有两种方法解决高速缓冲存储器一致性问题.

(1)Cache-safe buffer(即non-cacheable 的buffer)。这种情况下,CPU读数据时会从内存中读取.而不是从高速缓冲存储器中读取:而CPU写数据时则同时写入高速缓冲存储器和内存.

该方案可通过以下两种方法实现.

* 在内存段属性中定义此段buffer,空间属性为non-cacheable;

* 在内存管理单元MMU支持下,用cacheDmaMalloc()/cacheDmaFree()获得此段buffer。则此段buffer是non-cacheable的(注意无MMU时。分配的buffer是cacheable.此法不支持这种情况)。

(2)对于cacheable的buffer空间,采用flush()/invalidate()函数或宏来配合读/写使用此段buffer空间.flush()将高速缓冲存储器中的数据写入内存。invalidate()则将内存中数据写入高速缓冲存储器。这两个函数都保证了高速缓冲存储器与内存同步。

实际flush()/invalidate()函数有如下两组,功能相同稍有区别:

组1:CACHE_DMA_FLUSH()函数和CACHE_DMA_INVALIDATE()函数

组2:cacheFlush()函数和cacheInvalidate()函数

第一组实际是2个宏,与cacheDmaMalloc()函数配合使用。

2. MPC860上高速缓冲存储器一致性的软件设计方法

MPC860是摩托罗拉公司的32位多用途集成通信控制器.主要包括一个32位的嵌入式PowerPC core。一个通信处理模块CPM,一个系统集成模块SIM60及一个独立的快速以太网FEC模块.在VxWorks下编写MPC860的驱动程序。要保护的是CPM、FEC模块的发送/接收缓冲区描述符TXBD/RXBD及其对应的缓冲区对于MPC860开发中象BD(Buffer DescriptiOn)这样的静态空间适合采用cache-safe boffer方法。即采用第1种方法;

而对BD域中对应的缓冲区.由于该缓冲区多是动态分配和释放,更适合采用第2种方法,即采用flush()/invalidate()函数或宏来配合读/写使用此段缓冲区空间.这样可以避免将整个的包括还未分配的空间都预先标记为non-cacheable而造成效率低下。具体可以采用下面的方法:

(1)TXBD/RXBD放在MPC860双口RAM中。并在板级支持包BSP文件Syslib.c中的页描述符数据结构 svsPhysMemDesc[]中定义860上所有64K内存空间为non-cachable的缓冲区。从而不必做cache coherence的保护了.

(2)对应TXBD/RXBD中数据指针域的发/收缓冲区均用cache DmaMalloc()获得(具体是指初始化时给所有接收RXBD挂接的初始缓冲区和接收帧函数中给RXBD挂接的新缓冲区.以及在应用层中使用的发送 TXBD对应的缓冲区)。而用cacheDmaFree()释放.同时发送帧函数中用cacheFlush()函数保护待发送TXBD对应的缓冲区:接收帧函数中用cache Invalidate()函数保护已经装载了接收数据的接收缓冲区。以快速以太网FEC的驱动程序为例,保护具体实现如下:

/* FEC发送帧函数 */

FEC_SEND_FRAME()

{

/* 填写发送buffer内容,实际填写在data cache中 */

sptr_tx_buffer[i]=data;

fec.txBd.dataPointer=(char*)sptr_tx_buffer;

/*将填写在data cache中的内容写回内存中的实际发送buffer(即以sptr_tx_buffer为地址的内存)中*/

cacheFlush(DATA_CACHE,sptr_tx_buffer,1518);

/*启动发送命令,FEC控制器发送内存中buffer内容而非data cache中内容*/

*(UINT32*)VXImmrGet()+MOT_FEC_TX_ACT_OFF))=MOT_FEC_TX_ACT;

}

/*FEC接收帧函数*/

FEC_RECEIVE_FRAME()

{

/*取得实际接收buffer的地址*/

pBuffer=(void*)fec.rxBd.dataPointer;

/*将RXBD对应的内存中接收buffer中内容写回data cache中*/

cacheInvalidate(DATA_CACHE,pBuffer,1520);

*vptr_buffer=pBuffer;

/*以后CPU可以安全使用接收buffer中的内容**vptr_buffer了*/

}

if ((pBuffer = (void *)malloc (allocBytes)) == NULL)

return (NULL);

/* Flush any data that may be still sitting in the cache */

cacheClear (DATA_CACHE, pBuffer, allocBytes);

cacheInvalidate (INSTRUCTION_CACHE, pBuffer, allocBytes);

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

无论您是在研究如何使用 10GigE 还是寻求所需考虑事项的建议,本文均提供有实践,帮助确保单相机 10GigE 视觉系统设置顺利并拥有良好性能。 我们列出了主机系统配置、布线和相机设置的实践。

关键字: 视觉系统 CPU 存储器

存储器是计算机系统中的关键组件,负责存储程序指令和数据,是实现计算和信息处理的基础。根据其工作原理、存储容量、访问速度、稳定性以及持久性等诸多特性,存储器可以被细分为多个类别。本篇文章将详细介绍存储器的主要分类,并探讨各...

关键字: 存储器 RAM

Apr. 03, 2024 ---- 4月3日7时58分在台湾花莲县海域(北纬23.81度,东经121.74度)发生7.3级地震,震源深度12千米。根据全球市场研究机构TrendForce集邦咨询于第一时间调查各厂受损及...

关键字: 存储器 晶圆代工

2024年3月26日,中国-- 服务多重电子应用领域、全球排名前列的半导体公司意法半导体(STMicroelectronics,简称ST;纽约证券交易所代码:STM)发布了一项基于 18 纳米全耗尽绝缘体上硅(FD-SO...

关键字: 处理器 微控制器 存储器

该产品线提供了并行SRAM的低成本替代方案,容量高达 4 Mb,具有143 MHz SPI/SQI™通信功能

关键字: SRAM 存储器 MCU

【2024年1月15日,德国慕尼黑讯】卫星上的边缘计算和推理可实现近乎实时的数据分析和决策制定。随着联网设备的数量及其产生的数据量不断增长,这一点变得愈发重要。为满足太空应用中的这些高性能计算需求,英飞凌科技股份公司(F...

关键字: 存储器 嵌入式 边缘计算

可编程逻辑控制器(PLC,Programmable Logic Controller)是一种专为工业环境设计的数字电子系统。它使用可编程的存储器,内部存储程序,执行逻辑运算、顺序控制、定时、计数和算术操作等面向用户的指令...

关键字: 可编程逻辑控制器 数字电子系统 存储器

Jan. 11, 2024 ---- 根据TrendForce集邦咨询表示,全球受高通胀冲击,2023年笔电市场需求欲振乏力,全年出货量仅1.66亿台,年减10.8%,但衰退幅度较2022年收敛。

关键字: AI 笔电 存储器

可编程逻辑控制器(PLC)是一种工业自动化控制装置,它采用可编程的存储器来存储指令,执行逻辑运算、顺序控制、计数、定时和算术操作等面向用户的指令,并通过模拟或数字输入/输出控制各种类型的机械或生产过程。PLC的基本原理可...

关键字: 可编程逻辑控制器 自动化 存储器

Jan. 8, 2024 ---- TrendForce集邦咨询表示,2024年第一季DRAM合约价季涨幅约13~18%,其中Mobile DRAM持续领涨。目前观察,由于2024全年需求展望仍不明朗,故原厂认为持续性减...

关键字: DRAM 存储器 智能手机
关闭
关闭