linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: "Sakkinen, Jarkko" <jarkko.sakkinen@intel.com>
To: Yinghai Lu <yinghai@kernel.org>
Cc: Thomas Gleixner <tglx@linutronix.de>, Ingo Molnar <mingo@elte.hu>,
	"H. Peter Anvin" <hpa@zytor.com>,
	"Eric W. Biederman" <ebiederm@xmission.com>,
	Andrew Morton <akpm@linux-foundation.org>,
	Borislav Petkov <bp@alien8.de>, Jan Kiszka <jan.kiszka@web.de>,
	Jason Wessel <jason.wessel@windriver.com>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v7u1 07/31] x86, realmode: Separate real_mode reserve and setup
Date: Fri, 4 Jan 2013 17:18:39 +0000	[thread overview]
Message-ID: <1357319845.7763.0.camel@jsakkine-mobl1> (raw)
In-Reply-To: <1357260531-11115-8-git-send-email-yinghai@kernel.org>

[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain; charset="utf-8", Size: 3482 bytes --]

On Thu, 2013-01-03 at 16:48 -0800, Yinghai Lu wrote:
> After we switch to use #PF handler help to set page table, init_level4_pgt
> will only have entries set after init_mem_mapping.
> We need to move copying init_level4_pgt to trampoline_pgd after that.
> 
> So split reserve and setup, and move the setup after init_mem_mapping()
> 
> Signed-off-by: Yinghai Lu <yinghai@kernel.org>
> Cc: Jarkko Sakkinen <jarkko.sakkinen@intel.com>

Acked-by: Jarkko Sakkinen <jarkko.sakkinen@intel.com>

