қоңырау ізі модульді Linux-қа жүктеу

Мен Linux ядроларының алғашқы модулін жазып жатырмын, ол жедел жадының дискісі плюс кейбір қосымша мүмкіндіктер. insmod модулін қолданып көргенімде, «Сегментация ақаулығы» орын алды.

Міне, сәйкесінше ядро ​​журналы, шын мәнінде екі дана ядро ​​туралы хабарламалар бар. Байланысты көптеген оқулықтарды оқығаннан кейін, менде осы журналға қатысты бірнеше сұрақтар бар:

1) Қоңырау іздерінің тізімінде сұрақ белгілерімен және онсыз берілген функциялар бар, «?» Сұрақ белгісінің ерекше мәні неде?

2) Қоңырау ізін түсінуім: төменгі функцияны қоспағанда, кез-келген функцияны оның астындағы функция шақыруы керек. Бірақ бұл үшін:

    [  397.855035]  [] ? exact_lock+0x0/0x16
    [  397.855035]  [] ? diag_init+0x252/0x4bd [b2bntb_diag]
    [  397.855035]  [] ? __blocking_notifier_call_chain+0x42/0x4d
    [  397.855035]  [] ? diag_init+0x0/0x4bd [b2bntb_diag]

diag_init мен жазған модуль init функциясы. Ол aniq_lock немесе __ blocking_notifier_call_chain деп аталатын кез-келген функцияны шақырмайды, бұл жерде екі функция қоңырау ізінде қалай пайда болады?

3) Қате неде және оны қалай шешуге болады?

BTW, мен жұмыс істейтін Linux ядросының 2.6.35.6 нұсқасы бар.

