All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 00/19] arm64 kexec kernel patches v13
@ 2016-01-15 19:18 ` Geoff Levand
  0 siblings, 0 replies; 174+ messages in thread
From: Geoff Levand @ 2016-01-15 19:18 UTC (permalink / raw)
  To: linux-arm-kernel

This series adds the core support for kexec re-boot and kdump on ARM64.  This
version of the series combines Takahiro's kdump patches with my kexec patches.
Please consider all patches for inclusion.

I just tested all the endian combinations of kexec LE->LE, LE->BE, BE->BE,
BE->LE, and both LE an BE kdump, and all work as expected.

To load a second stage kernel and execute a kexec re-boot or to work with kdump
on ARM64 systems a series of patches to kexec-tools [2], which have not yet been
merged upstream, are needed.

To examine vmcore (/proc/vmcore), you should use
  - gdb v7.7 or later
  - crash v7.1.1 or later

[1]  https://git.kernel.org/cgit/linux/kernel/git/geoff/linux-kexec.git
[2]  https://git.kernel.org/cgit/linux/kernel/git/geoff/kexec-tools.git

Changes for v13 (Jan 15, 2016, 20m):

  o Rebase to Linux-4.4.
  o Remove align directive from cpu_reset.c.
  o Use inline C wrapper for cpu_soft_restart.
  o Revert the new image d-cache flush changes of v10.
  o Add SCTLR cleanup patch.
  o Change pr_devel to pr_debug.
  o Call flush_icache_range() for reboot_code_buffer.
  o Add .ltorg directive to arm64_relocate_new_kernel.
  o Make new asm macro copy_page.
  o Change cache maintenence from inner-shareable to non-shareable.
  o Rename KEXEC_ARCH_ARM64 to KEXEC_ARCH_AARCH64.

  o arm64: kvm: allows kvm cpu hotplug
    - remove some garbage code from kvm_host.h
  o arm64: kdump: reserve memory for crash dump kernel
    - change CONFIG_KEXEC to CONFIG_KEXEC_CORE
    - don't panic on crash kernel alloc failure
      (thanks to Mark Salter, RH)
  o arm64: kdump: implement machine_crash_shutdown()
    - change "boot/non-boot cpu" to "crashing/non-crashing cpu"
    - introduce is_in_crash_kexec() for readability
    - re-introduce machine_kexec_mask_interrupts(), as arch/arm has,
      to discard unexpected interrupts
    - call crash_save_cpu() before making cpus offline to avoid a possible race
      (thanks to Pratyush Anand/Mark Salter, RH)
  o arm64: kdump: update a kernel doc
    - clarify that we support "Image" format as well as vmlinux in kdump.txt
  o arm64: kdump: relax BUG_ON() if more than one cpus are still active
    - change a warning message at the failure of shooting down non-crahsing cpus

Changes for v12 (Nov 24, 2015, 18m):

  o No changes, rebase to Linux-4.4-rc2.

Changes for v11 (Nov 6, 2015, 18m):

  o Rebase to Linux-4.3.
  o Move the new image d-cache flush from arm64_relocate_new_kernel to machine_kexec.
  o Pass values to arm64_relocate_new_kernel in registers, not in global variables.
  o Fixups to setting the sctlr_el1 and sctlr_el2 flags.

Changes for v10 (Oct 18, 2015, 17m):

  o Rebase to Linux-4.3-rc6.
  o Move tcr_set_idmap_t0sz to assembler.h.
  o Add back simplified cpu_reset routines.
  o Combine kexec + kdump patches.

Changes for v9 (Apr 7, 2015, 11m):

  o Use new upstream flag IND_FLAGS.

Changes for v8 (Mar 19, 2015, 10m):

  o Rebase to Linux-4.0-rc4.
  o Re-boot using purgatory only.

Changes for v7 (Jan 16, 2015, 8m):

  o Rebase to Linux-3.19-rc4.
  o Change from ESR_EL2_ to ESR_ELx_.
  o Remove work-arounds for EFI systems.
  
Changes for v6 (Dec 2, 2014, 7m):

  o Rebase to Linux-3.18-rc2

Changes for v5 (Nov 16, 2014, 6m):

Changes for v4 (Oct 3, 2014, 5m):

Changes for v3 (Sept 23, 2014, 4m):

Changes for v2 (Sep 9, 2014, 4m):

  o Rebase to Linux-3.17-rc4.
  o Move macros from proc-macros.S to assembler.h.
  o Convert hcalls to use ISS field.
  o Add new hcall HVC_CALL_FUNC.
  o Add EL2 switch to soft_restart.

First submission v1 (May 13, 2014):

  o Based on Linux-3.15-rc4.

-Geoff

The following changes since commit afd2ff9b7e1b367172f18ba7f693dfb62bdcb2dc:

  Linux 4.4 (2016-01-10 15:01:32 -0800)

are available in the git repository at:

  git://git.kernel.org/pub/scm/linux/kernel/git/geoff/linux-kexec.git kexec-v13

for you to fetch changes up to e52b39c76d2a967bdecc376daee07d6edd47b01a:

  arm64: kdump: relax BUG_ON() if more than one cpus are still active (2016-01-15 10:22:45 -0800)

----------------------------------------------------------------
AKASHI Takahiro (7):
      arm64: kvm: allows kvm cpu hotplug
      arm64: kdump: reserve memory for crash dump kernel
      arm64: kdump: implement machine_crash_shutdown()
      arm64: kdump: add kdump support
      arm64: kdump: enable kdump in the arm64 defconfig
      arm64: kdump: update a kernel doc
      arm64: kdump: relax BUG_ON() if more than one cpus are still active

Geoff Levand (11):
      arm64: Fold proc-macros.S into assembler.h
      arm64: Add new asm macro copy_page
      arm64: Cleanup SCTLR flags
      arm64: Convert hcalls to use HVC immediate value
      arm64: Add new hcall HVC_CALL_FUNC
      arm64: Add back cpu_reset routines
      Revert "arm64: mm: remove unused cpu_set_idmap_tcr_t0sz function"
      Revert "arm64: remove dead code"
      arm64/kexec: Add core kexec support
      arm64/kexec: Enable kexec in the arm64 defconfig
      arm64/kexec: Add pr_debug output

James Morse (1):
      arm64: kernel: Include _AC definition in page.h

 Documentation/kdump/kdump.txt        |  23 ++-
 arch/arm/include/asm/kvm_host.h      |  10 +-
 arch/arm/include/asm/kvm_mmu.h       |   1 +
 arch/arm/kvm/arm.c                   |  93 +++++++-----
 arch/arm/kvm/mmu.c                   |   5 +
 arch/arm64/Kconfig                   |  21 +++
 arch/arm64/configs/defconfig         |   2 +
 arch/arm64/include/asm/assembler.h   |  67 +++++++-
 arch/arm64/include/asm/kexec.h       |  93 ++++++++++++
 arch/arm64/include/asm/kvm_arm.h     |  11 --
 arch/arm64/include/asm/kvm_host.h    |  11 +-
 arch/arm64/include/asm/kvm_mmu.h     |   1 +
 arch/arm64/include/asm/mmu.h         |   1 +
 arch/arm64/include/asm/mmu_context.h |  35 +++--
 arch/arm64/include/asm/page.h        |   2 +
 arch/arm64/include/asm/sysreg.h      |  19 ++-
 arch/arm64/include/asm/virt.h        |  49 ++++++
 arch/arm64/kernel/Makefile           |   3 +
 arch/arm64/kernel/cpu-reset.S        |  57 +++++++
 arch/arm64/kernel/cpu-reset.h        |  29 ++++
 arch/arm64/kernel/crash_dump.c       |  71 +++++++++
 arch/arm64/kernel/hyp-stub.S         |  43 ++++--
 arch/arm64/kernel/machine_kexec.c    | 285 +++++++++++++++++++++++++++++++++++
 arch/arm64/kernel/relocate_kernel.S  | 131 ++++++++++++++++
 arch/arm64/kernel/setup.c            |   7 +-
 arch/arm64/kernel/smp.c              |  18 ++-
 arch/arm64/kvm/hyp-init.S            |  39 ++++-
 arch/arm64/kvm/hyp.S                 |  44 ++++--
 arch/arm64/mm/cache.S                |   2 -
 arch/arm64/mm/init.c                 |  89 +++++++++++
 arch/arm64/mm/mmu.c                  |  11 ++
 arch/arm64/mm/proc-macros.S          |  64 --------
 arch/arm64/mm/proc.S                 |   3 -
 include/uapi/linux/kexec.h           |   1 +
 34 files changed, 1175 insertions(+), 166 deletions(-)
 create mode 100644 arch/arm64/include/asm/kexec.h
 create mode 100644 arch/arm64/kernel/cpu-reset.S
 create mode 100644 arch/arm64/kernel/cpu-reset.h
 create mode 100644 arch/arm64/kernel/crash_dump.c
 create mode 100644 arch/arm64/kernel/machine_kexec.c
 create mode 100644 arch/arm64/kernel/relocate_kernel.S
 delete mode 100644 arch/arm64/mm/proc-macros.S

-- 
2.5.0

^ permalink raw reply	[flat|nested] 174+ messages in thread

end of thread, other threads:[~2016-03-02 16:51 UTC | newest]

Thread overview: 174+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-01-15 19:18 [PATCH 00/19] arm64 kexec kernel patches v13 Geoff Levand
2016-01-15 19:18 ` Geoff Levand
2016-01-15 19:18 ` [PATCH 07/19] arm64: Add back cpu_reset routines Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 03/19] arm64: Add new asm macro copy_page Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-20 14:01   ` James Morse
2016-01-20 14:01     ` James Morse
2016-01-15 19:18 ` [PATCH 05/19] arm64: Convert hcalls to use HVC immediate value Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 02/19] arm64: kernel: Include _AC definition in page.h Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-18 10:05   ` Mark Rutland
2016-01-18 10:05     ` Mark Rutland
2016-01-15 19:18 ` [PATCH 09/19] Revert "arm64: remove dead code" Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:55   ` Mark Rutland
2016-01-15 19:55     ` Mark Rutland
2016-01-20 21:18     ` Geoff Levand
2016-01-20 21:18       ` Geoff Levand
2016-01-15 19:18 ` [PATCH 04/19] arm64: Cleanup SCTLR flags Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 20:07   ` Mark Rutland
2016-01-15 20:07     ` Mark Rutland
2016-01-18 10:12     ` Marc Zyngier
2016-01-18 10:12       ` Marc Zyngier
2016-01-19 11:59       ` Dave Martin
2016-01-19 11:59         ` Dave Martin
2016-01-25 15:09   ` James Morse
2016-01-25 15:09     ` James Morse
2016-01-15 19:18 ` [PATCH 08/19] Revert "arm64: mm: remove unused cpu_set_idmap_tcr_t0sz function" Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 01/19] arm64: Fold proc-macros.S into assembler.h Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 06/19] arm64: Add new hcall HVC_CALL_FUNC Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 17/19] arm64: kdump: enable kdump in the arm64 defconfig Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 15/19] arm64: kdump: implement machine_crash_shutdown() Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 19/19] arm64: kdump: relax BUG_ON() if more than one cpus are still active Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 12/19] arm64/kexec: Enable kexec in the arm64 defconfig Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 18/19] arm64: kdump: update a kernel doc Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 20:16   ` Mark Rutland
2016-01-15 20:16     ` Mark Rutland
2016-01-18 10:26     ` AKASHI Takahiro
2016-01-18 10:26       ` AKASHI Takahiro
2016-01-18 11:29       ` Mark Rutland
2016-01-18 11:29         ` Mark Rutland
2016-01-19  5:31         ` AKASHI Takahiro
2016-01-19  5:31           ` AKASHI Takahiro
2016-01-19 12:10           ` Mark Rutland
2016-01-19 12:10             ` Mark Rutland
2016-01-20  4:34             ` AKASHI Takahiro
2016-01-20  4:34               ` AKASHI Takahiro
2016-01-19  1:43       ` Dave Young
2016-01-19  1:43         ` Dave Young
2016-01-19  1:50         ` Dave Young
2016-01-19  1:50           ` Dave Young
2016-01-19  5:35         ` AKASHI Takahiro
2016-01-19  5:35           ` AKASHI Takahiro
2016-01-19 12:28           ` Dave Young
2016-01-19 12:28             ` Dave Young
2016-01-19 12:51             ` Mark Rutland
2016-01-19 12:51               ` Mark Rutland
2016-01-19 13:45               ` Dave Young
2016-01-19 13:45                 ` Dave Young
2016-01-19 14:01                 ` Mark Rutland
2016-01-19 14:01                   ` Mark Rutland
2016-01-20  2:49                   ` Dave Young
2016-01-20  2:49                     ` Dave Young
2016-01-20  6:07                     ` AKASHI Takahiro
2016-01-20  6:07                       ` AKASHI Takahiro
2016-01-20  6:38                       ` Dave Young
2016-01-20  6:38                         ` Dave Young
2016-01-20  7:00                         ` Dave Young
2016-01-20  7:00                           ` Dave Young
2016-01-20  8:01                           ` AKASHI Takahiro
2016-01-20  8:01                             ` AKASHI Takahiro
2016-01-20  8:26                             ` Dave Young
2016-01-20  8:26                               ` Dave Young
2016-01-20 11:54                         ` Mark Rutland
2016-01-20 11:54                           ` Mark Rutland
2016-01-21  2:57                           ` Dave Young
2016-01-21  2:57                             ` Dave Young
2016-01-21  3:03                           ` Dave Young
2016-01-21  3:03                             ` Dave Young
2016-01-20 11:49                       ` Mark Rutland
2016-01-20 11:49                         ` Mark Rutland
2016-01-21  6:53                         ` AKASHI Takahiro
2016-01-21  6:53                           ` AKASHI Takahiro
2016-01-21 12:02                           ` Mark Rutland
2016-01-21 12:02                             ` Mark Rutland
2016-01-22  6:23                             ` AKASHI Takahiro
2016-01-22  6:23                               ` AKASHI Takahiro
2016-01-22 11:13                               ` Mark Rutland
2016-01-22 11:13                                 ` Mark Rutland
2016-02-02  5:18                                 ` AKASHI Takahiro
2016-02-02  5:18                                   ` AKASHI Takahiro
2016-01-25  3:19                               ` Dave Young
2016-01-25  3:19                                 ` Dave Young
2016-01-25  4:23                                 ` Dave Young
2016-01-25  4:23                                   ` Dave Young
2016-01-20 11:28                     ` Mark Rutland
2016-01-20 11:28                       ` Mark Rutland
2016-01-21  2:54                       ` Dave Young
2016-01-21  2:54                         ` Dave Young
2016-01-20  5:25                   ` AKASHI Takahiro
2016-01-20  5:25                     ` AKASHI Takahiro
2016-01-20 12:02                     ` Mark Rutland
2016-01-20 12:02                       ` Mark Rutland
2016-01-20 12:36                       ` Mark Rutland
2016-01-20 12:36                         ` Mark Rutland
2016-01-20 14:59                         ` Ard Biesheuvel
2016-01-20 14:59                           ` Ard Biesheuvel
2016-01-20 15:04                           ` Mark Rutland
2016-01-20 15:04                             ` Mark Rutland
2016-01-21  5:43                           ` AKASHI Takahiro
2016-01-21  5:43                             ` AKASHI Takahiro
2016-01-21 13:02                             ` Mark Rutland
2016-01-21 13:02                               ` Mark Rutland
2016-01-19 12:17         ` Mark Rutland
2016-01-19 12:17           ` Mark Rutland
2016-01-19 13:52           ` Dave Young
2016-01-19 13:52             ` Dave Young
2016-01-19 14:05             ` Mark Rutland
2016-01-19 14:05               ` Mark Rutland
2016-01-20  2:54               ` Dave Young
2016-01-20  2:54                 ` Dave Young
2016-01-15 19:18 ` [PATCH 10/19] arm64: kvm: allows kvm cpu hotplug Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-26 17:42   ` James Morse
2016-01-26 17:42     ` James Morse
2016-01-27  7:37     ` AKASHI Takahiro
2016-01-27  7:37       ` AKASHI Takahiro
2016-01-15 19:18 ` [PATCH 14/19] arm64: kdump: reserve memory for crash dump kernel Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 11/19] arm64/kexec: Add core kexec support Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 13/19] arm64/kexec: Add pr_debug output Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-15 19:18 ` [PATCH 16/19] arm64: kdump: add kdump support Geoff Levand
2016-01-15 19:18   ` Geoff Levand
2016-01-21 14:17   ` James Morse
2016-01-21 14:17     ` James Morse
2016-01-22  4:50     ` AKASHI Takahiro
2016-01-22  4:50       ` AKASHI Takahiro
2016-01-19 12:32 ` [PATCH 00/19] arm64 kexec kernel patches v13 Dave Young
2016-01-19 12:32   ` Dave Young
2016-01-20  0:15   ` Geoff Levand
2016-01-20  0:15     ` Geoff Levand
2016-01-20  2:56     ` Dave Young
2016-01-20  2:56       ` Dave Young
2016-01-20 21:15       ` Geoff Levand
2016-01-20 21:15         ` Geoff Levand
2016-01-21 12:11       ` Mark Rutland
2016-01-21 12:11         ` Mark Rutland
     [not found] ` <c7575f853ccc491bb0212e025aab1cc9@NASANEXM01H.na.qualcomm.com>
2016-03-01 17:54   ` Azriel Samson
2016-03-01 17:54     ` Azriel Samson
2016-03-02  1:17     ` Geoff Levand
2016-03-02  1:17       ` Geoff Levand
2016-03-02  1:38       ` Will Deacon
2016-03-02  1:38         ` Will Deacon
2016-03-02  2:28         ` AKASHI Takahiro
2016-03-02  2:28           ` AKASHI Takahiro
2016-03-02  8:07       ` Marc Zyngier
2016-03-02  8:07         ` Marc Zyngier
2016-03-02 12:33     ` Pratyush Anand
2016-03-02 12:33       ` Pratyush Anand
2016-03-02 16:51       ` Azriel Samson
2016-03-02 16:51         ` Azriel Samson

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.