rev 0.1
快乐虾
http://blog.csdn.net/lights_joy/
本文适用于
ADI bf561 DSP
uclinux-2008r1.5-rc3 (smp patch)
Visual DSP++ 5.0(update 5)
欢迎转载,但请保留作者信息
这是uclinux最先处理的几个内核参数之一,对它的处理由parse_cmdline_early函数完成,在此函数的注释中,简单说明了此参数的作用及其格式:
* - Controlling the physical memory size: max_mem=xxx[KMG][$][#]
* $ -> reserved memory is dcacheable
* # -> reserved memory is icacheable
即它将控制可用内存的大小,看看内核对此参数的处理:
} else if (!memcmp(to, "max_mem=", 8)) {
to += 8;
memsize = memparse(to, &to);
if (memsize) {
physical_mem_end = memsize;
if (*to != ' ') {
if (*to == '$'
|| *(to + 1) == '$')
reserved_mem_dcache_on =
1;
if (*to == '#'
|| *(to + 1) == '#')
reserved_mem_icache_on =
1;
}
}
} else if (!memcmp(to, "earlyprintk=", 12)) {
它将修改三个全局变量,physical_mem_end、reserved_mem_dcache_on和reserved_mem_icache_on。后两个参数将影响CPLB的设置。
默认情况下physical_mem_end将指向物理内存的结束位置。看下面这段代码:
void __init setup_arch(char **cmdline_p)
{
…………………….
/* Keep a copy of command line */
*cmdline_p = &command_line[0];
memcpy(boot_command_line, command_line, COMMAND_LINE_SIZE);
boot_command_line[COMMAND_LINE_SIZE - 1] = '\0';
/* setup memory defaults from the user config */
physical_mem_end = 0;
_ramend = CONFIG_MEM_SIZE * 1024 * 1024;
parse_cmdline_early(&command_line[0]);
………………………
if (physical_mem_end == 0)
physical_mem_end = _ramend;
………………………
}
从这段代码可以看出,在不设置mem和max_mem两个参数的情况下,_ramend和physical_mem_end都将指向预先设置好大小的内存的最高位置。如果只设置了mem参数,那么_ramend和physical_mem_end都将设置为mem参数指定的大小。如果只设置max_mem参数,那么将只改变physical_mem_end的位置,而_ramend仍然指向编译内核时设置好的内存大小的最高位置。
uclinux内核参数处理(1):参数接收(2009-1-29)
uclinux内核参数处理(2):parse_cmdline_early(2009-1-29)
uclinux内核参数处理(3):mem(2009-1-30)