Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 22 Oct 2007 15:08:22 -0600
From:      Scott Long <scottl@samsco.org>
To:        Julian Elischer <julian@elischer.org>
Cc:        current@freebsd.org
Subject:   Re: kthreads->kproc and back to kthread.. next patch
Message-ID:  <471D1146.2050502@samsco.org>
In-Reply-To: <471BDA2E.9040801@elischer.org>
References:  <471BDA2E.9040801@elischer.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Julian Elischer wrote:
> Here is the link to the next patch.
> 
> this introduces (back) the kthread_create (etc) calls but now they
> make threads..
> It's still in the testing stage..
> I'd certainly appreciate feedback.
> Especially as some of the locking and stuff has changed since I first 
> wrote this and tested it over 2 years ago.
> 
> One possibility.. changing kthread_create() to kthread_new()
> so that any people who are using the old kthread_create() don't get the new
> one by mistake....
> 
> 
> after this is committed, I will start changing over some of the callers 
> of kproc_create,
> one at a time....
> 
> 
>     http://people.freebsd.org/~julian/kthread.diff
> 
> 
> it may also be worth adding some help for people to make a new kproc,
> and populate it with a number of kthreads.
> 
> for instance it would be aesthetically pleasing to have a single idle 
> process,
> and have all the idle threads be part of that single process.
> 
> Similarly, might things like the syncer or other processes ever benefit 
> from having multiple threads?
> Anyhow that's another discussion.

Why is there a need for separate kprocs with their own private kthreads
in the kernel?  The kernel is a single unified address space; I thought
that the only real benefit to "true" kthreads was just elimination of
duplication of vmspaces for all off the kthreads that are currently
running around.  Do I gain some sort of security or management benefit
from having my own private kproc for my kthreads, or am I really just
burning another vmspace object and nothing more?  What about the
existing fast context switching between kthreads (i.e. not flushing CR3
on the switch), will that remain, or does it now get more complicated?
Are there scheduling implications and benefits?  In fact for that
matter, how is scheduling going to be done for this?  Is it all going to
be 1:1 style scheduling, or will there be a multi-tier scheduler for
kprocs and kthreads and associated niceness/fairness?  What about high
priority kthreads like ithreads, taskqueues, and SWI's?

If I've missed the discussion on scheduling, I apologize.  If not, have
these questions been thought through yet?

Scott



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?471D1146.2050502>