OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5079|回复: 3

正点原子-内存管理实验

[复制链接]

343

主题

358

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1554
金钱
1554
注册时间
2016-12-7
在线时间
93 小时
发表于 2017-2-16 14:43:41 | 显示全部楼层 |阅读模式
1金钱
//内存池(32字节对齐)
__align(32) u8 mem1base[MEM1_MAX_SIZE];                                                                                                        //内部SRAM内存池
__align(32) u8 mem2base[MEM2_MAX_SIZE] __attribute__((at(0X68000000)));                                        //外部SRAM内存池
__align(32) u8 mem3base[MEM3_MAX_SIZE] __attribute__((at(0X10000000)));                                        //内部CCM内存池
//内存管理表
u16 mem1mapbase[MEM1_ALLOC_TABLE_SIZE];                                                                                                        //内部SRAM内存池MAP
u16 mem2mapbase[MEM2_ALLOC_TABLE_SIZE] __attribute__((at(0X68000000+MEM2_MAX_SIZE)));//外部SRAM内存池MAP
u16 mem3mapbase[MEM3_ALLOC_TABLE_SIZE] __attribute__((at(0X10000000+MEM3_MAX_SIZE)));//内部CCM内存池MAP
这个是例程里面带的代码。
为什么红色部分"u16 mem1mapbase[MEM1_ALLOC_TABLE_SIZE];"  定位没有+MEM1_MAX_SIZE呢?


最佳答案

查看完整内容[请看2#楼]

因为mem1mapbase是内部ram,编译器会自动分配内存的。其他两个是外部RAM或者CCM的,需要用户来定义,安排内存的使用
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2017-2-16 14:43:42 | 显示全部楼层
因为mem1mapbase是内部ram,编译器会自动分配内存的。其他两个是外部RAM或者CCM的,需要用户来定义,安排内存的使用
回复

使用道具 举报

343

主题

358

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1554
金钱
1554
注册时间
2016-12-7
在线时间
93 小时
 楼主| 发表于 2017-2-16 14:45:11 | 显示全部楼层
回复

使用道具 举报

343

主题

358

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1554
金钱
1554
注册时间
2016-12-7
在线时间
93 小时
 楼主| 发表于 2017-2-20 10:57:16 | 显示全部楼层
zuozhongkai 发表于 2017-2-16 14:43
因为mem1mapbase是内部ram,编译器会自动分配内存的。其他两个是外部RAM或者CCM的,需要用户来定义,安排内 ...

谢谢了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-12 14:53

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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