查看: 1112|回复: 0

[分享] 技术分享:优化LPC55(S)06内存管理,实现RAM连续支持大区间H...

[复制链接]
  • TA的每日心情
    擦汗
    12 小时前
  • 签到天数: 1776 天

    连续签到: 31 天

    [LV.Master]伴坛终老

    11

    主题

    1万

    帖子

    1

    金牌会员

    Rank: 6Rank: 6

    积分
    21108
    最后登录
    2025-9-12
    发表于 2024-10-6 00:41:11 | 显示全部楼层 |阅读模式
    LPC55(S)06拥有96KB的SRAM, 分成了SRAM0, SRAM1, SRAM2, SRAM3和SRAM X 五个分区。
    其中SRAM0,1,2,3为连续的RAM区域,总计可达80KB。近日有客户,希望malloc能支持70KB,Stack同时支持8K。
    想要在LPC55(S)06上需要一定的技巧把SRAM0,1,2,3利用起来,今天为各位看官逐一分析。

      划重点


    分析新思路
    1.png




    2.png
                  LPC55(S)06的内存地址分配
    IDE,咱们用的是KEIL. IAR和MCUXpresso同理。
    首先我们需要在system_lpc55s06.c文件中的SystemInit()函数中使能SRAM1,2,3.这里SRAM 3 被SDK定义为了USB SRAM1。

    RESET_PeripheralReset(kSRAM1_RST_SHIFT_RSTn);
    RESET_PeripheralReset(kSRAM2_RST_SHIFT_RSTn);
    RESET_PeripheralReset(kUSB1RAM_RST_SHIFT_RSTn);
    CLOCK_EnableClock(kCLOCK_Sram1);
    CLOCK_EnableClock(kCLOCK_Sram2);
    CLOCK_EnableClock(kCLOCK_UsbRam1);
    3.png
    SystemInit是在startup.s被调用的,调用的时候MCU系统的STACK和HEAP还没有被初始化, 4.png


    完成好SRAM的使能后,我们需要去调整分散加载scatter文件。
    这里我们隐掉了之前SDK的设置,我们调正了HEAP区占用SRAM的最高区0x20014000,而不是STACK区区占用SRAM的最高区0x20014000, 如果STACK设置到了SRAM3则会在boot过程中产生HardFault。
    所以这里我们调成了HEAP和STACK区间的位置顺序,变成了"code可用的RAM空间" - STACK - HEAP 而不是"code可用的RAM空间"-HEAP-STACK。 5.png
                             分散加载文件
    6.png


                  编译后STACK和HEAP的地址空间
    如果一切正常,则用如下测试代码就会毫无问题。就此,咱们就可以完整的使用80KB连续的SRAM区间了~

    uint8_t *malloc_buf;malloc_buf = malloc(70*1024);memset(malloc_buf, 0x00, 70*1024);

    该会员没有填写今日想说内容.
    回复

    使用道具 举报

    您需要登录后才可以回帖 注册/登录

    本版积分规则

    关闭

    站长推荐上一条 /3 下一条

    Archiver|手机版|小黑屋|恩智浦技术社区

    GMT+8, 2025-9-13 12:58 , Processed in 0.086751 second(s), 20 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2024, Tencent Cloud.

    快速回复 返回顶部 返回列表