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

快乐虾

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

[email protected]

本文适用于

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

你可能感兴趣的:(thread,C++,c,算法,cache)