请选择 进入手机版 | 继续访问电脑版

你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【STM32H7S78-DK】rtthread 增加 psram 内存管理

[复制链接]
chrome777 发布时间:2024-9-4 22:03

前言

  1. 【STM32H7S78-DK】开箱与rtthread工程初体验

概述

板卡因为内置 flash 小的问题,采用 boot+application 运行方式,自带的 boot 固件已经开启了 flash 和 psram 的内存映射,可以直接访问对应的地址。现在我们就将 psram 内存添加至内存管理单元中

mem_01.png

配置工程

打开 bsp/stm32/stm32h7s7-st-disco 目录

  1. board/port/ 目录下新增 drv_psram.c,添加如下代码
     /*
      * Copyright (c) 2006-2021, RT-Thread Development Team
      *
      * SPDX-License-Identifier: Apache-2.0
      *
      * Change Logs:
      * Date           Author         Notes
      * 2024-08-28     morph          first implementation
      */
     
     #include <board.h>
     #include <rtthread.h>
     
     #ifdef BSP_USING_PSRAM
     
     
     #define DRV_DEBUG
     #define LOG_TAG             "drv.psram"
     #include <drv_log.h>
     
     #ifdef RT_USING_MEMHEAP_AS_HEAP
     static struct rt_memheap system_heap;
     #endif
     
     
     static int PSRAM_Init(void)
     {
         int result = RT_EOK;
     
     #ifdef RT_USING_MEMHEAP_AS_HEAP
         /* If RT_USING_MEMHEAP_AS_HEAP is enabled, SDRAM is initialized to the heap */
         rt_memheap_init(&system_heap, "psram", (void *)STM32_PSRAM_START, STM32_PSRAM_SIZE * 1024U);
     #endif
     
         return result;
     }
     INIT_BOARD_EXPORT(PSRAM_Init);
     
     #endif /* BSP_USING_PSRAM */
  2. 修改 board/board.h/ 加入 psram 的配置信息 config_01.png config_02.png
  3. 修改 board/linker_scripts/link.sct 链接文件,重新规划分区 config_03.png
  4. 修改 board/kconfig 文件,增加 PSRAM 配置项,因为 boot 已经支持就直接默认使能 config_04.png
  5. 修改 board/SConscript 文件,将 drv_psram.c 加入进来 config_05.png
  6. 使用 ****menuconfig** 查看 onboard 驱动,看到已经增加 PSRAM 配置**** config_06.png
  7. 在 kernel 目录,开启 memheap 管理,才能加入内存管理,保存退出 config_07.png
  8. 使用 ****scons --target=mdk5** 工具同步工程,重新编写下载,可以看到内存管理多了 psram 块** console_01.png

