从fork_init看uclinux内核的线程数量限制

快乐虾

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

lights@hb165.com

 

本文适用于

ADSP-BF561

uclinux-2008r1.5-RC3(移植到vdsp5)

Visual DSP++ 5.0(update 5)

 

欢迎转载,但请保留作者信息

 

start_kernel函数中调用的第二个与进程管理相关的函数是fork_init

     fork_init(num_physpages);

在此调用中num_physpages实际表示了SDRAM中总共的页面数量,对于64M内存(实际限制为60M)其值为0x3bff

fork_init函数的实现在kernel/fork.c中:

void __init fork_init(unsigned long mempages)

{

#ifndef __HAVE_ARCH_TASK_STRUCT_ALLOCATOR

#ifndef ARCH_MIN_TASKALIGN

#define ARCH_MIN_TASKALIGN  L1_CACHE_BYTES

#endif

     /* create a slab on which task_structs can be allocated */

     task_struct_cachep =

         kmem_cache_create("task_struct", sizeof(struct task_struct),

              ARCH_MIN_TASKALIGN, SLAB_PANIC, NULL, NULL);

#endif

 

     /*

      * The default maximum number of threads is set to a safe

      * value: the thread structures can take up at most half

      * of memory.

      */

     max_threads = mempages / (8 * THREAD_SIZE / PAGE_SIZE);

 

     /*

      * we need to allow at least 20 threads to boot a system

      */

     if(max_threads < 20)

         max_threads = 20;

 

     init_task.signal->rlim[RLIMIT_NPROC].rlim_cur = max_threads/2;

     init_task.signal->rlim[RLIMIT_NPROC].rlim_max = max_threads/2;

     init_task.signal->rlim[RLIMIT_SIGPENDING] =

         init_task.signal->rlim[RLIMIT_NPROC];

}

在此函数中,首先创建了一个用于分配task_struct的缓冲区,这样就可以用SLAB算法快速分配task_struct这个结构体的对象了。

max_threads是在fork.c中定义的一个全局变量

int max_threads;       /* tunable limit on nr_threads */

此外还有

/*

 * Size of kernel stack for each process. This must be a power of 2...

 */

#define THREAD_SIZE         8192 /* 2 pages */

因而对于64M内存,max_threads将限制为0x3bf,即959

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌云阁主

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值