/hg/release/icedtea-web-1.6: Fixed possible segfault during file...
Jiri Vanek
jvanek at redhat.com
Mon Oct 5 11:33:58 UTC 2015
>> static guint appletviewer_watch_id = -1;
>>
>> bool debug_initiated = false;
>> +bool file_logs_initiated = false;
>
> This exactly what I meant. There is no need for this. It does not add any logic nor is it correct.
How it can not be necessary? The methods in initFileLogs may log. And in debug mode the log always.
So they are crashing plugin.
> This makes me assume that you either did not read my post carefully enough or did not understand it.
Probably the second. Anyway following was spoken :
>> So I can proceed with original patch (+ above -FILE +FILe)? As sigsev was what
>> it was about to fix :)
>
> Yep, I think so.
So I took it as green light. Sorry for misunderstanding.
> Please remove this, as this does not add any program logic and is based on wrong assumptions.
Not unless better fix for "segfault because of logging during fileLogs initiation" is known.
>
>> int plugin_debug = getenv ("ICEDTEAPLUGIN_DEBUG") != NULL;
>> bool plugin_debug_headers = false;
>> bool plugin_debug_to_file = false ;
>> bool plugin_debug_to_streams = true ;
>> bool plugin_debug_to_system = false;
>> bool plugin_debug_to_console = true;
>> -FILE * plugin_file_log;
>> +FILE * plugin_file_log = NULL;
>> std::string plugin_file_log_name;
>>
>> int plugin_debug_suspend = (getenv("ICEDTEAPLUGIN_DEBUG") != NULL) &&
>> diff -r 75504136acda -r cbc3174bed98 plugin/icedteanp/IcedTeaNPPlugin.h
>> --- a/plugin/icedteanp/IcedTeaNPPlugin.h Tue Sep 22 18:24:33 2015 +0200
>> +++ b/plugin/icedteanp/IcedTeaNPPlugin.h Fri Oct 02 15:35:30 2015 +0200
>> @@ -117,6 +117,7 @@
>>
>> // debug switches
>> extern bool debug_initiated;
>> +extern bool file_logs_initiated;
>> extern int plugin_debug;
>> extern bool plugin_debug_headers;
>> extern bool plugin_debug_to_file;
>> diff -r 75504136acda -r cbc3174bed98 plugin/icedteanp/IcedTeaPluginUtils.h
>> --- a/plugin/icedteanp/IcedTeaPluginUtils.h Tue Sep 22 18:24:33 2015 +0200
>> +++ b/plugin/icedteanp/IcedTeaPluginUtils.h Fri Oct 02 15:35:30 2015 +0200
>> @@ -86,6 +86,7 @@
>> plugin_debug_to_console = is_java_console_enabled(); \
>> if (plugin_debug_to_file) { \
>> IcedTeaPluginUtilities::initFileLog(); \
>> + file_logs_initiated = true; \
>
> Again, you cannot assume that after IcedTeaPluginUtilities::initFileLog() has been called, the log
> file has been properly initialized.
But it des not meter. If they were not, then ITW will crash and it is OK.
(better debugging of this should bring the patch which is checking the io returns)
The fix with new variable is to avoid known reason of segfault - that ITW is trying to log to files,
during the preparation of themselves.
The logging in helper methods is good - they are reused several times.
>
>> } \
>> if (plugin_debug_to_console) { \
>> /*initialisation done during jvm startup*/ \
>> @@ -134,7 +135,7 @@
>> snprintf(ldebug_message, MESSAGE_SIZE, "%s%s", ldebug_header, ldebug_body); \
>> fprintf (stdout, "%s", ldebug_message);\
>> } \
>> - if (plugin_debug_to_file) { \
>> + if (plugin_debug_to_file && file_logs_initiated) { \
>> snprintf(ldebug_message, MESSAGE_SIZE, "%s%s", ldebug_header, ldebug_body); \
>> fprintf (plugin_file_log, "%s", ldebug_message); \
>> fflush(plugin_file_log); \
>> @@ -180,7 +181,7 @@
>> snprintf(ldebug_message, MESSAGE_SIZE, "%s%s", ldebug_header, ldebug_body); \
>> fprintf (stderr, "%s", ldebug_message); \
>> } \
>> - if (plugin_debug_to_file) { \
>> + if (plugin_debug_to_file && file_logs_initiated) { \
>> snprintf(ldebug_message, MESSAGE_SIZE, "%s%s", ldebug_header, ldebug_body); \
>> fprintf (plugin_file_log, "%s", ldebug_message); \
>> fflush(plugin_file_log); \
>>
More information about the distro-pkg-dev
mailing list