maintainer-feedback requested: [Bug 226224] devel/qtcreator

bugzilla-noreply at freebsd.org bugzilla-noreply at freebsd.org
Mon Feb 26 21:26:17 UTC 2018


q5sys <jt at ixsystems.com> has reassigned Bugzilla Automation
<bugzilla at FreeBSD.org>'s request for maintainer-feedback to Max Brazhnikov
<kde at FreeBSD.org>:
Bug 226224: devel/qtcreator
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=226224



--- Description ---
Qt Creator will segfault when trying to parse a QML file.

Steps to reproduce:
1) Open Qt Creator
2) Open any QML example that ships with Qt Creator.
3) Attempt to open any QML file in the editor.

Alternatively

1) Open Qt Creator
2) Create new QML project
3) Attempt to open any QML file

Alternatively

1) Open Qt Creator
2) Open any QML project
3) Attempt to add a new blank QML file
4) Qt Creator will segfault as soon as you type brackets


In doing testing, it appears that Qt Creator is loading the file in the editor
properly, but when it attempt to parse the text it crashes.  Adding import
statements does not crash the editor, but the moment you type any brackets it
will.

TRUSS Output:

fstatat(AT_FDCWD,"/usr/local/lib/qt5/qml/QtQuick/Controls",{ mode=drwxr-xr-x
,inode=138124,size=37,blksize=4096 },0x0) = 0 (0x0)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35253723136
(0x835492000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264684032
(0x835f06000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35253727232
(0x835493000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264696320
(0x835f09000)
mmap(0x0,20480,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264700416
(0x835f0a000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264720896
(0x835f0f000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264724992
(0x835f10000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264729088
(0x835f11000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264733184
(0x835f12000)
poll({ 11/POLLIN 26/POLLIN 148/POLLIN 135/POLLIN 16/POLLIN 6/POLLIN },6,219) =
0 (0x0)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264737280
(0x835f13000)
poll({ 11/POLLIN 26/POLLIN 148/POLLIN 135/POLLIN 16/POLLIN 6/POLLIN },6,0) = 0
(0x0)
write(7,"\0",1) 				 = 1 (0x1)
poll({ 3/POLLIN|POLLOUT },1,-1) 		 = 1 (0x1)
writev(0x3,0x7fffffffdae8,0x1)			 = 4 (0x4)
poll({ 3/POLLIN },1,-1) 			 = 1 (0x1)
recvmsg(3,0x7fffdfffdcf8,0)			 = 32 (0x20)
_umtx_op(0x8006ee0b8,UMTX_OP_NWAKE_PRIVATE,0x1,0x0,0x0) = 0 (0x0)
_umtx_op(0x803c97210,UMTX_OP_WAIT_UINT_PRIVATE,0x0,0x0,0x0) = 0 (0x0)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264741376
(0x835f14000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264745472
(0x835f15000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264749568
(0x835f16000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264761856
(0x835f19000)
poll({ 3/POLLIN|POLLOUT },1,-1) 		 = 1 (0x1)
writev(0x3,0x7fffffffdab8,0x1)			 = 76 (0x4c)
poll({ 11/POLLIN 26/POLLIN 148/POLLIN 135/POLLIN 16/POLLIN 6/POLLIN },6,57) = 1
(0x1)
read(6,"\0",16) 				 = 1 (0x1)
read(6,0x7fffffffe370,16)			 ERR#35 'Resource temporarily
unavailable'
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264765952
(0x835f1a000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264770048
(0x835f1b000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264774144
(0x835f1c000)
mmap(0x0,4096,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264778240
(0x835f1d000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264782336
(0x835f1e000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264794624
(0x835f21000)
mmap(0x0,20480,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264806912
(0x835f24000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264827392
(0x835f29000)
mmap(0x0,12288,PROT_READ|PROT_WRITE,MAP_PRIVATE|MAP_ANON,-1,0x0) = 35264839680
(0x835f2c000)
SIGNAL 10 (SIGBUS) code=BUS_OBJERR trapno=9 addr=0x818d200b7
<thread 101547 exited>
<thread 101548 exited>
<thread 100812 exited>
<thread 101551 exited>
<thread 101550 exited>
<thread 101549 exited>
<thread 101563 exited>
process killed, signal = 10
[q5sys at skynet] ~/code/dashboard/qml% 


LLDB

[q5sys at skynet] ~% lldb
(lldb) process attach --pid 5104
Process 5104 stopped

Executable module set to "/usr/local/bin/qtcreator".
Architecture set to: x86_64--freebsd12.0.
(lldb) c
Process 5104 resuming
(lldb) Info: creating stash file
/usr/home/q5sys/git/build-qmltest-Desktop-Debug/.qmake.stash
SOFT ASSERT: "item" in file treemodel.cpp, line 1108
Process 5104 stopped
* thread #12, name = 'qtcreator', stop reason = signal SIGSEGV: invalid address
(fault address: 0x84793e4d0)
    frame #0: 0x0000000818d200e2
libQmlJS.so.4`QmlJS::Context::imports(QmlJS::Document const*) const + 66
libQmlJS.so.4`QmlJS::Context::imports:
->  0x818d200e2 <+66>: movq   (%r8,%rdx,8), %rax
    0x818d200e6 <+70>: xorl   %ebx, %ebx
    0x818d200e8 <+72>: cmpq   %rdi, %rax
    0x818d200eb <+75>: je     0x818d20154		; <+180>
(lldb) bt
* thread #12, name = 'qtcreator', stop reason = signal SIGSEGV: invalid address
(fault address: 0x84793e4d0)
  * frame #0: 0x0000000818d200e2
libQmlJS.so.4`QmlJS::Context::imports(QmlJS::Document const*) const + 66
    frame #1: 0x0000000818d20190
libQmlJS.so.4`QmlJS::Context::lookupType(QmlJS::Document const*,
QmlJS::AST::UiQualifiedId*, QmlJS::AST::UiQualifiedId) const + 32
    frame #2: 0x0000000818d206ec
libQmlJS.so.4`QmlJS::Context::lookupReference(QmlJS::Value const*) const + 252
    frame #3: 0x0000000818caa4f8
libQmlJS.so.4`QmlJS::PrototypeIterator::hasNext(void) + 168
    frame #4: 0x0000000818cd2c98
libQmlJS.so.4`QmlJS::ScopeBuilder::setQmlScopeObject(QmlJS::AST::Node*) + 440
    frame #5: 0x0000000818cd2529
libQmlJS.so.4`QmlJS::ScopeBuilder::push(QmlJS::AST::Node*) + 169
    frame #6: 0x0000000818cc39aa
libQmlJS.so.4`QmlJS::Check::visitQmlObject(QmlJS::AST::Node*,
QmlJS::Check::visitQmlObject::UiQualifiedId*,
QmlJS::Check::visitQmlObject::UiObjectInitializer*) + 5466
    frame #7: 0x0000000818cc2441
libQmlJS.so.4`QmlJS::Check::visit(QmlJS::AST::UiObjectDefinition*) + 17
    frame #8: 0x0000000818c6557c
libQmlJS.so.4`QmlJS::AST::UiObjectDefinition::accept0(QmlJS::AST::Visitor*) +
28
    frame #9: 0x0000000818c65916
libQmlJS.so.4`QmlJS::AST::UiObjectMemberList::accept0(QmlJS::AST::Visitor*) +
86
    frame #10: 0x0000000818c65496
libQmlJS.so.4`QmlJS::AST::UiProgram::accept0(QmlJS::AST::Visitor*) + 118
    frame #11: 0x0000000818c62c8e
libQmlJS.so.4`QmlJS::AST::Node::accept(QmlJS::AST::Node*, QmlJS::AST::Visitor*)
+ 46
    frame #12: 0x0000000818cc0d45 libQmlJS.so.4`QmlJS::Check::operator()(void)
+ 101
    frame #13: 0x0000000827d8b7b0
libQmlJSEditor.so`___lldb_unnamed_symbol1033$$libQmlJSEditor.so + 1456
    frame #14: 0x0000000827d8b05c
libQmlJSEditor.so`___lldb_unnamed_symbol1032$$libQmlJSEditor.so + 428
    frame #15: 0x00000008028abd4a
libQt5Core.so.5`___lldb_unnamed_symbol244$$libQt5Core.so.5 + 234
    frame #16: 0x0000000803a7ac55
libthr.so.3`___lldb_unnamed_symbol1$$libthr.so.3 + 325
(lldb)


More information about the kde-freebsd mailing list