使能 CACHE 和 MPU

  1. 修改 board/kconfig 文件,在 chip driver 栏增加 cache 配置项,这边我也是直接默认使能config_08.png
  2. 修改 board/board.c 文件,增加 mpu 的配置
     /*
      * Copyright (c) 2006-2022, RT-Thread Development Team
      *
      * SPDX-License-Identifier: Apache-2.0
      *
      * Change Logs:
      * Date           Author       Notes
      * 2024-04-10     RealThread   first version
      */
     
     #include "board.h"
     
     
     #define DBG_TAG "board"
     #define DBG_LVL DBG_INFO
     #include <rtdbg.h>
     
     
     /* MPU Configuration */
     
     static void MPU_Config(void)
     {
       MPU_Region_InitTypeDef MPU_InitStruct = {0};
     
       /* Disables the MPU */
       HAL_MPU_Disable();
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Enable = MPU_REGION_ENABLE;
       MPU_InitStruct.Number = MPU_REGION_NUMBER0;
       MPU_InitStruct.BaseAddress = 0x0;
       MPU_InitStruct.Size = MPU_REGION_SIZE_4GB;
       MPU_InitStruct.SubRegionDisable = 0xA7;
       MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0;
       MPU_InitStruct.AccessPermission = MPU_REGION_FULL_ACCESS;
       MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_DISABLE;
       MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE;
       MPU_InitStruct.IsCacheable = MPU_ACCESS_NOT_CACHEABLE;
       MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER1;
       MPU_InitStruct.BaseAddress = 0x70000000;
       MPU_InitStruct.Size = MPU_REGION_SIZE_128MB;
       MPU_InitStruct.SubRegionDisable = 0x0;
       MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL1;
       MPU_InitStruct.IsShareable = MPU_ACCESS_NOT_SHAREABLE;
       MPU_InitStruct.IsCacheable = MPU_ACCESS_CACHEABLE;
       MPU_InitStruct.IsBufferable = MPU_ACCESS_BUFFERABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER2;
       MPU_InitStruct.Size = MPU_REGION_SIZE_2MB;
       MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_ENABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER3;
       MPU_InitStruct.BaseAddress = 0x90000000;
       MPU_InitStruct.Size = MPU_REGION_SIZE_32MB;
       MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_DISABLE;
       MPU_InitStruct.IsCacheable = MPU_ACCESS_NOT_CACHEABLE;
       MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER4;
       MPU_InitStruct.BaseAddress = 0x20000000;
       MPU_InitStruct.Size = MPU_REGION_SIZE_64KB;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER5;
       MPU_InitStruct.BaseAddress = 0x24000000;
       MPU_InitStruct.Size = MPU_REGION_SIZE_512KB;
       MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE;
       MPU_InitStruct.IsCacheable = MPU_ACCESS_CACHEABLE;
       MPU_InitStruct.IsBufferable = MPU_ACCESS_BUFFERABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
     
       /** Initializes and configures the Region and the memory to be protected
       */
       MPU_InitStruct.Number = MPU_REGION_NUMBER6;
       MPU_InitStruct.BaseAddress = 0x2406e000;
       MPU_InitStruct.Size = MPU_REGION_SIZE_16KB;
       MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0;
       MPU_InitStruct.IsCacheable = MPU_ACCESS_NOT_CACHEABLE;
     
       HAL_MPU_ConfigRegion(&MPU_InitStruct);
       /* Enables the MPU */
       HAL_MPU_Enable(MPU_PRIVILEGED_DEFAULT);
     
     }
     
     /**
       * @brief System Clock Configuration
       * @retval None
       */
     void SystemClock_Config(void)
     {
         //Notice: system main clock is set in user boot stage.
         //you can modify it but be aware on XPI1 and XPI2 status.
         /* MPU Configuration--------------------------------------------------------*/
         MPU_Config();
     
         return;
     }
     
     int clock_information(void)
     {
         LOG_I("System Clock information");
         LOG_I("SYSCLK_Frequency = %d", HAL_RCC_GetSysClockFreq());
         LOG_I("HCLK_Frequency   = %d", HAL_RCC_GetHCLKFreq());
         LOG_I("PCLK1_Frequency  = %d", HAL_RCC_GetPCLK1Freq());
         LOG_I("PCLK2_Frequency  = %d", HAL_RCC_GetPCLK2Freq());
         LOG_I("XSPI1_Frequency  = %d", HAL_RCCEx_GetPeriphCLKFreq(RCC_PERIPHCLK_XSPI1));
         LOG_I("XSPI2_Frequency  = %d", HAL_RCCEx_GetPeriphCLKFreq(RCC_PERIPHCLK_XSPI2));
     
         return RT_EOK;
     }
     INIT_BOARD_EXPORT(clock_information);
     
  3. 使用 menuconfig 查看 onchip driver,看到已经增加 cache 配置 config_09.png
  4. 使用 scons --target=mdk5 工具同步工程,重新编写下载,运行无误

总结

评估板板载了 32MB 的 PSRAM,用于缓存图形数据提升显示效率

2 收藏 评论0 发布时间:2024-9-4 22:03

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版