免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3629 | 回复: 14
打印 上一主题 下一主题

[内存管理] 请教怎样让1G memory在kernel里注册只使用物理的512m-1G部分 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-12-27 22:22 |只看该作者 |倒序浏览
我碰到的问题是如果uboot传入的参数是mem=512m系统就正常,mem>512m系统会出现随机死机问题,死机是开机系统报库出错,概率大于10%,每次死的不同。但单纯做 视频播放+memory R/W compare test又正常
我想专门注册后半段memory地址来排除ddr的问题,我目前ddr地址是0x80000000-0xc0000000,我想实际使用0xa0000000-0xc0000000的地址让kernel使用,要怎样做呢?
或者大家觉得可能是哪里的问题?
lk 2.6.34,ARM Cortex A9,谢谢大家

论坛徽章:
0
2 [报告]
发表于 2012-12-28 10:24 |只看该作者
看kernel-parameter.txt,里面有如何使用特定内存区域的boot command line说明。

你这种情况,你这点线索不好说是哪的事,可能是硬件的,也可能是软件的,我感觉软件的可能要大一些。

论坛徽章:
0
3 [报告]
发表于 2012-12-28 13:58 |只看该作者
你需要修改你的 bootloader  加载 kernel的位置 0xa0000000 + 0x8000

bootloader 传给kernel参数的地址  0xa0000000 + 0x100

然后修改

arch/arm/mach-yourmachine/ 中的某个文件包含 MACHINE_START宏的内容

下面是我的机器用的,只做参考
MACHINE_START(SHOWN, "shown")
        .boot_params    = 0x30000100,
        .map_io         = shown_map_io,
        .init_irq       = shown_init_irq,
        .init_machine   = shown_init,
        .timer          = &shown_timer,
MACHINE_END

红色部分修改成你要用的物理地址 0xa0000100

修改arch/arm/mach-yourmachine/Makefile.boot 中的

zreladdr-y      :=0xa0008000
params_phys-y   :=0xa0000100

修改arch/arm/mach-yourmachine/include/mach/memory.h

#define PLAT_PHYS_OFFSET 0xa0000000



可能会有遗漏, 希望对你有帮助。

论坛徽章:
0
4 [报告]
发表于 2012-12-28 14:26 |只看该作者
回复 3# hanshu830


    boot kernel with mem=X@Y
ex:  mem=176m@16m

论坛徽章:
0
5 [报告]
发表于 2012-12-28 16:31 |只看该作者
本帖最后由 fei1700 于 2012-12-28 16:36 编辑

回复 4# oscarvei


    我试过mem=176m@16m 这类的uboot参数,系统就起不来了

关于这个,我这板子有人改过arch/arm/kernel/setup.c里的early_mem这个函数,所以不是完全线性map,有额外64m video,额外100多m 特定driver的,额外1m suspend等

论坛徽章:
0
6 [报告]
发表于 2012-12-28 16:33 |只看该作者
目前的状况是只要High Total为0,系统就正常
1. 修改mem=XXXm,此时lowmem+vmalloc <768M, 让High Total为0, 系统正常
2. 直接去掉CONFIG_HIGHMEM,系统正常

论坛徽章:
0
7 [报告]
发表于 2012-12-28 16:58 |只看该作者
hanshu830 发表于 2012-12-28 13:58
你需要修改你的 bootloader  加载 kernel的位置 0xa0000000 + 0x8000

bootloader 传给kernel参数的地址  ...



谢谢你,目前我没有修改uboot,关于启动参数,我修改内核cmdline,让它使用config里的值。lk修改memory.h这样不行,
或许是要改uboot的加载地址,不过lk不是会rellocate吗,读到哪里会有影响吗

论坛徽章:
0
8 [报告]
发表于 2012-12-28 17:34 |只看该作者
bootloader 的relocation 功能应该是搬移自己的代码段, 使之符合自己的连接脚本中的定义

oscarvei兄的方法,我不太清楚

我认为 kernel 必须要知道自己加载的物理位置, 而且bootloader 也需要把kernel加载到该位置

这样kernel才能把自己的代码段做正确的映射

论坛徽章:
0
9 [报告]
发表于 2012-12-28 18:39 |只看该作者
回复 8# hanshu830


    hi,目前我不认为是ddr的问题了,所以不打算修改memory注册后512M,谢谢你的帮助

该问题目前的规避办法是去掉CONFIG_HIGHMEM, 修改VMALLOC_END和减小VMALLOC_OFFSET,尽可能扩大系统内存,并修改IO MAP BASE,也就是要浪费一部分内存了,从c0000000-fd0000000(VMALLOC_END)是976M,比原本768M多了一点。

那么其实问题还是HIGHMEM相关的,2.6.34不知问题在哪,我另一个3.0.8版本的平台就没这个问题,但差别就不是一点了.

那么HIGHMEM问题,要怎么入手来查呢,我只打开了highmem debug这一个

论坛徽章:
0
10 [报告]
发表于 2012-12-29 11:46 |只看该作者
回复 9# fei1700

HIGH_MEM 这一块我不太熟悉。。。 我去查查相关资料


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

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP