ARCS can't load CONFIG_DEBUG_LOCK_ALLOC kernel

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



I've reported in the past that turning on CONFIG_DEBUG_LOCK_ALLOC produces a
kernel that can't boot on several SGI platforms.  It turns out that using
arcload (Stan's bootloader originally written for IP30), I can get some
debugging out on why.  I am still puzzled, but maybe this information can be
interpreted by someone else into something meaningful?

All addresses printed out of arcload are physical address.

ARCS Memory Map as printed by some debugging I added to the arcload binary:

0x00000000 - 0x00001000 ExceptionBlock
0x00001000 - 0x00002000 SystemParameterBlock
0x00002000 - 0x00004000 FirmwarePermanent
0x20004000 - 0x20f00000 FreeMemory***
0x20f00000 - 0x21000000 FirmwareTemporary
0x21000000 - 0x5fff0000 FreeMemory
0x5fff0000 - 0x5ffff000 LoadedProgram
0x5ffff000 - 0x60000000 FreeMemory
0x60000000 - 0xa0000000 FirmwarePermanent

The ***'ed FreeMemory segment is where the kernel is supposed to load.  Here's
the debugging for a kernel WITHOUT CONFIG_DEBUG_LOCK_ALLOC enabled (4102norm):

ELF Start: 0x20004000
Elf End  : 0x20a6fdd0
Size     : 0x00a6bdd0 (~10MB?)

# ls -l 4102norm
-rwxr-xr-x 1 root root 28M Mar 15 15:12 4102norm*


And the debugging kernel compiled with CONFIG_DEBUG_LOCK_ALLOC=y (no other
config changes from above):

ELF Start: 0x20004000
Elf End  : 0x2148bf80
Size     : 0x01487f80 (~20MB?)

# ls -l 4102dbg
-rwxr-xr-x 1 root root 29M Mar 15 15:21 4102dbg*


I am only using the traditional "vmlinux" make target, so there shouldn't be
any compression involved here.  Yet, it looks like, according to ARCS anyways,
that CONFIG_DEBUG_LOCK_ALLOC is adding an additional 10MB of "something", yet
the vmlinux file only grows by roughly 1MB.

If I examine both kernels with readelf and dump the program headers, I can see
these two sizes reflected under "MemSiz":

# mips64-unknown-linux-gnu-readelf -l 4102norm

Elf file type is EXEC (Executable file)
Entry point 0xa800000020700450
There are 2 program headers, starting at offset 64

Program Headers:
  Type           Offset             VirtAddr           PhysAddr
                 FileSiz            MemSiz              Flags  Align
  LOAD           0x0000000000004000 0xa800000020004000 0xa800000020004000
                 0x00000000009a5030 0x0000000000a6bdd0  RWE    10000
  NOTE           0x0000000000714bb0 0xa800000020714bb0 0xa800000020714bb0
                 0x0000000000000024 0x0000000000000024  R      4

# mips64-unknown-linux-gnu-readelf -l 4102dbg

Elf file type is EXEC (Executable file)
Entry point 0xa800000020749c80
There are 2 program headers, starting at offset 64

Program Headers:
  Type           Offset             VirtAddr           PhysAddr
                 FileSiz            MemSiz              Flags  Align
  LOAD           0x0000000000004000 0xa800000020004000 0xa800000020004000
                 0x0000000000a05850 0x0000000001487f80  RWE    10000
  NOTE           0x000000000075e330 0xa80000002075e330 0xa80000002075e330
                 0x0000000000000024 0x0000000000000024  R      4


So I'm not quite certain why ARCS or arcload dislike kernels with
CONFIG_DEBUG_LOCK_ALLOC=y.  This issue is known about on at least IP27 and IP30
platforms for the past few years, and it's been quite a hindrance in doing any
debugging of locks.

-- 
Joshua Kinard
Gentoo/MIPS
kumba@xxxxxxxxxx
6144R/F5C6C943 2015-04-27
177C 1972 1FB8 F254 BAD0 3E72 5C63 F4E3 F5C6 C943

"The past tempts us, the present confuses us, the future frightens us.  And our
lives slip away, moment by moment, lost in that vast, terrible in-between."

--Emperor Turhan, Centauri Republic




[Index of Archives]     [Linux MIPS Home]     [LKML Archive]     [Linux ARM Kernel]     [Linux ARM]     [Linux]     [Git]     [Yosemite News]     [Linux SCSI]     [Linux Hams]

  Powered by Linux