uclinux内核参数处理(4):max_mem

rev 0.1

快乐虾

http://blog.csdn.net/lights_joy/

lights@hb165.com

本文适用于

ADI bf561 DSP

优视BF561EVB开发板

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_endreserved_mem_dcache_onreserved_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;

………………………

}

从这段代码可以看出,在不设置memmax_mem两个参数的情况下,_ramendphysical_mem_end都将指向预先设置好大小的内存的最高位置。如果只设置了mem参数,那么_ramendphysical_mem_end都将设置为mem参数指定的大小。如果只设置max_mem参数,那么将只改变physical_mem_end的位置,而_ramend仍然指向编译内核时设置好的内存大小的最高位置。

1 参考资料

uclinux内核参数处理(1):参数接收(2009-1-29)

uclinux内核参数处理(2)parse_cmdline_early(2009-1-29)

uclinux内核参数处理(3)mem(2009-1-30)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/1. 声明一个 led 字符设备结构体 static struct cdev led_cdev; //2.1 声明一个设备号 static dev_t led_num; //声明一个 myled 的类指针 static struct class * led_class; //声明一个 led 的设备指针 static struct device *led_device; //4.定义一个文件操作集 int led_open(struct inode * inode, struct file *file) { printk(KERN_INFO"led_open\n"); return 0; } //ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *); ssize_t led_write(struct file * file, const char __user * buff, size_t len, loff_t * offset) { int rt; char kbuf[64]={0}; if(buff==NULL) return -EINVAL; if(len > sizeof kbuf) len=sizeof kbuf; //注释:unsigned long copy_from_user(void *to, const void __user *from, unsigned long n) rt=copy_from_user(kbuf,buff,len); len=len-rt; printk("copy from user buf is %s,len=%d\n",buff,len); return len; } //注释:ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *); ssize_t led_read(struct file *file, char __user * buff, size_t len, loff_t * offset) { int rt; char kbuff[64]="I'm kernel data"; if(buff==NULL) return -EINVAL; if(len > sizeof kbuff) len=sizeof kbuff; rt=copy_to_user(buff, kbuff, strlen(kbuff)); len=strlen(kbuff)-rt; printk("len=%d\n",len); return len; } int led_close(struct inode * inode, struct file *file) { printk("led_close\n"); return 0; } struct file_operations led_fops={ .owner = THIS_MODULE, .open = led_open, .write = led_write, .read = led_read, .release = led_close }; static int __init kernel_init(void) { int re; //2.2 构建一个设备号,主设备号为 240,次设备号为 0 led_num=MKDEV(240,0); /3. 注册是设备号 re=register_chrdev_region(led_num, 1, "myled"); if(re<0) { printk("register_chrdev_region error\n"); goto err_register_chrdev_region; } cdev_init(&led_cdev,&led_fops); re=cdev_add(&led_cdev, led_num, 1); if(re<0) { printk("cdev_add failed\n"); goto err_cdev_add; } //创建 myled 的设备类/sys/class 目录中找到 led_class=class_create(THIS_MODULE,"myled"); if(IS_ERR(led_class)) { printk(KERN_INFO"class create error\n"); re=PTR_ERR(led_class); goto err_class_create; } //创建设备类成功创建 myled 的设备信息 led_device=device_create(led_class,NULL,led_num,NULL,"myled"); if (IS_ERR(led_device)) { re = PTR_ERR(led_device); printk("device_create leds device fail\n"); goto err_device_create; } printk(KERN_INFO"mylded_drv\n"); return 0; err_device_create: class_destroy(led_class); err_class_create: cdev_del(&led_cdev); err_cdev_add: unregister_chrdev_region(led_num, 1); return re; err_register_chrdev_region: return re; } static void __exit kernel_exit(void) { device_destroy(led_class,led_num); class_destroy(led_class); cdev_del(&led_cdev); unregister_chrdev_region(led_num, 1); printk("exit myled_drv\n"); } module_init(kernel_init); module_exit(kernel_exit); MODULE_AUTHOR("wangna wangna@blackfin.uclinux.org 1351234556"); MODULE_DESCRIPTION("kernel module test"); MODULE_LICENSE("GPL");为以上代码增加注释
最新发布
06-12

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值