public inbox for linux-ia64@vger.kernel.org
 help / color / mirror / Atom feed
From: "Kaigai Kohei" <kaigai@ak.jp.nec.com>
To: linux-ia64@vger.kernel.org
Subject: Re: [PATCH] Kernel panic on IA-64 Linux with SELinux
Date: Tue, 15 Jun 2004 09:37:25 +0000	[thread overview]
Message-ID: <019e01c452bc$5ec3b530$f97d220a@linux.bs1.fc.nec.co.jp> (raw)
In-Reply-To: <013f01c44ddb$636d4aa0$f97d220a@linux.bs1.fc.nec.co.jp>

[-- Attachment #1: Type: text/plain, Size: 2351 bytes --]

Dear David

The attached patch moves the current of cpu_idle from region 7 to region 5.

The init_task can be viewed from either region 5 or 7.
But the current(r13) of cpu_idle was a region 7 address while &init_task
referes to a region 5 address. Thus, some bad effects occurred.
(This problem came to the front first time by enabling SELinux.)


Signed-off-by: Kazuto MIYOSHI <k-miyoshi@cb.jp.nec.com>
Signed-off-by: Takayoshi Kochi <t-kochi@bq.jp.nec.com>
Signed-off-by: Kaigai Kohei <kaigai@ak.jp.nec.com>

Thanks, so much.
--------
Kaigai Kohei, Linux Promotion Center, NEC
E-mail: kaigai@ak.jp.nec.com


> Hi Kaigai,
> 
> Thanks for looking into this issue.
> 
> >>>>> On Tue, 15 Jun 2004 11:28:14 +0900, "Kaigai Kohei" <kaigai@ak.jp.nec.com> said:
> 
>   Kaigai> I have applied this patch to 2.6.6 kernel, and system stall
>   Kaigai> occurred while booting up. The problem is in
>   Kaigai> init_mount_tree().  The init_mount_tree() function uses
>   Kaigai> do_each_thread() macro defined as follows:
> 
>   Kaigai> #define do_each_thread(g, t) \
>   Kaigai>   for (g = t = &init_task ; (g = t = next_task(g)) != &init_task ; ) do
> 
> Yeah, that'd do it.
> 
>   Kaigai> There are several solutions against this problem.
> 
>   Kaigai> (1) Initializing only wait_chldexit as my first patch.
> 
>   Kaigai> (2) Moving current of swapper from region 7 to region 5 as
>   Kaigai> Miyoshi's second patch.
> 
>   Kaigai> (3) Replacing &init_task with task_t *p_init_task which
>   Kaigai> refers to init_task in region 7, and refers to init_task
>   Kaigai> directly on other archtectures.
> 
>   Kaigai> (1) is easy but ad hoc. (3) needs to correct generic code.
>   Kaigai> (2) is consistent on &init_task is in region 5 and
>   Kaigai> current(r13) for cpu_idle refers to region 5. But the number
>   Kaigai> of steps in switch_to() macro will increase.  This overhead
>   Kaigai> is not a big problem, I guess.
> 
>   Kaigai> For reasons already stated I prefer (2). What do you think?
> 
> I agree, (2) seems to best solution so far.  It maintains the
> invariant that static data will be in region 5.  The extra
> instructions should be pretty much free since it should be possible to
> schedule them into existing stalls.
> 
> Can you resend the tested patch with proper changelog and "Signed-off-by"
> trailer?
> 
> Thanks,
> 
> --david
> 

[-- Attachment #2: migrate.init_task.2.6.7-rc3.patch --]
[-- Type: application/octet-stream, Size: 1156 bytes --]

diff -rNU2 linux-2.6.7-rc3/arch/ia64/kernel/entry.S linux-2.6.7-rc3.selinux/arch/ia64/kernel/entry.S
--- linux-2.6.7-rc3/arch/ia64/kernel/entry.S	2004-06-08 04:14:02.000000000 +0900
+++ linux-2.6.7-rc3.selinux/arch/ia64/kernel/entry.S	2004-06-15 15:19:24.925797780 +0900
@@ -178,5 +178,8 @@
 	DO_SAVE_SWITCH_STACK
 	.body
-
+	
+	movl r22=init_task;;
+	cmp.eq p7,p6=r22,in0
+	
 	adds r22=IA64_TASK_THREAD_KSP_OFFSET,r13
 	mov r27=IA64_KR(CURRENT_STACK)
@@ -190,5 +193,5 @@
 	 * If we've already mapped this task's page, we can skip doing it again.
 	 */
-	cmp.eq p7,p6=r26,r27
+(p6)	cmp.eq p7,p6=r26,r27
 (p6)	br.cond.dpnt .map
 	;;
diff -rNU2 linux-2.6.7-rc3/arch/ia64/kernel/head.S linux-2.6.7-rc3.selinux/arch/ia64/kernel/head.S
--- linux-2.6.7-rc3/arch/ia64/kernel/head.S	2004-06-08 04:14:42.000000000 +0900
+++ linux-2.6.7-rc3.selinux/arch/ia64/kernel/head.S	2004-06-15 15:15:57.434480607 +0900
@@ -182,4 +182,6 @@
 
 	// load the "current" pointer (r13) and ar.k6 with the current task
+	(isBP) movl r2=init_task	// migrate to region 5
+	;; 
 	mov IA64_KR(CURRENT)=r2		// virtual address
 	mov IA64_KR(CURRENT_STACK)=r16

  parent reply	other threads:[~2004-06-15  9:37 UTC|newest]

Thread overview: 19+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-06-09  4:36 [PATCH] Kernel panic on IA-64 Linux with SELinux 
2004-06-09 14:40 ` Kazuto MIYOSHI
2004-06-09 21:55 ` David Mosberger
2004-06-09 22:44 ` Luck, Tony
2004-06-09 23:25 ` David Mosberger
2004-06-09 23:35 ` Luck, Tony
2004-06-10  0:58 ` David Mosberger
2004-06-10  5:19 ` Luck, Tony
2004-06-10  5:23 ` David Mosberger
2004-06-10  5:28 ` Luck, Tony
2004-06-15  2:28 ` Kaigai Kohei
2004-06-15  4:17 ` Luck, Tony
2004-06-15  4:23 ` David Mosberger
2004-06-15  4:25 ` Luck, Tony
2004-06-15  4:25 ` David Mosberger
2004-06-15  9:37 ` Kaigai Kohei [this message]
2004-06-15 12:52 ` Kaigai Kohei
2004-06-17  1:10 ` David Mosberger
     [not found] <Xine.LNX.4.44.0406101657420.8385-100000@thoron.boston.redhat.com>
2004-06-11  1:13 ` Kaigai Kohei

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='019e01c452bc$5ec3b530$f97d220a@linux.bs1.fc.nec.co.jp' \
    --to=kaigai@ak.jp.nec.com \
    --cc=linux-ia64@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox