page size change on MIPS

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

 



Hi All,

I observe one different behavior when we have page size set to 4KB or
16KB in kernel busybox receive argc[0] argument correct, but
when page size set to 64KB I am getting argv[0] as empty. So what may
be issue. I am using codesourcercy toolchain.

Kind regards




---------- Forwarded message ----------
From: naveen yadav <yad.naveen@xxxxxxxxx>
Date: Fri, Feb 4, 2011 at 9:46 AM
Subject: Re: page size change on MIPS
To: Ralf Baechle <ralf@xxxxxxxxxxxxxx>
Cc: kernelnewbies@xxxxxxxxxxxx, Himanshu Aggarwal
<lkml.himanshu@xxxxxxxxx>, David Daney <ddaney@xxxxxxxxxxxxxxxxxx>,
linux-mips@xxxxxxxxxxxxxx


Hi, I am adding readelf info also .

mips-linux-gnu-readelf -S squashfs-root/bin/busybox
There are 35 section headers, starting at offset 0x174290:

Section Headers:
 [Nr] Name              Type            Addr     Off    Size   ES Flg Lk Inf Al
 [ 0]                   NULL            00000000 000000 000000 00      0   0  0
 [ 1] .note.ABI-tag     NOTE            004000d4 0000d4 000020 00   A  0   0  4
 [ 2] .reginfo          MIPS_REGINFO    004000f4 0000f4 000018 18   A  0   0  4
 [ 3] .rel.dyn          REL             0040010c 00010c 000010 08   A  0   0  4
 [ 4] .init             PROGBITS        0040011c 00011c 00005c 00  AX  0   0  4
 [ 5] .text             PROGBITS        00400180 000180 11d2b0 00  AX  0   0 16
 [ 6] __libc_freeres_fn PROGBITS        0051d430 11d430 001368 00  AX  0   0  4
 [ 7] __libc_thread_fre PROGBITS        0051e798 11e798 000148 00  AX  0   0  4
 [ 8] .fini             PROGBITS        0051e8e0 11e8e0 000034 00  AX  0   0  4
 [ 9] .rodata           PROGBITS        0051e920 11e920 02d560 00   A  0   0 16
 [10] __libc_subfreeres PROGBITS        0054be80 14be80 000058 00   A  0   0  4
 [11] __libc_atexit     PROGBITS        0054bed8 14bed8 000004 00   A  0   0  4
 [12] __libc_thread_sub PROGBITS        0054bedc 14bedc 000008 00   A  0   0  4
 [13] .gcc_except_table PROGBITS        0054bee4 14bee4 0001fb 00   A  0   0  1
 [14] .eh_frame         PROGBITS        0055c0e0 14c0e0 002464 00  WA  0   0  4
 [15] .tdata            PROGBITS        0055e544 14e544 000018 00 WAT  0   0  4
 [16] .tbss             NOBITS          0055e55c 14e55c 000034 00 WAT  0   0  4
 [17] .ctors            PROGBITS        0055e55c 14e55c 000008 00  WA  0   0  4
 [18] .dtors            PROGBITS        0055e564 14e564 00000c 00  WA  0   0  4
 [19] .jcr              PROGBITS        0055e570 14e570 000004 00  WA  0   0  4
 [20] .data.rel.ro      PROGBITS        0055e574 14e574 000030 00  WA  0   0  4
 [21] .data             PROGBITS        0055e5b0 14e5b0 000b30 00  WA  0   0 16
 [22] .got              PROGBITS        0055f0e0 14f0e0 000148 04 WAp  0   0 16
 [23] .sdata            PROGBITS        0055f228 14f228 000004 00 WAp  0   0  4
 [24] .sbss             NOBITS          0055f230 14f22c 000184 00 WAp  0   0  8
 [25] .bss              NOBITS          0055f3c0 14f22c 00516c 00  WA  0   0 16
 [26] __libc_freeres_pt NOBITS          0056452c 14f22c 000040 00  WA  0   0  4
 [27] .pdr              PROGBITS        00000000 14f22c 016880 00      0   0  4
 [28] .comment          PROGBITS        00000000 165aac 0027e0 00      0   0  1
 [29] .debug_frame      MIPS_DWARF      00000000 16828c 00be88 00      0   0  4
 [30] .gnu.attributes   LOOS+ffffff5    00000000 174114 000010 00      0   0  1
 [31] .mdebug.abi32     PROGBITS        000030c0 174124 000000 00      0   0  1
 [32] .shstrtab         STRTAB          00000000 174124 00016c 00      0   0  1
 [33] .symtab           SYMTAB          00000000 174808 015320 10
34 2843  4
 [34] .strtab           STRTAB          00000000 189b28 012f65 00      0   0  1
Key to Flags:
 W (write), A (alloc), X (execute), M (merge), S (strings)
 I (info), L (link order), G (group), x (unknown)
 O (extra OS processing required) o (OS specific), p (processor specific)


On Fri, Feb 4, 2011 at 8:54 AM, naveen yadav <yad.naveen@xxxxxxxxx> wrote:
> thanaks a lot for your suggestion ..
>
>
> I debug this issue further, and here is my observations:
>
> 1. If I replace init with simple static link executable binary, this
> can be executed.
> 2. In case of busy-box, I debug the reason why init fails to excute.
>
> When I execute init command from busybox the control goes in main()
> function of busybox(appletlib.c) with argv value
> as the command you are suppose to execute, which in our case is init.
>
> But when i check argv is coming null when page size is 64KB and it
> comes init when page size is 16KB.
>
> This behaviour is very strange and i am still debugging this issue.
>
>
> I have check in Glibc, the max_page size it support is 64 KB in
> codesourcercy toolchain 4.4.1
>
> How can I check alignment issue as mention by Mr. Ralf Baechle.
>
>
>
> Kind regards
>
>
>
>
> On Mon, Jan 31, 2011 at 6:38 PM, Ralf Baechle <ralf@xxxxxxxxxxxxxx> wrote:
>> On Sun, Jan 30, 2011 at 08:32:43PM +0530, Himanshu Aggarwal wrote:
>>
>>> Why should the application or the toolchains depend on pagesize? I am
>>> not very clear on this. Can someone explain it?
>>
>> To allow loading directly with mmap the executable file's layout must
>> be such that it's it's segments are on offsets that are a multiple of
>> the page size so in turn the linker must know that alignment.
>>
>>  Ralf
>>
>

_______________________________________________
Kernelnewbies mailing list
Kernelnewbies@xxxxxxxxxxxxxxxxx
http://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies



[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux