fix importwallet crash due to out of scope wallet reference #16134
pull sidhujag wants to merge 1 commits into bitcoin:master from sidhujag:patch-1 changing 1 files +0 −1-
sidhujag commented at 4:39 am on June 2, 2019: noneshowProgress hold’s a reference that is invalidated because wallet is used outside of the locked scope and inside of RescanWallet it is locked into a new context.. calling showProgress outside of the wallet lock context results in intermittent crashes of core.
-
fix importwallet crash due to out of scope wallet reference
showProgress hold's a reference that is invalidated because wallet is used outside of the locked scope and inside of RescanWallet it is locked into a new context.. calling showProgress outside of the wallet lock context results in intermittent crashes of core.
-
fanquake added the label RPC/REST/ZMQ on Jun 2, 2019
-
fanquake added the label Wallet on Jun 2, 2019
-
MarcoFalke commented at 8:26 am on June 2, 2019: memberCould you explain which member needs to be guarded by the lock, but istn’t. Also how does the crash look like? Are there issues open about the crash?
-
sidhujag commented at 2:14 pm on June 2, 2019: noneI think it’s the wallet and locked chain it’s outside the scope and the crash is in showProgress on memory cleanup. I can attach the user log on my OS X to show the exact line and stack but it’s likely because in rescanwallet it tries to update showProgress again and I don’t know if those calls are idempotent
-
sidhujag commented at 2:25 pm on June 2, 2019: none
Thread 0 Crashed:: bitcoin-main Dispatch queue: com.apple.main-thread 0 org.qt-project.QtWidgets 0x0000000103b4d4a7 QWidgetPrivate::close_helper(QWidgetPrivate::CloseMode) + 23 1 bitcoin-qt 0x0000000102687ab3 BitcoinGUI::showProgress(QString const&, int) + 67 (bitcoingui.cpp:1433) 2 org.qt-project.QtCore 0x0000000104807e42 QMetaObject::activate(QObject*, int, int, void**) + 1474 3 bitcoin-qt 0x000000010275cefc ClientModel::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) + 732 4 org.qt-project.QtCore 0x00000001048009f1 QObject::event(QEvent*) + 769 5 org.qt-project.QtWidgets 0x0000000103b2446d QApplicationPrivate::notify_helper(QObject*, QEvent*) + 269 6 org.qt-project.QtWidgets 0x0000000103b25897 QApplication::notify(QObject*, QEvent*) + 583 7 org.qt-project.QtCore 0x00000001047d6f64 QCoreApplication::notifyInternal2(QObject*, QEvent*) + 164 8 org.qt-project.QtCore 0x00000001047d80d7 QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) + 791
the last entry of debug.log 2019-06-02T14:22:58Z [default wallet] RescanFromTime: Rescanning last 253 blocks
if I remove that showProgress call in the commit I did, the progress closes and no more crash. It happens fairly regular if you delete existing wallet.dat and run an import.
-
fanquake commented at 4:09 pm on June 2, 2019: member
Thanks @sidhujag, I’ve recreated the crash using master (c7cfd20a77ce57d200b3b9e5e0dfb0d63818abdc):
0lldb Bitcoin-Qt.app -- -regtest 1(lldb) target create "Bitcoin-Qt.app" 2Current executable set to 'Bitcoin-Qt.app' (x86_64). 3(lldb) settings set -- target.run-args "-regtest" 4(lldb) run 5Process 70618 launched: '/Users/michael/github/bitcoin/Bitcoin-Qt.app/Contents/MacOS/Bitcoin-Qt' (x86_64) 62019-06-02 11:56:53.744068-0400 Bitcoin-Qt[70618:5085197] MessageTracer: Falling back to default whitelist 7Process 70618 stopped 8* thread [#1](/bitcoin-bitcoin/1/), name = 'bitcoin-main', queue = 'com.apple.main-thread', stop reason = EXC_BAD_ACCESS (code=EXC_I386_GPFLT) 9 frame [#0](/bitcoin-bitcoin/0/): 0x0000000100e516f1 QtWidgets`QWidgetPrivate::close_helper(QWidgetPrivate::CloseMode) + 17 10QtWidgets`QWidgetPrivate::close_helper: 11-> 0x100e516f1 <+17>: movl 0x140(%rdi), %eax 12 0x100e516f7 <+23>: movb $0x1, %bl 13 0x100e516f9 <+25>: testl $0x200, %eax ; imm = 0x200 14 0x100e516fe <+30>: jne 0x100e5192c ; <+588> 15Target 0: (Bitcoin-Qt) stopped.
-
fanquake commented at 4:16 pm on June 2, 2019: memberChecked that the same crash occurs using
0.18.0
(2472733a24a9364e4c6233ccd04166a26a68cc65). -
sidhujag referenced this in commit 8b7943b647 on Jun 2, 2019
-
fanquake closed this on Jun 2, 2019
-
laanwj referenced this in commit 38523721ac on Jun 3, 2019
-
sidhujag deleted the branch on Jun 21, 2019
-
MarcoFalke deleted a comment on Jul 1, 2019
-
MarcoFalke deleted a comment on Jul 1, 2019
-
PastaPastaPasta referenced this in commit b8e50742ef on Jun 27, 2021
-
PastaPastaPasta referenced this in commit c65766fad2 on Jun 28, 2021
-
PastaPastaPasta referenced this in commit 78137e6017 on Jun 29, 2021
-
PastaPastaPasta referenced this in commit 98b4883d77 on Jul 1, 2021
-
PastaPastaPasta referenced this in commit f2511863ae on Jul 1, 2021
-
PastaPastaPasta referenced this in commit 93c1999c2f on Jul 12, 2021
-
DrahtBot locked this on Dec 16, 2021
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 00:12 UTC
More mirrored repositories can be found on mirror.b10c.me