stas 2002/12/08 22:47:37 Modified: src/docs/2.0/devel/debug_c debug_c.pod Added: src/docs/2.0/devel/debug_c/code .debug-modperl-register Log: add another startup script which allows to break at the very early entrance to mod_perl Revision Changes Path 1.11 +13 -2 modperl-docs/src/docs/2.0/devel/debug_c/debug_c.pod Index: debug_c.pod =================================================================== RCS file: /home/cvs/modperl-docs/src/docs/2.0/devel/debug_c/debug_c.pod,v retrieving revision 1.10 retrieving revision 1.11 diff -u -r1.10 -r1.11 --- debug_c.pod 21 Jun 2002 17:26:20 -0000 1.10 +++ debug_c.pod 9 Dec 2002 06:47:37 -0000 1.11 @@ -216,13 +216,24 @@ =item * Debugging mod_perl Initialization The F<code/.debug-modperl-init> startup script breaks at the -modperl_hook_init() function, which is useful for debugging code at +C<modperl_hook_init()> function, which is useful for debugging code at the modperl's initialization phase. +=item * Debugging mod_perl's Hooks Registeration With httpd + +Similar to the previous startup script, the +F<code/.debug-modperl-register> startup script breaks at the +C<modperl_register_hooks()>, which is the very first hook called in +the mod_perl land. Therefore use this one if you need to start +debugging at an even earlier entry point into mod_perl. + +Refer to the notes inside the script to adjust it for a specific +I<httpd.conf> file. + =item * Debugging mod_perl XS Extensions The F<code/.debug-modperl-xs> startup script breaks at the -mpxs_Apache__Filter_print() function implemented in +C<mpxs_Apache__Filter_print()> function implemented in I<xs/Apache/Filter/Apache__Filter.h>. This is an example of debugging code in XS Extensions. For this particular example the complete test case is: 1.1 modperl-docs/src/docs/2.0/devel/debug_c/code/.debug-modperl-register Index: .debug-modperl-register =================================================================== # This gdb startup script allows to break at the very first invocation # of mod_perl initialization, just after it was loaded. When the # perl_module is loaded, and its pointer struct is added via # ap_add_module(), the first hook that will be called is # modperl_register_hooks(). # # Invoke as: # gdb -command=.debug-modperl-register # # see ADJUST notes for things that may need to be adjusted define sharedap sharedlibrary apr sharedlibrary aprutil #sharedlibrary mod_ssl.so end define sharedperl sharedlibrary libperl end ### Run ### # ADJUST: the path to the httpd executable if needed file ~/httpd/prefork/bin/httpd handle SIGPIPE nostop handle SIGPIPE pass set auto-solib-add 0 tbreak main # assuming that mod_dso is compiled in b load_module # ADJUST: the httpd.conf file's path if needed # ADJUST: add -DPERL_USEITHREADS to debug threaded mpms run -d `pwd`/t -f `pwd`/t/conf/httpd.conf \ -DONE_PROCESS -DNO_DETATCH -DAPACHE2 # skip over 'tbreak main' continue # In order to set the breakpoint in mod_perl.so, we need to get to # the point where it's loaded. # # With static mod_perl, the bp can be set right away # # With DSO mod_perl, mod_dso's load_module() loads the mod_perl.so # object and it immediately calls ap_add_module(), which calls # modperl_register_hooks(). So if we want to bp at the latter, we need # to stop at load_module(), set the 'bp modperl_register_hooks' and # then continue. # Assuming that 'LoadModule perl_module' is the first LoadModule # directive in httpd.conf, you need just one 'finish'. If it's not the # first you need as many 'finish' commands as the number of # 'LoadModule foo' before perl_module, plus one. # # If mod_perl is compiled statically, everything is already preloaded, # so you can set modperl_* the breakpoints right away b ap_add_module continue sharedlibrary modperl b modperl_register_hooks continue #b modperl_hook_init #b modperl_config_srv_create #b modperl_startup #b modperl_init_vhost #b modperl_dir_config #b modperl_cmd_load_module #modperl_config_apply_PerlModule # ADJUST: uncomment if you need to step through the code in apr libs #sharedap # ADJUST: uncomment if you need to step through the code in perlib #sharedperl
--------------------------------------------------------------------- To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED]