/hg/release/icedtea-web-1.6: Fixed possible segfault during file...

Jiri Vanek jvanek at redhat.com
Wed Oct 7 12:20:31 UTC 2015


On 10/05/2015 08:08 PM, Jacob Wisor wrote:
> On 10/05/2015 at 01:33 PM Jiri Vanek wrote:
>>>>   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.
>
> The cause for the plug-in to crash was an uninitialized file pointer, namely plugin_file_log, not a

no.

The crash was because of:
initFileLog calls:
get_log_dir which logs on error
and as addition get_log_dir calls create_dir which logs  on debug mode on.

The LAst one is the trouble maker, which caused segfault.when both file log and verbose/debug mode 
was on.


> missing additional variable. plugin_file_log did not get always properly initialized because
> initFileLog() assumed it to be always NULL before it has ever run. This was clearly a false
> assumption (because the value of an uninitialized variable in C/C++ is undefined). Now, that
> plugin_file_log is always initialized to NULL at load time, initFileLog()'s assumption has become
> correct. And, since initFileLog() now properly indicates the file log to have been initialized by
> setting plugin_debug_to_file to true, you do not need any additional logic or variables. If
> anything, always check the variable at stake, not a proxy variable before a function call.
> Just please take some time to think about it. Do not haste and do not start slapping around new
> variables just to make the problem go seemingly away.
>
>>> 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.
>
> Sorry, but you are obviously confused. The following two statements say nothing about the state of
> either the plugin_file_log file pointer nor the value of plugin_debug_to_file.

On contrary, yes, I must admit I'm confused:) And hoping a bit that you will post na patch making 
various IO in the plugin better or logging safer.
>
> IcedTeaPluginUtilities::initFileLog();
> file_logs_initiated = true;
>
> At best, all it says is that initFileLog() has been called. No other effects can be assumed, not
> even the value of plugin_debug_to_file.

As I repeated many times, and hoefully highlighted in this emial's first paragraph, tnothing else 
then "says is that initFileLog() has been called" is wonted.
>

Tahnx!
   J.



More information about the distro-pkg-dev mailing list