[ltt-dev] Updated TODO list before releasing LTTng bufferingtoLKML
Zhaolei
zhaolei at cn.fujitsu.com
Wed Oct 29 01:41:15 EDT 2008
* Zhaolei wrote:
>* Mathieu Desnoyers wrote:
>>> > - move ltt/ltt-marker-control.c /proc interface to debugfs
>>> > I think we should integrate its directory tree to the new LTTng tracer
>>> > debugfs API like this :
>>> >
>>> > /debugfs/ltt/events/buffer_name/marker_name/
>>> > where we find files like :
>>> > state
>>> > write : 1/0 (on/off)
>>> > read : 1/0 (on/off)
>>> > format
>>> > read : marker format string
>>> Hello, Mathieu,
>>>
>>> So we need to create a marker's debugfs-directory when user insmod
>>> a module with markers.
>>> But i think we don't have a callback when user insmod, and we
>>> should avoid to patch kernel/module.c for this kind of function.
>>>
>>> So, maybe we can only "echo marker_name 0/1" > marker-control.
>>> Dou you have suggestion for me?
>>>
>>
>>
>> Yes, we do have a callback in insmod.
>>
>> See :
>>
>> load_module()
>>
>> #ifdef CONFIG_MARKERS
>> if (!mod->taints)
>> marker_update_probe_range(mod->markers,
>> mod->markers + mod->num_markers);
>> #endif
>>
>> We would probably also have to get a callback in free_module to remove
>> the marker directory entry when the last marker reference is gone. The
>> same
>>
>> #ifdef CONFIG_MARKERS
>> if (!mod->taints)
>> marker_update_probe_range(mod->markers,
>> mod->markers + mod->num_markers);
>> #endif
>>
>> Could probably be used in free_module.
>>
> Do you means we insert another callback as markers do?
> as example in insmod:
> #ifdef CONFIG_MARKERS
> if (!mod->taints)
> marker_update_probe_range(mod->markers,
> mod->markers + mod->num_markers);
> #endif
> #ifdef CONFIG_LTT
> if (!mod->taints)
> lttctl_create_dirs(mod->markers,
> mod->markers + mod->num_markers);
> #endif
>
> It it is true, i think because ltt_control will be a kernel module, and we can't
> call a module's function in load_module().
>
> So, maybe we can do as following:
> 1: make module.c support callbackset.
> add following functions to module.c
> module_register_callback(enum MODULE_CALLBACK_TYPE type, callback_func func);
> module_unregister_callback(LOAD_MODULE, callback_func func);
Sorry for my mistake
module_unregister_callback(LOAD_MODULE, callback_func func);
-> module_unregister_callback(enum MODULE_CALLBACK_TYPE type, callback_func func);
>
> 2: make marks and ltt_control use new function
> example if ltt_control's
> init() {module_register_callback(LOAD_MODULE, create_debugfs_dir);}
> exit() {module_unregister_callback(LOAD_MODULE, free_debugfs_dir);}
> void create_debugfs_dir(struct module *mod) {
> for (i = 0; i < mod->num_markers; i++ )
> ...
> }
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
>
More information about the lttng-dev
mailing list