Re: 2.6.{26.2,27-rc} oops on virtualbox

Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
From: Gerhard Brauer
Date: Tuesday, August 26, 2008 - 1:34 pm

On Tue, Aug 26, 2008 at 02:15:58PM -0400, Mathieu Desnoyers wrote:

Hej! This last changes (in addition to the others you mentioned) seems
to be a good shot. I could reboot 8 times the guest, compile several
packages (something which always leeds to the oops) and currently i
build two big packages simultan. So this is heavy IO.

I will try tomorrow more heavy build tests (to gain the good feeling to
the vbox+guest kernel again like it was with 2.6.25), but i think your
changes goes in the right direction.

Here is the diff what i've changed on your hints:

,----[ arch/x86/kernel/alternative.c ]
| --- alternative.c.org	2008-07-13 23:51:29.000000000 +0200
| +++ alternative.c	2008-08-26 21:35:20.000000000 +0200
| @@ -343,6 +343,7 @@
|  void alternatives_smp_switch(int smp)
|  {
|  	struct smp_alt_module *mod;
| +	unsigned long flags;
|  
|  #ifdef CONFIG_LOCKDEP
|  	/*
| @@ -359,7 +360,7 @@
|  		return;
|  	BUG_ON(!smp && (num_online_cpus() > 1));
|  
| -	spin_lock(&smp_alt);
| +	spin_lock_irqsave(&smp_alt, flags);
|  
|  	/*
|  	 * Avoid unnecessary switches because it forces JIT based VMs to
| @@ -383,7 +384,7 @@
|  						mod->text, mod->text_end);
|  	}
|  	smp_mode = smp;
| -	spin_unlock(&smp_alt);
| +	spin_unlock_irqrestore(&smp_alt, flags);
|  }
|  
|  #endif
| @@ -420,6 +421,7 @@
|  
|  void __init alternative_instructions(void)
|  {
| +	unsigned long flags;
|  	/* The patching is not fully atomic, so try to avoid local interruptions
|  	   that might execute the to be patched code.
|  	   Other CPUs are not running. */
| @@ -427,6 +429,7 @@
|  #ifdef CONFIG_X86_MCE
|  	stop_mce();
|  #endif
| +	local_irq_save(flags);
|  
|  	apply_alternatives(__alt_instructions, __alt_instructions_end);
|  
| @@ -465,6 +468,7 @@
|  				(unsigned long)__smp_locks,
|  				(unsigned long)__smp_locks_end);
|  
| +	local_irq_restore(flags);
|  	restart_nmi();
|  #ifdef CONFIG_X86_MCE
|  	restart_mce();
| @@ -508,33 +512,5 @@
|   */
|  void *__kprobes text_poke(void *addr, const void *opcode, size_t len)
|  {
| -	unsigned long flags;
| -	char *vaddr;
| -	int nr_pages = 2;
| -	struct page *pages[2];
| -	int i;
| -
| -	if (!core_kernel_text((unsigned long)addr)) {
| -		pages[0] = vmalloc_to_page(addr);
| -		pages[1] = vmalloc_to_page(addr + PAGE_SIZE);
| -	} else {
| -		pages[0] = virt_to_page(addr);
| -		WARN_ON(!PageReserved(pages[0]));
| -		pages[1] = virt_to_page(addr + PAGE_SIZE);
| -	}
| -	BUG_ON(!pages[0]);
| -	if (!pages[1])
| -		nr_pages = 1;
| -	vaddr = vmap(pages, nr_pages, VM_MAP, PAGE_KERNEL);
| -	BUG_ON(!vaddr);
| -	local_irq_save(flags);
| -	memcpy(&vaddr[(unsigned long)addr & ~PAGE_MASK], opcode, len);
| -	local_irq_restore(flags);
| -	vunmap(vaddr);
| -	sync_core();
| -	/* Could also do a CLFLUSH here to speed up CPU recovery; but
| -	   that causes hangs on some VIA CPUs. */
| -	for (i = 0; i < len; i++)
| -		BUG_ON(((char *)addr)[i] != ((char *)opcode)[i]);
| -	return addr;
| +	return text_poke_early(addr, opcode, len);
|  }
`----

So if Luiz and others could also try all 3 mentioned changes, maybe we
have a solution. I also will build tomorrow a new LiveCD/Install ISO
with these patches to see if the error there is also gone.


Gerhard


-- 
Was wir wissen, ist ein Tropfen.
Was wir nicht wissen, ein Ozean (Newton)
--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Wed Aug 20, 12:29 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Thu Aug 21, 2:34 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Thu Aug 21, 11:42 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Ingo Molnar, (Thu Aug 21, 11:50 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 7:28 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 7:39 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Fri Aug 22, 8:34 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 9:29 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Fri Aug 22, 9:35 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 10:16 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 10:20 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Fri Aug 22, 10:45 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 10:57 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 11:11 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 12:10 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 12:14 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 12:18 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 12:40 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 12:42 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 1:31 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 1:55 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Fri Aug 22, 1:57 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Fri Aug 22, 2:08 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 7:18 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Tue Aug 26, 7:53 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Tue Aug 26, 9:02 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Tue Aug 26, 9:09 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Tue Aug 26, 9:13 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 9:40 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Tue Aug 26, 10:18 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Tue Aug 26, 10:32 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Tue Aug 26, 11:02 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Tue Aug 26, 11:15 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 12:27 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Tue Aug 26, 12:52 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 1:34 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Tue Aug 26, 1:48 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 2:25 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Tue Aug 26, 2:35 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, H. Peter Anvin, (Tue Aug 26, 2:51 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Tue Aug 26, 5:13 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Wed Aug 27, 12:13 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Mathieu Desnoyers, (Wed Aug 27, 4:33 pm)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Thu Aug 28, 6:30 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Thu Aug 28, 6:50 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Sun Aug 31, 2:29 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Stefan Lippers-Hollmann, (Sun Aug 31, 6:28 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Sun Aug 31, 7:03 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Sun Aug 31, 7:09 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Gerhard Brauer, (Sun Sep 21, 6:41 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Ingo Molnar, (Mon Sep 22, 2:51 am)
Re: 2.6.{26.2,27-rc} oops on virtualbox, Luiz Fernando N. Cap ..., (Wed Sep 24, 6:24 am)