From: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v1 2/2] x86: zImage: Propagate acpi_rsdp_addr to kernel via boot parameters
Date: Fri, 12 Jan 2018 15:01:01 +0200 [thread overview]
Message-ID: <1515762061.7000.942.camel@linux.intel.com> (raw)
In-Reply-To: <CAEUhbmVokr8Y7wbdxzW9K7unJK35yVZKFtoOw6r6u7evrjXZog@mail.gmail.com>
On Fri, 2018-01-12 at 17:00 +0800, Bin Meng wrote:
> Hi Andy,
>
> On Thu, Jan 11, 2018 at 1:40 AM, Andy Shevchenko
> <andriy.shevchenko@linux.intel.com> wrote:
> > New field acpi_rsdp_addr, which has been introduced in boot protocol
> > v2.14 [1], in boot parameters tells kernel the exact address of RDSP
> > ACPI table. Knowing it increases robustness of the kernel by
> > avoiding
> > in some cases traversal through a part of physical memory.
> > It will slightly reduce boot time by the same reason.
> >
> > [1] See Linux kernel commit
> >
> > 2f74cbf947f4 ("x86/boot: Add the ACPI RSDP address to struct
> > setup_header::acpi_rdsp_addr")
>
> I don't see this commit id in my linux tree. Is this in some
> custodian's tree?
https://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git/commit/?id=2
f74cbf947f45fa082dda8eac1a1f1299a372f49
> > for the details.
> >
> > Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
> > ---
> > arch/x86/include/asm/bootparam.h | 1 +
> > arch/x86/lib/acpi_table.c | 7 +++++++
> > arch/x86/lib/acpi_table.h | 10 ++++++++++
> > arch/x86/lib/zimage.c | 6 ++++++
> > 4 files changed, 24 insertions(+)
> > create mode 100644 arch/x86/lib/acpi_table.h
> >
> > diff --git a/arch/x86/include/asm/bootparam.h
> > b/arch/x86/include/asm/bootparam.h
> > index 48b138c6b0..90768a99ce 100644
> > --- a/arch/x86/include/asm/bootparam.h
> > +++ b/arch/x86/include/asm/bootparam.h
> > @@ -66,6 +66,7 @@ struct setup_header {
> > __u64 pref_address;
> > __u32 init_size;
> > __u32 handover_offset;
> > + __u64 acpi_rsdp_addr;
> > } __attribute__((packed));
> >
> > struct sys_desc_table {
> > diff --git a/arch/x86/lib/acpi_table.c b/arch/x86/lib/acpi_table.c
> > index 7b33cd371e..45bfc111ef 100644
> > --- a/arch/x86/lib/acpi_table.c
> > +++ b/arch/x86/lib/acpi_table.c
> > @@ -20,6 +20,7 @@
> > #include <asm/mpspec.h>
> > #include <asm/tables.h>
> > #include <asm/arch/global_nvs.h>
> > +#include "acpi_table.h"
> >
> > /*
> > * IASL compiles the dsdt entries and writes the hex values
> > @@ -27,6 +28,11 @@
> > */
> > extern const unsigned char AmlCode[];
> >
> > +/*
> > + * ACPI RSDP address to be used in boot parameters.
> > + */
>
> nits: use single line comment format without the ending .
OK.
>
> > +unsigned long acpi_rsdp_addr;
> > +
> > static void acpi_write_rsdp(struct acpi_rsdp *rsdp, struct
> > acpi_rsdt *rsdt,
> > struct acpi_xsdt *xsdt)
> > {
> > @@ -460,6 +466,7 @@ ulong write_acpi_tables(ulong start)
> >
> > debug("current = %x\n", current);
> >
> > + acpi_rsdp_addr = (unsigned long)rsdp;
> > debug("ACPI: done\n");
> >
> > /* Don't touch ACPI hardware on HW reduced platforms */
> > diff --git a/arch/x86/lib/acpi_table.h b/arch/x86/lib/acpi_table.h
> > new file mode 100644
> > index 0000000000..cece5d1420
> > --- /dev/null
> > +++ b/arch/x86/lib/acpi_table.h
> > @@ -0,0 +1,10 @@
> > +/*
> > + * SPDX-License-Identifier: GPL-2.0
> > + */
> > +
> > +#ifndef _X86_LIB_ACPI_TABLES_H
> > +#define _X86_LIB_ACPI_TABLES_H
> > +
> > +extern unsigned long acpi_rsdp_addr;
> > +
> > +#endif
> > diff --git a/arch/x86/lib/zimage.c b/arch/x86/lib/zimage.c
> > index d224db4e07..eae26635b1 100644
> > --- a/arch/x86/lib/zimage.c
> > +++ b/arch/x86/lib/zimage.c
> > @@ -24,6 +24,7 @@
> > #include <asm/arch/timestamp.h>
> > #endif
> > #include <linux/compiler.h>
> > +#include "acpi_table.h"
> >
> > DECLARE_GLOBAL_DATA_PTR;
> >
> > @@ -255,6 +256,11 @@ int setup_zimage(struct boot_params
> > *setup_base, char *cmd_line, int auto_boot,
> > hdr->hardware_subarch = X86_SUBARCH_INTEL_MID;
> > #endif
> >
> > +#ifdef CONFIG_GENERATE_ACPI_TABLE
> > + if (bootproto >= 0x020e)
> > + hdr->acpi_rsdp_addr = acpi_rsdp_addr;
> > +#endif
> > +
> > setup_video(&setup_base->screen_info);
> >
> > return 0;
> > --
>
> Other than the above nits,
> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
>
> I can fix the nits when applying if you like.
If you have a chance to do it soon, please, do, otherwise I would send a
new version later (next week I suppose).
Thanks!
>
> Regards,
> Bin
--
Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Intel Finland Oy
next prev parent reply other threads:[~2018-01-12 13:01 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-01-10 17:40 [U-Boot] [PATCH v1 1/2] x86: zImage: Move subarch assignment out of cmd_line check Andy Shevchenko
2018-01-10 17:40 ` [U-Boot] [PATCH v1 2/2] x86: zImage: Propagate acpi_rsdp_addr to kernel via boot parameters Andy Shevchenko
2018-01-12 9:00 ` Bin Meng
2018-01-12 13:01 ` Andy Shevchenko [this message]
2018-01-15 2:33 ` Bin Meng
2018-01-30 12:50 ` Bin Meng
2018-06-16 23:22 ` Bin Meng
2018-06-18 9:22 ` Andy Shevchenko
2018-06-18 13:03 ` Bin Meng
2018-06-18 13:27 ` Andy Shevchenko
2018-06-18 13:52 ` Andy Shevchenko
2018-08-22 9:05 ` Bin Meng
2018-08-22 10:23 ` Andy Shevchenko
2018-01-12 9:00 ` [U-Boot] [PATCH v1 1/2] x86: zImage: Move subarch assignment out of cmd_line check Bin Meng
2018-01-15 2:33 ` Bin Meng
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=1515762061.7000.942.camel@linux.intel.com \
--to=andriy.shevchenko@linux.intel.com \
--cc=u-boot@lists.denx.de \
/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