memset会导致一大块内存进cache吗

269 篇文章 398 订阅

在Arm体系结构中,我们知道大多数的normal memory的配置都是write allocation和read allocation的,即当写一块内存或读一块内存的时候,如果miss了,那么会将该物理内存缓存到cache中。 那么就带来一个这样的思考,如果我执行memset(a, b, len),len是一个很大的数,即对一大块内存清0,那么这一大块内存数据(此时都是0的数据)都需要被缓存到cache吗? 这岂不是造成cache的浪费?一下就把cache占满了?

在之前的微架构,也许是真的存在此问题的。然后在近些年的微架构中,可通过“Write streaming mode”解决。具体介绍如下,我们就以Cortex-A720为例,进一步说明。

Cortex-A720核心支持Write streaming mode,有时也称为读分配模式,对于L1和L2缓存都支持。
在读不命中或写不命中时,会向L1或L2缓存分配缓存行。然而,写入大块数据可能会使缓存中充满不必要的数据。这不仅会浪费电力,也会降低性能,因为整个线路会被后续写入覆盖(例如使用memset()或memcpy())。在某些情况下,不需要在写入时分配缓存行。例如,当执行C标准库的memset()函数来将大块内存清零为已知值时。
为了防止不必要的缓存行分配,内存系统会检测core何时写入了一系列完整的缓存行。如果在可配置数量的连续线路填充上检测到这种情况,那么它会切换到写入流模式。

在写入流模式下,加载操作行为与正常情况相同,仍然可能引起线路填充。
写入仍然在缓存中查找,但如果未命中,则会写入L2或L3缓存,而不会启动线路填充L1。

在内存系统切换到写入流模式之前,CHI主控器或AXI主控器接口可能会观察到超过指定数量的线路填充。

写入流模式保持启用,直到以下情况之一发生:
• 检测到一个不是完整缓存行的可缓存写入突发。
• 存在后续加载操作,其目标与未完成的写入流相同。

当Cortex-A720核心切换到写入流模式后,内存系统会继续监视总线流量。当它观察到一系列完整的缓存行写入时,会向L2或L3缓存发出信号,以进入写入流模式。
写入流阈值定义了在存储操作停止引起缓存分配之前,连续写入的缓存行数量。您可以通过写入寄存器 IMP_CPUECTLR_EL1来配置每个缓存(L1、L2和L3)的写入流阈值。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
memset函数是C语言中的一个库函数,用于将一块内存区域的值设置为指定的值。它的原型如下: ```c void *memset(void *s, int c, size_t n); ``` 其中,`s`是指向要设置的内存区域的指针,`c`是要设置的值,`n`是要设置的字节数。 使用memset函数时,需要注意以下几点,以避免可能导致内存泄漏的情况: 1. 内存分配:在使用memset函数之前,需要确保已经为要设置的内存区域分配了足够的内存空间。否则,可能导致访问非法内存区域或者覆盖其他变量的值。 2. 内存释放:如果在使用memset函数之前已经为内存区域分配了内存空间,并且在使用完毕后不再需要该内存空间,应该及时释放内存,以避免内存泄漏。可以使用`free`函数来释放动态分配的内存空间。 3. 注意边界:在使用memset函数时,需要确保不越界访问内存区域。如果要设置的字节数超过了实际分配的内存大小,可能导致访问非法内存区域或者覆盖其他变量的值。 4. 结构体和指针:当要设置的内存区域是一个结构体或者指针时,需要特别注意内存的释放和管理。如果结构体或指针中包含了动态分配的内存空间,需要在使用memset函数之前先释放这些内存空间,以避免内存泄漏。 总之,使用memset函数时需要注意内存的分配和释放,以及边界情况的处理,以避免可能导致内存泄漏的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

代码改变世界ctw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值