[  397.850955] ------------[ cut here ]------------
[  397.851544] WARNING: at lib/kobject.c:168 kobject_add_internal+0x3a/0x1e2()
[  397.851601] Hardware name: VirtualBox
[  397.851639] kobject: (f4580258): attempted to be registered with empty name!
[  397.851678] Modules linked in: b2bntb_diag(+) fuse vboxvideo drm sunrpc ip6t_REJECT nf_conntrack_ipv6 ip6table_filter ip6_tables ipv6 vboxsf uinput snd_intel8x0 snd_ac97_codec vboxguest ac97_bus snd_seq snd_seq_device ppdev snd_pcm parport_pc parport microcode snd_timer joydev snd e1000 i2c_piix4 soundcore i2c_core snd_page_alloc [last unloaded: mperf]
[  397.852707] Pid: 1958, comm: insmod Tainted: G        W   2.6.35.6-45.fc14.i686 #1
[  397.852749] Call Trace:
[  397.852828]  [] warn_slowpath_common+0x6a/0x7f
[  397.852970]  [] ? kobject_add_internal+0x3a/0x1e2
[  397.853130]  [] warn_slowpath_fmt+0x2b/0x2f
[  397.853182]  [] kobject_add_internal+0x3a/0x1e2
[  397.853235]  [] kobject_add+0x5b/0x66
[  397.853292]  [] device_add+0xda/0x4b6
[  397.853346]  [] ? kvasprintf+0x38/0x43
[  397.853394]  [] ? kobject_set_name_vargs+0x46/0x4c
[  397.853467]  [] register_disk+0x31/0x109
[  397.853528]  [] ? blk_register_region+0x20/0x25
[  397.853579]  [] add_disk+0x9f/0xf0
[  397.853627]  [] ? exact_match+0x0/0xd
[  397.853678]  [] ? exact_lock+0x0/0x16
[  397.853731]  [] diag_init+0x252/0x4bd [b2bntb_diag]
[  397.853785]  [] ? __blocking_notifier_call_chain+0x42/0x4d
[  397.853836]  [] ? diag_init+0x0/0x4bd [b2bntb_diag]
[  397.853889]  [] do_one_initcall+0x4f/0x139
[  397.853967]  [] ? blocking_notifier_call_chain+0x11/0x13
[  397.854086]  [] sys_init_module+0x7f/0x19b
[  397.854142]  [] syscall_call+0x7/0xb
[  397.854177] ---[ end trace 6dc509801197bdc3 ]---
[  397.855035] ------------[ cut here ]------------
[  397.855035] kernel BUG at fs/sysfs/group.c:65!
[  397.855035] invalid opcode: 0000 [#1] SMP
[  397.855035] last sysfs file: /sys/devices/LNXSYSTM:00/LNXSYBUS:00/PNP0A03:00/PNP0C0A:00/power_supply/BAT0/energy_full
[  397.855035] Modules linked in: b2bntb_diag(+) fuse vboxvideo drm sunrpc ip6t_REJECT nf_conntrack_ipv6 ip6table_filter ip6_tables ipv6 vboxsf uinput snd_intel8x0 snd_ac97_codec vboxguest ac97_bus snd_seq snd_seq_device ppdev snd_pcm parport_pc parport microcode snd_timer joydev snd e1000 i2c_piix4 soundcore i2c_core snd_page_alloc [last unloaded: mperf]
[  397.855035]
[  397.855035] Pid: 1958, comm: insmod Tainted: G        W   2.6.35.6-45.fc14.i686 #1 /VirtualBox
[  397.855035] EIP: 0060:[] EFLAGS: 00010246 CPU: 0
[  397.855035] EIP is at internal_create_group+0x23/0x103
[  397.855035] EAX: f4580258 EBX: f4580258 ECX: c09d4344 EDX: 00000000
[  397.855035] ESI: f60521f0 EDI: c09d4344 EBP: f45b7ef0 ESP: f45b7ed0
[  397.855035]  DS: 007b ES: 007b FS: 00d8 GS: 00e0 SS: 0068
[  397.855035] Process insmod (pid: 1958, ti=f45b6000 task=f3a68ca0 task.ti=f45b6000)
[  397.855035] Stack:
[  397.855035]  00000000 f45b7ee4 c05b08e0 8eecb04c f4580200 f4580200 f60521f0 f4580200
[  397.855035] <0> f45b7ef8 c0520e1c f45b7f00 c0498de9 f45b7f18 c05a261a f4580250 f4580200
[  397.855035] <0> 00000001 00000000 f45b7f38 c05a6b0f c05a5bff c05a603b f4580200 0fc00000
[  397.855035] Call Trace:
[  397.855035]  [] ? kobject_set_name_vargs+0x46/0x4c
[  397.855035]  [] ? sysfs_create_group+0x11/0x15
[  397.855035]  [] ? blk_trace_init_sysfs+0x10/0x12
[  397.855035]  [] ? blk_register_queue+0x3b/0xac
[  397.855035]  [] ? add_disk+0xa6/0xf0
[  397.855035]  [] ? exact_match+0x0/0xd
[  397.855035]  [] ? exact_lock+0x0/0x16
[  397.855035]  [] ? diag_init+0x252/0x4bd [b2bntb_diag]
[  397.855035]  [] ? __blocking_notifier_call_chain+0x42/0x4d
[  397.855035]  [] ? diag_init+0x0/0x4bd [b2bntb_diag]
[  397.855035]  [] ? do_one_initcall+0x4f/0x139
[  397.855035]  [] ? blocking_notifier_call_chain+0x11/0x13
[  397.855035]  [] ? sys_init_module+0x7f/0x19b
[  397.855035]  [] ? syscall_call+0x7/0xb
[  397.855035] Code: 8d 65 f4 5b 5e 5f 5d c3 55 89 e5 57 56 53 83 ec 14 0f 1f 44 00 00 85 c0 89 c3 89 55 e0 89 cf 74 0a 85 d2 75 08 83 78 18 00 75 11 <0f> 0b 83 78 18 00 be ea ff ff ff 0f 84 c5 00 00 00 8b 17 85 d2
[  397.855035] EIP: [] internal_create_group+0x23/0x103 SS:ESP 0068:f45b7ed0
[  397.865682] ---[ end trace 6dc509801197bdc4 ]---
[root@localhost ntb]#

14
задан Peter Mortensen 23 June 2011 в 20:44
поделиться