Inicializar o kernel de resgate no endereço de memória alta usando kexec no braço

3

Resumo: o Crashkernel é inicializado com 512MB de endereço na RAM com kexec -e/-l , mas não com kexec -p - por que?

Plataforma embarcada com Marvell Armada XP (MV78460) (ARMv7 com 4 núcleos) e 1GB de RAM.

  • kernel de produção: Linux customizado 3.4.91
  • kernel de resgate: clean kernel.org-Linux (4.2.3) (Estou ciente de que ele usa árvores de dispositivos, mas que funciona bem anexando o DTB ao zImage)
  • no espaço do usuário, estou usando o mais recente kexec-tools (2.0.10)

    Histórico: Usando kexec -l (com ramdisk e linha de comando params de 3.4.91-kernel e --atags ) e kexec -e , o kernel de resgate é inicializado bem e parece se colocar no início da RAM ( de acordo com /proc/iomem ), independentemente do que está sendo definido por meio de --mem-min e --mem-max . Ao reservar espaço na RAM usando a opção de inicialização crashkernel , eu tenho que usar um endereço de memória alta porque senão ele me diz que a área solicitada já está em uso. Então, definimos crashkernel=128M@512M . O kernel não inicializa com kexec -p .

    Status atual: Eu entendo que os kernels relocáveis ( CONFIG_AUTO_ZRELADDR=y ) devem residir nos 128 MB superiores, o que não é possível para nós. Por isso, trabalhei em torno da configuração padrão do kernel e forcei CONFIG_ARM_PATCH_PHYS_VIRT to no e CONFIG_PHYS_OFFSET to 0x20000000 . Eu tive que adicionar um Makefile.boot para a máquina onde eu defini zreladdr-y := 0x20008000, params_phys-y := 0x20000100, initrd_phys-y := 0x20800000 . Agora o kernel ainda é inicializado usando kexec -l e kexec -e e de acordo com --mem-min . Eu posso ver que é colocado em 512MB. No entanto, configurando-o com -p e causando um pânico, o console diz Loading crashdump kernel... Bye! e permanece em silêncio para sempre.

    Todos os arquivos e tudo são localizados apenas na RAM.

    O que eu poderia estar fazendo de errado? Devo me preocupar com os erros de descompressão (mesmo no bom caso)?

    From dmesg:
    Reserving 128MB of memory at 512MB for crashkernel (System RAM: 760MB)
    
    root@host:~# cat /proc/iomem
    00000000-3bff9fff : System RAM
      00008000-00724f43 : Kernel code
      0076e000-0087553f : Kernel data
      20000000-27ffffff : Crash kernel
    (some RAM at the end is reserved for persistent storage, that's why it doesn't add up to 1GB)
    

    Caso de sucesso:

    root@host:~# kexec -l -t zImage --command-line="console=ttyS0,38400 earlyprintk=ttyS0 root=/dev/ram rdinit=/sbin/init rw irqpoll maxcpus=1 reset_devices" --atags --initrd=./initramfs.cpio.gz -d --mem-min=0x20000000 --mem-max=0x28000000 ./zImage_fixed_addr
    Try gzip decompression.
    Try LZMA decompression.
    lzma_decompress_file: read on ./zImage_fixed_addr of 65536 bytes failed
    kernel: 0xb6c06008 kernel_size: 0x3db659
    kexec_load: entry = 0x20008000 flags = 0x280000
    nr_segments = 3
    segment[0].buf   = 0x40e98
    segment[0].bufsz = 0x3f0
    segment[0].mem   = 0x20001000
    segment[0].memsz = 0x1000
    segment[1].buf   = 0xb6c06008
    segment[1].bufsz = 0x3db659
    segment[1].mem   = 0x20008000
    segment[1].memsz = 0x3dc000
    segment[2].buf   = 0xb5ade008
    segment[2].bufsz = 0x1127516
    segment[2].mem   = 0x20f6e000
    segment[2].memsz = 0x1128000
    root@host:~# kexec -e
    Starting new kernel
    Booting Linux on physical CPU 0x0
    ...
    

    Depois da inicialização:

    root@vanilla:~# cat /proc/iomem
    20000000-3fffffff : System RAM
      20008000-206dd237 : Kernel code
      20720000-2078f54f : Kernel data
    

    Caso mal sucedido:

    root@host:~# kexec -p -t zImage --command-line="console=ttyS0,38400 earlyprintk=ttyS0 root=/dev/ram rdinit=/sbin/init rw irqpoll maxcpus=1 reset_devices" --atags --initrd=./initramfs.cpio.gz -d ./zImage_fixed_addr
    Try gzip decompression
    Try LZMA decompression.
    lzma_decompress_file: read on ./zImage_fixed_addr of 65536 bytes failed
    kernel: 0xb6b69008 kernel_size: 0x3db659
    phys_offset: 0
    kernel symbol _stext vaddr =         c0008240
    page_offset is set to c0000000
    get_crash_notes_per_cpu: crash_notes addr = 10f525c, size = 1024
    Elf header: p_type = 4, p_offset = 0x10f525c p_paddr = 0x10f525c p_vaddr = 0x0 p_filesz = 0x400 p_memsz = 0x400
    get_crash_notes_per_cpu: crash_notes addr = 10ff25c, size = 1024
    Elf header: p_type = 4, p_offset = 0x10ff25c p_paddr = 0x10ff25c p_vaddr = 0x0 p_filesz = 0x400 p_memsz = 0x400
    get_crash_notes_per_cpu: crash_notes addr = 110925c, size = 1024
    Elf header: p_type = 4, p_offset = 0x110925c p_paddr = 0x110925c p_vaddr = 0x0 p_filesz = 0x400 p_memsz = 0x400
    get_crash_notes_per_cpu: crash_notes addr = 111325c, size = 1024
    Elf header: p_type = 4, p_offset = 0x111325c p_paddr = 0x111325c p_vaddr = 0x0 p_filesz = 0x400 p_memsz = 0x400
    vmcoreinfo header: p_type = 4, p_offset = 0x7f1330 p_paddr = 0x7f1330 p_vaddr = 0x0 p_filesz = 0x1000 p_memsz = 0x1000
    Elf header: p_type = 1, p_offset = 0x0 p_paddr = 0x0 p_vaddr = 0xc0000000 p_filesz = 0x20000000 p_memsz = 0x20000000
    Elf header: p_type = 1, p_offset = 0x28000000 p_paddr = 0x28000000 p_vaddr = 0xe8000000 p_filesz = 0x13ffa000 p_memsz = 0x13ffa000
    elfcorehdr: 0x27f00000
    crashkernel: [0x20000000 - 0x27ffffff] (128M)
    memory range: [0 - 0x1fffffff] (512M)
    memory range: [0x28000000 - 0x3bff9fff] (319M)
    kernel command line: "console=ttyS0,38400 earlyprintk=ttyS0 root=/dev/ram rdinit=/sbin/init rw irqpoll maxcpus=1 reset_devices elfcorehdr=0x27f00000 mem=130048K"
    kexec_load: entry = 0x20008000 flags = 0x280001
    nr_segments = 4
    segment[0].buf   = 0x416e0
    segment[0].bufsz = 0x410
    segment[0].mem   = 0x20001000
    segment[0].memsz = 0x1000
    segment[1].buf   = 0xb6b69008
    segment[1].bufsz = 0x3db659
    segment[1].mem   = 0x20008000
    segment[1].memsz = 0x3dc000
    segment[2].buf   = 0xb5a41008
    segment[2].bufsz = 0x1127516
    segment[2].mem   = 0x20f6e000
    segment[2].memsz = 0x1128000
    segment[3].buf   = 0x412a0
    segment[3].bufsz = 0x400
    segment[3].mem   = 0x27f00000
    segment[3].memsz = 0x1000
    
    <cause crash via SysRq>
    
    Loading crashdump kernel...
    Bye!
    
        
  • por Hans W. Heckel 21.10.2015 / 08:49

    0 respostas