> ---
>  arch/x86/include/asm/realmode.h |    3 ++-
>  arch/x86/kernel/setup.c         |    4 +++-
>  arch/x86/realmode/init.c        |   30 +++++++++++++++++++-----------
>  3 files changed, 24 insertions(+), 13 deletions(-)
> 
> diff --git a/arch/x86/include/asm/realmode.h b/arch/x86/include/asm/realmode.h
> index fe1ec5b..9c6b890 100644
> --- a/arch/x86/include/asm/realmode.h
> +++ b/arch/x86/include/asm/realmode.h
> @@ -58,6 +58,7 @@ extern unsigned char boot_gdt[];
>  extern unsigned char secondary_startup_64[];
>  #endif
>  
> -extern void __init setup_real_mode(void);
> +void reserve_real_mode(void);
> +void setup_real_mode(void);
>  
>  #endif /* _ARCH_X86_REALMODE_H */
> diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
> index 81ea5a5..01b22d0 100644
> --- a/arch/x86/kernel/setup.c
> +++ b/arch/x86/kernel/setup.c
> @@ -913,10 +913,12 @@ void __init setup_arch(char **cmdline_p)
>  	printk(KERN_DEBUG "initial memory mapped: [mem 0x00000000-%#010lx]\n",
>  			(max_pfn_mapped<<PAGE_SHIFT) - 1);
>  
> -	setup_real_mode();
> +	reserve_real_mode();
>  
>  	init_mem_mapping();
>  
> +	setup_real_mode();
> +
>  	memblock.current_limit = get_max_mapped();
>  	dma_contiguous_reserve(0);
>  
> diff --git a/arch/x86/realmode/init.c b/arch/x86/realmode/init.c
> index 384b3f4..3baae96 100644
> --- a/arch/x86/realmode/init.c
> +++ b/arch/x86/realmode/init.c
> @@ -8,9 +8,26 @@
>  struct real_mode_header *real_mode_header;
>  u32 *trampoline_cr4_features;
>  
> -void __init setup_real_mode(void)
> +void __init reserve_real_mode(void)
>  {
>  	phys_addr_t mem;
> +	unsigned char *base;
> +	size_t size = PAGE_ALIGN(real_mode_blob_end - real_mode_blob);
> +
> +	/* Has to be in very low memory so we can execute real-mode AP code. */
> +	mem = memblock_find_in_range(0, 1<<20, size, PAGE_SIZE);
> +	if (!mem)
> +		panic("Cannot allocate trampoline\n");
> +
> +	base = __va(mem);
> +	memblock_reserve(mem, size);
> +	real_mode_header = (struct real_mode_header *) base;
> +	printk(KERN_DEBUG "Base memory trampoline at [%p] %llx size %zu\n",
> +	       base, (unsigned long long)mem, size);
> +}
> +
> +void __init setup_real_mode(void)
> +{
>  	u16 real_mode_seg;
>  	u32 *rel;
>  	u32 count;
> @@ -25,16 +42,7 @@ void __init setup_real_mode(void)
>  	u64 efer;
>  #endif
>  
> -	/* Has to be in very low memory so we can execute real-mode AP code. */
> -	mem = memblock_find_in_range(0, 1<<20, size, PAGE_SIZE);
> -	if (!mem)
> -		panic("Cannot allocate trampoline\n");
> -
> -	base = __va(mem);
> -	memblock_reserve(mem, size);
> -	real_mode_header = (struct real_mode_header *) base;
> -	printk(KERN_DEBUG "Base memory trampoline at [%p] %llx size %zu\n",
> -	       base, (unsigned long long)mem, size);
> +	base = (unsigned char *)real_mode_header;
>  
>  	memcpy(base, real_mode_blob, size);
>  

ÿôèº{.nÇ+‰·Ÿ®‰­†+%ŠËÿ±éݶ\x17¥Šwÿº{.nÇ+‰·¥Š{±þG«éÿŠ{ayº\x1dʇڙë,j\a­¢f£¢·hšïêÿ‘êçz_è®\x03(­éšŽŠÝ¢j"ú\x1a¶^[m§ÿÿ¾\a«þG«éÿ¢¸?™¨è­Ú&£ø§~á¶iO•æ¬z·švØ^\x14\x04\x1a¶^[m§ÿÿÃ\fÿ¶ìÿ¢¸?–I¥

  reply	other threads:[~2013-01-04 17:19 UTC|newest]

Thread overview: 199+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-01-04  0:48 [PATCH v7u1 00/31] x86, boot, 64bit: Add support for loading ramdisk and bzImage above 4G Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 01/31] x86, mm: Fix page table early allocation offset checking Yinghai Lu
2013-01-04  7:17   ` Borislav Petkov
2013-01-04 21:50     ` Yinghai Lu
2013-01-05 13:05       ` Borislav Petkov
2013-01-15 12:27   ` Stefano Stabellini
2013-01-04  0:48 ` [PATCH v7u1 02/31] x86, 64bit, mm: make pgd next calculation consistent with pud/pmd Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 03/31] x86, realmode: set real_mode permissions early Yinghai Lu
2013-01-04 20:15   ` Borislav Petkov
2013-01-04 20:58     ` Yinghai Lu
2013-01-04 21:04       ` Borislav Petkov
2013-01-04 22:13         ` Yinghai Lu
2013-01-05 13:25           ` Borislav Petkov
2013-01-07 12:40             ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 04/31] x86, 64bit, mm: add generic kernel/ident mapping helper Yinghai Lu
2013-01-04 21:19   ` Borislav Petkov
2013-01-04 22:19     ` Yinghai Lu
2013-01-05 13:21       ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 05/31] x86, 64bit: copy zero-page early Yinghai Lu
2013-01-07 15:53   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 06/31] x86, 64bit, realmode: use init_level4_pgt to set trapmoline_pgt directly Yinghai Lu
2013-01-04 17:18   ` Sakkinen, Jarkko
2013-01-04 22:01     ` Yinghai Lu
2013-01-05  9:59       ` Sakkinen, Jarkko
2013-01-07 15:54   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 07/31] x86, realmode: Separate real_mode reserve and setup Yinghai Lu
2013-01-04 17:18   ` Sakkinen, Jarkko [this message]
2013-01-07 15:54   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 08/31] x86, 64bit: early #PF handler set page table Yinghai Lu
2013-01-07 15:55   ` Borislav Petkov
2013-01-10  1:56     ` Yinghai Lu
2013-01-10 12:19       ` Borislav Petkov
2013-01-10 17:05         ` Yinghai Lu
2013-01-10 20:27           ` Borislav Petkov
2013-01-12 22:04             ` H. Peter Anvin
2013-01-04  0:48 ` [PATCH v7u1 09/31] x86, 64bit: #PF handler set page to cover 2M only Yinghai Lu
2013-01-09 22:57   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 10/31] x86, 64bit: Don't set max_pfn_mapped wrong value early on native path Yinghai Lu
2013-01-11 12:13   ` Borislav Petkov
2013-01-11 16:42     ` Yinghai Lu
2013-01-11 16:52       ` Borislav Petkov
2013-01-15 13:48   ` Stefano Stabellini
2013-01-15 15:22     ` Konrad Rzeszutek Wilk
2013-01-15 15:59       ` Stefano Stabellini
2013-01-15 16:37     ` Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 11/31] x86: Merge early_reserve_initrd for 32bit and 64bit Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 12/31] x86: add get_ramdisk_image/size() Yinghai Lu
2013-01-07 15:56   ` Borislav Petkov
2013-01-10  1:53     ` Yinghai Lu
2013-01-10 12:13       ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 13/31] x86, boot: add get_cmd_line_ptr() Yinghai Lu
2013-01-07 15:56   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 14/31] x86, boot: move checking of cmd_line_ptr out of common path Yinghai Lu
2013-01-07 16:00   ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 15/31] x86, boot: pass cmd_line_ptr with unsigned long instead Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 16/31] x86, boot: move verify_cpu.S and no_longmode down Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 17/31] x86, boot: Move lldt/ltr out of 64bit code section Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 18/31] x86, kexec: remove 1024G limitation for kexec buffer on 64bit Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 19/31] x86, kexec: set ident mapping for kernel that is above max_pfn Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 20/31] x86, kexec: replace ident_mapping_init and init_level4_page Yinghai Lu
2013-01-04 21:01   ` Borislav Petkov
2013-01-04 22:04     ` Yinghai Lu
2013-01-05 13:24       ` Borislav Petkov
2013-01-10  1:26         ` Yinghai Lu
2013-01-10 11:59           ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 21/31] x86, kexec: only set ident mapping for ram Yinghai Lu
2013-01-13 12:56   ` Borislav Petkov
2013-01-14  5:46     ` Yinghai Lu
2013-01-14  9:53       ` Borislav Petkov
2013-01-14 18:17         ` Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 22/31] x86, boot: add fields to support load bzImage and ramdisk above 4G Yinghai Lu
2013-01-13 21:41   ` Borislav Petkov
2013-01-14  5:37     ` Yinghai Lu
2013-01-14  9:43       ` Borislav Petkov
2013-01-14 23:06         ` Yinghai Lu
2013-01-14 17:49       ` H. Peter Anvin
2013-01-14 18:57         ` Yinghai Lu
2013-01-14 18:59           ` H. Peter Anvin
2013-01-14 19:19             ` Yinghai Lu
2013-01-14 19:50             ` Yinghai Lu
2013-01-14 19:56               ` H. Peter Anvin
2013-01-14 20:05                 ` Yinghai Lu
2013-01-15  6:17                   ` Yinghai Lu
2013-01-15 15:50                     ` Borislav Petkov
2013-01-15 16:03                       ` Yinghai Lu
2013-01-15 16:48                         ` Borislav Petkov
2013-01-15 18:43                           ` Yinghai Lu
2013-01-15 19:49                             ` Borislav Petkov
2013-01-15 20:16                               ` Yinghai Lu
2013-01-15 20:28                                 ` Borislav Petkov
2013-01-14 20:05           ` Borislav Petkov
2013-01-14 20:14             ` Yinghai Lu
2013-01-14 20:26               ` Borislav Petkov
2013-01-14 22:38                 ` Yinghai Lu
2013-01-14 23:11                   ` Borislav Petkov
2013-01-15  1:04                     ` Yinghai Lu
2013-01-14 23:10     ` H. Peter Anvin
2013-01-14 23:21       ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 23/31] x86, boot: update comments about entries for 64bit image Yinghai Lu
2013-01-14 11:20   ` Borislav Petkov
2013-01-14 18:35     ` Yinghai Lu
2013-01-14 18:37       ` Yinghai Lu
2013-01-14 18:46         ` Borislav Petkov
2013-01-14 20:01           ` Yinghai Lu
2013-01-14 18:43       ` Borislav Petkov
2013-01-04  0:48 ` [PATCH v7u1 24/31] x86, boot: Not need to check setup_header version for setup_data Yinghai Lu
2013-01-14 11:26   ` Borislav Petkov
2013-01-14 17:37     ` H. Peter Anvin
2013-01-14 18:04       ` Borislav Petkov
2013-01-14 18:42         ` H. Peter Anvin
2013-01-04  0:48 ` [PATCH v7u1 25/31] memblock: add memblock_mem_size() Yinghai Lu
2013-01-14 20:42   ` H. Peter Anvin
2013-01-14 22:28     ` Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 26/31] x86: Don't enable swiotlb if there is not enough ram for it Yinghai Lu
2013-01-04 16:05   ` Konrad Rzeszutek Wilk
2013-01-04 19:57     ` Yinghai Lu
2013-01-04 17:50   ` Shuah Khan
2013-01-04 20:34     ` Yinghai Lu
2013-01-04 21:02       ` Shuah Khan
2013-01-04 22:10         ` Yinghai Lu
2013-01-04 22:26           ` Shuah Khan
2013-01-04 22:34             ` Yinghai Lu
2013-01-04 22:47             ` Eric W. Biederman
2013-01-04 22:56               ` Shuah Khan
2013-01-04 23:00                 ` Yinghai Lu
2013-01-04 23:21                   ` Shuah Khan
2013-01-04 23:55                     ` Yinghai Lu
2013-01-05  2:02                       ` Shuah Khan
2013-01-05  4:10                         ` Yinghai Lu
2013-01-05 22:04                           ` Shuah Khan
2013-01-04 22:58               ` Yinghai Lu
2013-01-07 15:26           ` Konrad Rzeszutek Wilk
2013-01-07 17:02             ` Shuah Khan
2013-01-07 19:29               ` Konrad Rzeszutek Wilk
2013-01-08  2:22               ` Eric W. Biederman
2013-01-08  2:48                 ` Konrad Rzeszutek Wilk
2013-01-08  3:03                   ` Eric W. Biederman
2013-01-08  3:01                 ` Yinghai Lu
2013-01-08  3:13                   ` Eric W. Biederman
2013-01-08  3:50                     ` Yinghai Lu
2013-01-08 23:40                       ` Yinghai Lu
2013-01-09  0:04                         ` Eric W. Biederman
2013-01-09  0:43                         ` Konrad Rzeszutek Wilk
2013-01-09  0:56                           ` Yinghai Lu
2013-01-09  0:58                           ` Eric W. Biederman
2013-01-09  1:07                             ` Yinghai Lu
2013-01-09  1:12                               ` Yinghai Lu
2013-01-09  2:31                                 ` Eric W. Biederman
2013-01-09 13:24                                 ` Konrad Rzeszutek Wilk
2013-01-09 17:27                                   ` Yinghai Lu
2013-01-09 18:01                                     ` Shuah Khan
2013-01-09 19:13                                       ` Yinghai Lu
2013-01-09 21:00                                     ` Eric W. Biederman
2013-01-09 21:15                                       ` Yinghai Lu
2013-01-10 23:07                                         ` Yinghai Lu
2013-01-10 23:15                                           ` Eric W. Biederman
2013-01-10 23:55                                             ` Yinghai Lu
2013-01-11 16:35                                           ` Konrad Rzeszutek Wilk
2013-01-11 16:52                                             ` Yinghai Lu
2013-01-11 17:49                                               ` Yinghai Lu
2013-01-15  6:19                                                 ` Yinghai Lu
2013-01-18 15:55                                                   ` Konrad Rzeszutek Wilk
2013-01-24 15:39                                                     ` Konrad Rzeszutek Wilk
2013-01-24 16:51                                                       ` Shuah Khan
2013-01-24 19:22                                                         ` Shuah Khan
2013-01-24 21:50                                                           ` Yinghai Lu
2013-01-29  2:27                                                             ` Shuah Khan
2013-01-29  3:44                                                               ` Yinghai Lu
2013-01-31 19:28                                                                 ` Shuah Khan
2013-01-31 19:35                                                                   ` H. Peter Anvin
2013-01-09 13:12                             ` Konrad Rzeszutek Wilk
2013-01-07 20:32             ` Yinghai Lu
2013-01-07 21:30               ` Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 27/31] x86, kdump: remove crashkernel range find limit for 64bit Yinghai Lu
2013-01-14 15:43   ` Borislav Petkov
2013-01-14 18:18     ` Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 28/31] x86: add Crash kernel low reservation Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 29/31] x86: Merge early kernel reserve for 32bit and 64bit Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 30/31] x86, 64bit, mm: Mark data/bss/brk to nx Yinghai Lu
2013-01-04  0:48 ` [PATCH v7u1 31/31] x86, 64bit, mm: hibernate use generic mapping_init Yinghai Lu
2013-01-04 11:43   ` Rafael J. Wysocki
2013-01-04 21:59     ` Yinghai Lu
2013-01-04 22:07       ` Rafael J. Wysocki
2013-01-04  7:09 ` [PATCH v7u1 00/31] x86, boot, 64bit: Add support for loading ramdisk and bzImage above 4G Borislav Petkov
2013-01-04 21:44   ` Yinghai Lu
2013-01-14 20:45 ` H. Peter Anvin
2013-01-14 22:44   ` Yinghai Lu
2013-01-14 23:16     ` H. Peter Anvin
2013-01-14 23:39       ` David Woodhouse
2013-01-14 23:50         ` H. Peter Anvin
2013-01-15  0:12           ` David Woodhouse
2013-01-15 12:19 ` Stefano Stabellini
2013-01-15 16:43   ` Yinghai Lu
2013-01-15 19:28     ` Yinghai Lu
2013-01-16 11:32       ` Stefano Stabellini
2013-01-16 17:31         ` Yinghai Lu
2013-01-16 17:38           ` H. Peter Anvin
2013-01-16 18:20             ` Yinghai Lu
2013-01-17  2:35               ` Yinghai Lu

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=1357319845.7763.0.camel@jsakkine-mobl1 \
    --to=jarkko.sakkinen@intel.com \
    --cc=akpm@linux-foundation.org \
    --cc=bp@alien8.de \
    --cc=ebiederm@xmission.com \
    --cc=hpa@zytor.com \
    --cc=jan.kiszka@web.de \
    --cc=jason.wessel@windriver.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mingo@elte.hu \
    --cc=tglx@linutronix.de \
    --cc=yinghai@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;
as well as URLs for NNTP newsgroup(s).