WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED INVALID
175855
[GTK] Segfault on WebView run_javascript() function from Python thread
https://bugs.webkit.org/show_bug.cgi?id=175855
Summary
[GTK] Segfault on WebView run_javascript() function from Python thread
luke
Reported
2017-08-22 15:27:45 PDT
Created
attachment 318810
[details]
Test case to reproduce the issue Hi there. In a recent library update, a Python WebKitGTK application now runs into a segfault when invoking the run_javascript() function from a Python thread (via the threading module). This is a regression as this didn't occur in previous versions and crashes web applications for the desktop, such as ubuntu-mate-welcome. Confirmed a problem ========================== WebKit2GTK Version: 2.17.91-1ubuntu1 Python version: 3.6.2 Ubuntu version: 17.10 Alpha 2 Last known good version ========================== WebKit2GTK Version: 2.16.6-0ubuntu0.16.04.1 Python version: 3.5.2 Ubuntu version: 16.04.3 LTS A test case has been attached to reproduce this issue. It creates a simple GTK window with WebView, and invokes run_javascript() to run "window.alert" but will be invoked from a new thread. In Ubuntu 16.04, this executes the JavaScript "window.alert()" successfully, but in Ubuntu 17.10, this will produce a segfault and crash the application. The segfault as follows: ------------------------------------------------------ 1 0x7fed43b7f287 /usr/lib/x86_64-linux-gnu/libjavascriptcoregtk-4.0.so.18(WTFCrash+0x17) [0x7fed43b7f287] 2 0x7fed4cb90cca /usr/lib/x86_64-linux-gnu/libwebkit2gtk-4.0.so.37(+0x63dcca) [0x7fed4cb90cca] 3 0x7fed4cb8582c /usr/lib/x86_64-linux-gnu/libwebkit2gtk-4.0.so.37(+0x63282c) [0x7fed4cb8582c] 4 0x7fed4cd5d463 /usr/lib/x86_64-linux-gnu/libwebkit2gtk-4.0.so.37(webkit_web_view_run_javascript+0xc3) [0x7fed4cd5d463] 5 0x7fed607e0e18 /usr/lib/x86_64-linux-gnu/libffi.so.6(ffi_call_unix64+0x4c) [0x7fed607e0e18] 6 0x7fed607e087a /usr/lib/x86_64-linux-gnu/libffi.so.6(ffi_call+0x32a) [0x7fed607e087a] 7 0x7fed611ce9cc /usr/lib/python3/dist-packages/gi/_gi.cpython-36m-x86_64-linux-gnu.so(+0x2b9cc) [0x7fed611ce9cc] 8 0x7fed611d04b8 /usr/lib/python3/dist-packages/gi/_gi.cpython-36m-x86_64-linux-gnu.so(+0x2d4b8) [0x7fed611d04b8] 9 0x7fed611c4209 /usr/lib/python3/dist-packages/gi/_gi.cpython-36m-x86_64-linux-gnu.so(+0x21209) [0x7fed611c4209] 10 0x4591b3 /usr/bin/python3(_PyObject_FastCallDict+0xa3) [0x4591b3] 11 0x54e607 /usr/bin/python3() [0x54e607] 12 0x552f9b /usr/bin/python3(_PyEval_EvalFrameDefault+0x36ab) [0x552f9b] 13 0x54e4b1 /usr/bin/python3() [0x54e4b1] 14 0x54f45f /usr/bin/python3(PyEval_EvalCodeEx+0x2f) [0x54f45f] 15 0x48b41d /usr/bin/python3() [0x48b41d] 16 0x458fbe /usr/bin/python3(PyObject_Call+0x3e) [0x458fbe] 17 0x551497 /usr/bin/python3(_PyEval_EvalFrameDefault+0x1ba7) [0x551497] 18 0x54da88 /usr/bin/python3() [0x54da88] 19 0x54e9e6 /usr/bin/python3() [0x54e9e6] 20 0x552f9b /usr/bin/python3(_PyEval_EvalFrameDefault+0x36ab) [0x552f9b] 21 0x54da88 /usr/bin/python3() [0x54da88] 22 0x54e9e6 /usr/bin/python3() [0x54e9e6] 23 0x552f9b /usr/bin/python3(_PyEval_EvalFrameDefault+0x36ab) [0x552f9b] 24 0x54da88 /usr/bin/python3() [0x54da88] 25 0x55772e /usr/bin/python3(_PyFunction_FastCallDict+0x2be) [0x55772e] 26 0x459531 /usr/bin/python3(_PyObject_Call_Prepend+0x231) [0x459531] 27 0x458fbe /usr/bin/python3(PyObject_Call+0x3e) [0x458fbe] 28 0x58db52 /usr/bin/python3() [0x58db52] 29 0x7fed62d7a74a /lib/x86_64-linux-gnu/libpthread.so.0(+0x774a) [0x7fed62d7a74a] 30 0x7fed61f43caf /lib/x86_64-linux-gnu/libc.so.6(clone+0x3f) [0x7fed61f43caf] Segmentation fault ------------------------------------------------------
Attachments
Test case to reproduce the issue
(975 bytes, text/x-python)
2017-08-22 15:27 PDT
,
luke
no flags
Details
View All
Add attachment
proposed patch, testcase, etc.
davidmohammed
Comment 1
2017-08-23 10:27:33 PDT
phew - thanks for filing this Luke. I thought I was going mad! Can confirm this with budgie-welcome - Ubuntu Budgie 17.10
Michael Catanzaro
Comment 2
2017-08-28 07:34:41 PDT
In the future please use the WebKitGTK+ component or we won't notice your bugs. Someone pinged me about this one on IRC!
Michael Catanzaro
Comment 3
2017-08-28 07:49:17 PDT
I can reproduce. It works fine with Fedora's 2.16.6 but fails with trunk built in JHBuild. It's interesting that the behavior changed from one WebKit version to the next, but your code is illegal and it's just luck that it ever worked. You can't use GTK+ except on the thread you initialized it on (usually the main thread), because it's not threadsafe. Same goes for WebKit and most GNOME-related libraries. It might work on your computer, but users could be getting crashes or weird problems. The fix is to post actions you want to take to the main thread, e.g. using GLib.idle_add. For example: def run_js(i): webkit.run_javascript("window.alert('It works!')") print("Successfully ran Javascript!") return GLib.SOURCE_REMOVE # Now create a thread def threaded_function(): print("Sleeping on thread for 2 seconds") sleep(2) print("Going to run Javascript...") GLib.idle_add(run_js, None) That works without crashing for me. Hope that helps.
Michael Catanzaro
Comment 4
2017-08-28 07:51:19 PDT
(In reply to Michael Catanzaro from
comment #3
)
> def run_js(i):
Should be def run_js():. I was messing around. ;)
Michael Catanzaro
Comment 5
2017-08-28 07:53:21 PDT
Some background reading:
https://wiki.gnome.org/Projects/PyGObject/Threading
https://stackoverflow.com/questions/21150914/python-gtk-3-safe-threading
luke
Comment 6
2017-08-28 08:14:15 PDT
Makes sense, thanks for the info Michael :)
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug