[ltt-dev] LTTng 2.0 on ARM

Avik Sil avik.sil at linaro.org
Tue Sep 13 07:16:35 EDT 2011


On Tuesday 13 September 2011 12:35 AM, Mathieu Desnoyers wrote:
> * Avik Sil (avik.sil at linaro.org) wrote:
>>
>>> Hi Avik,
>>>
>>> Can I get your kernel .config ? Also, adding a printk in lttng-modules
>>> wrapper/vmalloc.h, just after vmalloc_sync_all_sym = (void *)
>>> kallsyms_lookup_name("vmalloc_sync_all");
>>>
>>> printing the vmalloc_sync_all_sym pointer value would be clearly
>>> helpful. I would think ARM does not implement vmalloc_sync_all, so the
>>> dummy mm/vmalloc.c vmalloc_sync_all weak symbol should be used as a
>>> valid empty function. Please grep for vmalloc_sync_all under your
>>> arch/arm to see if your particular omap flavor is implementing a
>>> vmalloc_sync_all.
>>>
>> Hi Mathieu,
>>
>> Please find attached my kernel .config. After adding printk just after
>> vmalloc_sync_all_sym = (void *)kallsyms_lookup_name("vmalloc_sync_all");
>> I got following output:
>>
>> [ 1139.173522] vmalloc_sync_all_sym: c00a1d14
>> [ 1139.180877] Internal error: Oops - undefined instruction: 0 [#1]
>> PREEMPT SMP
>> [ 1139.191284] Modules linked in: lttng_ftrace(+)
>> [ 1139.198974] CPU: 1    Not tainted  (3.0.0-1004-linaro-omap #6)
>> [ 1139.208099] PC is at vmalloc_sync_all+0x0/0x8
>> [ 1139.215667] LR is at init_module+0x1c/0x28 [lttng_ftrace]
>> [ 1139.224304] pc : [<c00a1d14>]    lr : [<bf800211>]    psr: 60000113
>> [ 1139.224304] sp : ebb11f50  ip : 00000000  fp : 00000000
>> [ 1139.242401] r10: 00000000  r9 : 00000000  r8 : c06a2f00
>> [ 1139.250793] r7 : bf8001f5  r6 : 00000000  r5 : 00182008  r4 : c00a1d14
>> [ 1139.260559] r3 : 271aed1f  r2 : ebb11f44  r1 : bf8003a6  r0 : 00000034
>> [ 1139.270233] Flags: nZCv  IRQs on  FIQs on  Mode SVC_32  ISA ARM
>> Segment user
>> [ 1139.280670] Control: 50c5387d  Table: abdb004a  DAC: 00000015
>> [ 1139.289672] Process insmod (pid: 1368, stack limit = 0xebb102f8)
>> [ 1139.298889] Stack: (0xebb11f50 to 0xebb12000)
>> [ 1139.306335] 1f40:                                     bf80044c
>> c00085f7 00000000 00000001
>> [ 1139.320587] 1f60: bf80044c bf80044c 00182008 bf80044c 00182008
>> 00000000 000019de c000c364
>> [ 1139.334899] 1f80: ebb10000 c00622bb 00182018 000019de 00182008
>> 00000002 000019de beb099a0
>> [ 1139.349273] 1fa0: 00000080 c000c161 00000002 000019de 00182018
>> 000019de 00182008 402e6250
>> [ 1139.363861] 1fc0: 00000002 000019de beb099a0 00000080 00000003
>> 00004000 400b9000 00000000
>> [ 1139.378540] 1fe0: 00011f80 beb09728 00008c01 40296ae0 00000110
>> 00182018 a92aabaa aab0b0aa
>> [ 1139.393310] [<c00a1d14>] (vmalloc_sync_all+0x0/0x8) from [<bf800211>]
>> (init_module+0x1c/0x28 [lttng_ftrace])
>> [ 1139.410095] [<bf800211>] (init_module+0x1c/0x28 [lttng_ftrace]) from
>> [<c00085f7>] (do_one_initcall+0x6b/0xfc)
>> [ 1139.427032] [<c00085f7>] (do_one_initcall+0x6b/0xfc) from
>> [<c00622bb>] (sys_init_module+0x4b/0x11c)
>> [ 1139.443176] [<c00622bb>] (sys_init_module+0x4b/0x11c) from
>> [<c000c161>] (ret_fast_syscall+0x1/0x50)
>> [ 1139.459472] Code: e8bdb007 bf008ff0 c0672290 c0be2e54 (f85db500)
>> [ 1139.475524] ---[ end trace 7f9f02516cb400bf ]---
>> Segmentation fault
>>
>> Also I found that vmalloc_sync_all is not implemented under arch/arm and
>> it is using the mm/vmalloc.c vmalloc_sync_all weak symbol whose
>> disassembly gives:
>>
>> bx	lr
> 
> Hrm, weird. It's possibly some linker issue around the weak symbol, or
> the compiler does not generate the stub correctly. Can you look at the
> full dissassembly of the weak vmalloc_sync_all ? I would like to know
> the surrounding of 0xc00a1d14.
> 
> e.g.
> objdump -S --start-address=0xc00a1d14 vmlinux |head -n 30

I got following output:
# objdump -S --start-address=0xc00a1d14
/usr/lib/debug/boot/vmlinux-3.0.0-1004-linaro-omap | head -n 30

/usr/lib/debug/boot/vmlinux-3.0.0-1004-linaro-omap:     file format
elf32-littlearm


Disassembly of section .text:

c00a1d14 <vmalloc_sync_all>:
c00a1d14:	b500      	push	{lr}
c00a1d16:	f76a fa9d 	bl	c000c254 <__gnu_mcount_nc>
c00a1d1a:	4770      	bx	lr

c00a1d1c <pcpu_free_vm_areas>:
c00a1d1c:	e92d 41f0 	stmdb	sp!, {r4, r5, r6, r7, r8, lr}
c00a1d20:	b500      	push	{lr}
c00a1d22:	f76a fa97 	bl	c000c254 <__gnu_mcount_nc>
c00a1d26:	2500      	movs	r5, #0
c00a1d28:	4604      	mov	r4, r0
c00a1d2a:	460f      	mov	r7, r1
c00a1d2c:	4606      	mov	r6, r0
c00a1d2e:	e004      	b.n	c00a1d3a <pcpu_free_vm_areas+0x1e>
c00a1d30:	f856 0b04 	ldr.w	r0, [r6], #4
c00a1d34:	3501      	adds	r5, #1
c00a1d36:	f7ff fc9b 	bl	c00a1670 <free_vm_area>
c00a1d3a:	42bd      	cmp	r5, r7
c00a1d3c:	dbf8      	blt.n	c00a1d30 <pcpu_free_vm_areas+0x14>
c00a1d3e:	4620      	mov	r0, r4
c00a1d40:	e8bd 41f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, lr}
c00a1d44:	f004 b888 	b.w	c00a5e58 <kfree>

c00a1d48 <walk_pmd_range>:

> 
> We have to keep in mind that this could also be a ftrace function tracer
> bug, in which case the surrounding of 0xc00a1d14 from the vmlinux image
> will not match the instructions in memory. Can you dump the hex content
> around 0xc00a1d14 just before the vmalloc_sync_all gets called and
> compare with the disassembly ?

The hex content dump shows:

[  150.810119] c00a1d14: b500 f85d eb04 4770

So it seems your guess is right, the content of vmlinux image
surrounding 0xc00a1d14 is not matching the instruction in memory. By
grepping objdump I found that instruction 'f85d eb04' translates to
"ldr.w	lr, [sp], #4".

> 
> Also, another test: what happens if you put a "return;" at the beginning
> of the wrapper/vmalloc.h vmalloc_sync_all wrapper ?
>
By putting "return;" the vmalloc_sync_all wrapper behaves correctly
without any oops.

Regards,
Avik

> Thanks,
> 
> Mathieu
> 




More information about the lttng-dev mailing list