Project

Profile

Help

Bug #6466

open

Python interactive interpreter seg-faults on tab completion

Added by Jens Troeger 7 months ago. Updated 6 months ago.

Status:
In Progress
Priority:
Low
Category:
Python API
Start date:
2024-07-04
Due date:
% Done:

0%

Estimated time:
Applies to branch:
Fix Committed on Branch:
12
Fixed in Maintenance Release:
Found in version:
12.4.2
Fixed in version:
SaxonC Languages:
C++, Python
SaxonC Platforms:
All
SaxonC Architecture:

Description

Hello,

I installed the Python package saxoncee ==12.4.2 in a Python 3.11.9 virtual environment, and upon trying to list the properties of an instance using tab completion, the interpreter crashed:

~ > uname -a
Darwin pooh 22.6.0 Darwin Kernel Version 22.6.0: Mon Apr 22 20:54:28 PDT 2024; root:xnu-8796.141.3.705.2~1/RELEASE_X86_64 x86_64 i386 Darwin
~ > PYTHONFAULTHANDLER=1 python
Python 3.11.9 (main, Apr  4 2024, 11:05:12) [Clang 14.0.3 (clang-1403.0.22.14.1)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import saxoncee          
>>> 
>>> saxon = saxoncee.PySaxonProcessor(license=False)
>>> document_builder = saxon.new_document_builder()
>>> node = document_builder.parse_xml(xml_text='<test/>')
>>> 
>>> node.Fatal Python error: Segmentation fault

Current thread 0x00007ff843bdd7c0 (most recent call first):
  File "/opt/local/Library/Frameworks/Python.framework/Versions/3.11/lib/python3.11/rlcompleter.py", line 189 in attr_matches
  File "/opt/local/Library/Frameworks/Python.framework/Versions/3.11/lib/python3.11/rlcompleter.py", line 92 in complete

Extension modules: saxoncee (total: 1)
Segmentation fault: 11

So on hitting the tab key on node. the interpreter crashes.

This happens with and without registering the license with the Saxon Processor.


Files

Bildschirmaufnahme 2024-07-08 123143.mp4 (10.1 MB) Bildschirmaufnahme 2024-07-08 123143.mp4 screen recording of segfault in Python 3.12 interactive shell on Ubuntu 24 trying tab completion on saxon_proc created with PySaxonProcessor() Martin Honnen, 2024-07-08 12:38
Bildschirmaufnahme 2024-07-08 um 12.54.55.mov (10.3 MB) Bildschirmaufnahme 2024-07-08 um 12.54.55.mov Martin Honnen, 2024-07-08 13:01
Bildschirmaufnahme 2024-07-08 133549.mp4 (25.5 MB) Bildschirmaufnahme 2024-07-08 133549.mp4 screen recording of error on trying tab completion on PySaxonProcessor() created variable in Windows 11 x64 cmd shell running Python 3.12 Martin Honnen, 2024-07-08 13:39

Related issues

Related to SaxonC - Bug #6468: saxoncee.__version__ is missingResolvedO'Neil Delpratt2024-07-04

Actions
Actions #1

Updated by O'Neil Delpratt 7 months ago

  • Category set to Python API
  • Status changed from New to AwaitingInfo
  • Found in version set to 12.4.2

Hi Jens,

Thank you for reporting the issue you found. The problem seems only to be on the SaxonC 12.4.2 release. I tried the same example with SaxonC 12.5 which was released a few days ago and the problem seems to have gone away.

See output with SaxonC 12.5:

>>> node.
node.add_xdm_item(         node.column_number         node.get_node_value(       node.is_function           node.name                  node.typed_value
node.attribute_count       node.get_array_value(      node.get_parent(           node.is_map                node.node_kind             
node.attributes            node.get_atomic_value(     node.get_string_value(     node.is_node               node.node_kind_str         
node.axis_nodes(           node.get_attribute_value(  node.head                  node.item_at(              node.size                  
node.base_uri              node.get_function_value(   node.is_array              node.line_number           node.string_value          
node.children              node.get_map_value(        node.is_atomic             node.local_name            node.to_string(  
Actions #2

Updated by Jens Troeger 6 months ago

Thanks O’Neil! I can confirm that, after installing saxoncee ==12.5.0, I was able to tab complete.

But, I also noticed that saxoncee.__version__ is missing, which is common to denote a package’s version (see also PEP-8).

Actions #3

Updated by O'Neil Delpratt 6 months ago

  • Related to Bug #6468: saxoncee.__version__ is missing added
Actions #4

Updated by O'Neil Delpratt 6 months ago

Jens Troeger wrote in #note-2:

Thanks O’Neil! I can confirm that, after installing saxoncee ==12.5.0, I was able to tab complete.

But, I also noticed that saxoncee.__version__ is missing, which is common to denote a package’s version (see also PEP-8).

I have created the bug issue to track the progress of __version__: #6468

Actions #5

Updated by O'Neil Delpratt 6 months ago

  • Status changed from AwaitingInfo to Rejected
Actions #6

Updated by Martin Honnen 6 months ago

In a Linux Ubuntu WSL shell with SaxonCHE 12.5 installed, I sometimes on the attempt to use tab completion continue to get an error/crash. I say sometimes because so far I have not figured what triggers or prevents it because some sessions it works and in others it doesn't.

Screen output:

(saxonche125) mh@LAPTOP-C329VRUD:~$ python
Python 3.12.3 (main, Apr 10 2024, 05:33:47) [GCC 13.2.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from saxonche import *
>>> saxon_proc = PySaxonProcessor()
>>> saxon_proc.Fatal error: Must either be at a safepoint or in native mode

Current timestamp: 1720350145512

Printing Instructions (ip=0x00007feaffa14600):
  0x00007feaffa145e0: 0x00 0x41 0xc7 0x87 0xfc 0x00 0x00 0x00 0xfe 0xfe 0xfe 0x7e 0x48 0x8b 0x7c 0x24
  0x00007feaffa145f0: 0x20 0x48 0x8b 0x74 0x24 0x10 0x48 0x8b 0x54 0x24 0x18 0xe8 0x90 0xfc 0xff 0xff
  0x00007feaffa14600: 0x90 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc
  0x00007feaffa14610: 0x48 0x83 0xec 0x18 0x49 0x3b 0x67 0x08 0x0f 0x86 0x9f 0x00 0x00 0x00 0x48 0x8b

Top of stack (sp=0x00007fff5f1c3b90):
  0x00007fff5f1c3b90: 0x0000000000000000 0x0000000000000001
  0x00007fff5f1c3ba0: 0x00007feafdc9a268 0x00007feafd700000
  0x00007fff5f1c3bb0: 0x00007feaffa58a91 0x00007feaffa5f5f4
  0x00007fff5f1c3bc0: 0x00007fff5f1c3d00 0x00007feaffa58a91
  0x00007fff5f1c3bd0: 0x00007fff5f1c3c28 0x00007feb02f903c0
  0x00007fff5f1c3be0: 0x0000000100000000 0x00007feaff9b2782
  0x00007fff5f1c3bf0: 0x7819c420788047b2 0x0000000000000002
  0x00007fff5f1c3c00: 0x00007fff5f1c3cbc 0x0000000001131d80
  0x00007fff5f1c3c10: 0x0000000000000001 0x00000000010b7cf0
  0x00007fff5f1c3c20: 0x0000000000000000 0x00007feb0322fe30
  0x00007fff5f1c3c30: 0x00007feb02f03140 0x00007feb02f9d680
  0x00007fff5f1c3c40: 0x00007fff5f1c3cf0 0x00007feb02e4e3a7
  0x00007fff5f1c3c50: 0x0000000001175230 0x00007feb02f03140
  0x00007fff5f1c3c60: 0x0000000000b43b70 0x0000000000b43b70
  0x00007fff5f1c3c70: 0x00007fff5f1c3cf0 0x0000000000000000
  0x00007fff5f1c3c80: 0x00007feb0322fe30 0x00007feb02eb5ded
  0x00007fff5f1c3c90: 0x0000000000b43b70 0x0000000000000000
  0x00007fff5f1c3ca0: 0x00007fff5f1c3cf0 0x0000000000584eb8
  0x00007fff5f1c3cb0: 0x0000000000551170 0x0000000000000001
  0x00007fff5f1c3cc0: 0x00007fff5f1c3ce0 0x00007feb0322fe30
  0x00007fff5f1c3cd0: 0x00007feb02f03140 0x00007fff5f1c3d48
  0x00007fff5f1c3ce0: 0x0000000000000027 0x00007feb032a9ee0
  0x00007fff5f1c3cf0: 0x00007fff5f1c3d30 0x0000000000584d38
  0x00007fff5f1c3d00: 0x00007fff5f1c3d70 0x00000000005b2ca2
  0x00007fff5f1c3d10: 0x0000000000b3acf0 0x00007feb036b8168
  0x00007fff5f1c3d20: 0x0000000000000003 0x0000000000a3f8a0
  0x00007fff5f1c3d30: 0x00007fff5f1c3d70 0x00000000005d2f24
  0x00007fff5f1c3d40: 0x000000000000009b 0x0000000000a2de00
  0x00007fff5f1c3d50: 0x0000000000ba5048 0x00007feb036b80a0
  0x00007fff5f1c3d60: 0x0000000000ba5048 0x000000000110504c
  0x00007fff5f1c3d70: 0x00007fff5f1c3ef0 0x00000000005d8b3e
  0x00007fff5f1c3d80: 0x0000000100000000 0x0000000000000000

Top frame info:
  TotalFrameSize in CodeInfoTable 48

Threads:
  0x00007feaf8000b80 STATUS_IN_NATIVE (ALLOW_SAFEPOINT) "Reference Handler" - 0x00007feafe7c5570, daemon, stack(0x00007feafcd01000,0x00007feafd500000)

VM thread locals for the failing thread 0x0000000001131d80:
  0 (8 bytes): JNIThreadLocalEnvironment.jniFunctions = (bytes)
    0x0000000001131d80: 0x0000000001193711
  8 (8 bytes): StackOverflowCheckImpl.stackBoundaryTL = (Word) 1 (0x0000000000000001)
  16 (4 bytes): Safepoint.safepointRequested = (int) 2147428937 (0x7fff2a49)
  20 (4 bytes): StatusSupport.statusTL = (int) 1 (0x00000001)
  24 (32 bytes): ThreadLocalAllocation.regularTLAB = (bytes)
    0x0000000001131d98: 0x0000000000000000 0x0000000000000000
    0x0000000001131da8: 0x0000000000000000 0x0000000000000000
  56 (8 bytes): PlatformThreads.currentThread = (Object) java.lang.Thread (0x00007feafe7c54b8)
  64 (8 bytes): JavaFrameAnchors.lastAnchor = (Word) 0 (0x0000000000000000)
  72 (8 bytes): AccessControlContextStack = (Object) null
  80 (8 bytes): ExceptionUnwind.currentException = (Object) null
  88 (8 bytes): IdentityHashCodeSupport.hashCodeGeneratorTL = (Object) java.util.SplittableRandom (0x00007feafd54a428)
  96 (8 bytes): IsolatedCompileClient.currentClient = (Object) null
  104 (8 bytes): IsolatedCompileContext.currentContext = (Object) null
  112 (8 bytes): JNIObjectHandles.handles = (Object) com.oracle.svm.core.handles.ThreadLocalHandles (0x00007feafd501158)
  120 (8 bytes): JNIThreadLocalPendingException.pendingException = (Object) null
  128 (8 bytes): JNIThreadLocalPinnedObjects.pinnedObjectsListHead = (Object) null
  136 (8 bytes): JNIThreadOwnedMonitors.ownedMonitors = (Object) null
  144 (8 bytes): NoAllocationVerifier.openVerifiers = (Object) null
  152 (8 bytes): ThreadingSupportImpl.activeTimer = (Object) null
  160 (8 bytes): SubstrateDiagnostics.threadOnlyAttachedForCrashHandler = (bytes)
    0x0000000001131e20: 0x0000000000000000
  168 (8 bytes): ThreadLocalAllocation.allocatedBytes = (Word) 300352 (0x0000000000049540)
  176 (8 bytes): VMThreads.IsolateTL = (Word) 140647251050496 (0x00007feafd700000)
  184 (8 bytes): VMThreads.OSThreadHandleTL = (Word) 140647347990656 (0x00007feb03373080)
  192 (8 bytes): VMThreads.OSThreadIdTL = (Word) 140647347990656 (0x00007feb03373080)
  200 (8 bytes): VMThreads.StackBase = (Word) 140734789095424 (0x00007fff5f1c9000)
  208 (8 bytes): VMThreads.StackEnd = (Word) 140734780715008 (0x00007fff5e9cb000)
  216 (8 bytes): VMThreads.StartedByCurrentIsolate = (bytes)
    0x0000000001131e58: 0x0000000000000000
  224 (8 bytes): VMThreads.nextTL = (Word) 18029952 (0x0000000001131d80)
  232 (8 bytes): VMThreads.unalignedIsolateThreadMemoryTL = (Word) 18029952 (0x0000000001131d80)
  240 (4 bytes): ActionOnExitSafepointSupport.actionTL = (int) 0 (0x00000000)
  244 (4 bytes): ActionOnTransitionToJavaSupport.actionTL = (int) 0 (0x00000000)
  248 (4 bytes): ImplicitExceptions.implicitExceptionsAreFatal = (int) 0 (0x00000000)
  252 (4 bytes): StackOverflowCheckImpl.yellowZoneStateTL = (int) 2130640638 (0x7efefefe)
  256 (4 bytes): StatusSupport.safepointBehaviorTL = (int) 1 (0x00000001)
  260 (4 bytes): ThreadingSupportImpl.currentPauseDepth = (int) 0 (0x00000000)

No VMOperation in progress

The 15 most recent VM operation status changes (oldest first):

Counters:

Java frame anchors for the failing thread 0x0000000001131d80:
  No anchors

Stacktrace for the failing thread 0x0000000001131d80:
  SP 0x00007fff5f1c3b90 IP 0x00007feaffa14600  [image code] com.oracle.svm.core.jdk.VMErrorSubstitutions.shutdown(VMErrorSubstitutions.java:116)
  SP 0x00007fff5f1c3b90 IP 0x00007feaffa14600  [image code] com.oracle.svm.core.jdk.VMErrorSubstitutions.shouldNotReachHere(VMErrorSubstitutions.java:109)
  SP 0x00007fff5f1c3bc0 IP 0x00007feaffa5f5f4  [image code] com.oracle.svm.core.util.VMError.shouldNotReachHere(VMError.java:65)
  SP 0x00007fff5f1c3bd0 IP 0x00007feaffa58a91  [image code] com.oracle.svm.core.util.VMError.guarantee(VMError.java:89)
  SP 0x00007fff5f1c3bd0 IP 0x00007feaffa58a91  [image code] com.oracle.svm.core.thread.Safepoint.enterSlowPathTransitionFromNativeToNewStatus(Safepoint.java:547)
  SP 0x00007fff5f1c3bf0 IP 0x00007feaff9b2782  [image code] com.oracle.svm.core.code.IsolateEnterStub.SaxonCAPI_getProductVersion_cfa0e13fc82d005b303f6bf24a96696cf9afd7c7(IsolateEnterStub.java:0)

VM mutexes:
  mutex "mainVMOperationControlWorkQueue" is unlocked.
  mutex "thread" is unlocked.
  mutex "referencePendingList" is unlocked.

AOT compiled code is mapped at 0x00007feaff96e000 - 0x00007feb0129788f

Heap settings and statistics:
  Supports isolates: true
  Heap base: 0x00007feafd700000
  Object reference size: 8
  Aligned chunk size: 1048576
  Incremental collections: 0
  Complete collections: 0

Native image heap boundaries:
  ReadOnly Primitives: 0x00007feafd801028 - 0x00007feafdc06978
  ReadOnly References: 0x00007feafdc06978 - 0x00007feafdef16a8
  ReadOnly Relocatables: 0x00007feafdef2000 - 0x00007feafe140cb0
  Writable Primitives: 0x00007feafe141000 - 0x00007feafe6b6498
  Writable References: 0x00007feafe6b6498 - 0x00007feafeb961a8
  Writable Huge: 0x00007feafec00030 - 0x00007feafec73830
  ReadOnly Huge: 0x00007feafec74030 - 0x00007feaff332b68

Heap:
  Young generation:
    Eden:
      edenSpace:
        aligned: 1048576/1 unaligned: 0/0
        aligned chunks:
          0x00007feafd500000 (0x00007feafd501028-0x00007feafd54a568)
    Survivors:
      Survivor-1 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-1 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-2 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-2 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-3 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-3 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-4 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-4 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-5 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-5 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-6 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-6 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-7 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-7 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-8 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-8 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-9 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-9 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-10 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-10 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-11 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-11 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-12 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-12 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-13 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-13 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-14 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-14 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-15 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-15 To:
        aligned: 0/0 unaligned: 0/0
  Old generation:
    oldFromSpace:
      aligned: 0/0 unaligned: 0/0
    oldToSpace:
      aligned: 0/0 unaligned: 0/0

  Unused:
    aligned: 0/0

Fatal error: Must either be at a safepoint or in native mode
Actions #7

Updated by Martin Honnen 6 months ago

I am also with SaxonCHE 12.5 able to trigger the segmentation fault in the shell on a Mac:

martin@MacBook-Pro-von-Martin ~ % python3 -m pip install saxonche==12.5
Defaulting to user installation because normal site-packages is not writeable
Collecting saxonche==12.5
  Downloading saxonche-12.5.0-cp39-cp39-macosx_11_0_arm64.whl.metadata (5.7 kB)
Downloading saxonche-12.5.0-cp39-cp39-macosx_11_0_arm64.whl (20.0 MB)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 20.0/20.0 MB 6.3 MB/s eta 0:00:00
Installing collected packages: saxonche
  Attempting uninstall: saxonche
    Found existing installation: saxonche 12.4.2
    Uninstalling saxonche-12.4.2:
      Successfully uninstalled saxonche-12.4.2
Successfully installed saxonche-12.5.0
martin@MacBook-Pro-von-Martin ~ % python3
Python 3.9.6 (default, Mar 29 2024, 10:51:09) 
[Clang 15.0.0 (clang-1500.3.9.4)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> from saxonche import *
>>> saxon_proc = PySaxon
PySaxonApiError(  PySaxonProcessor(
>>> saxon_proc = PySaxonProcessor()
>>> saxon_proc.zsh: segmentation fault  python3

Error report has more details as


Process:               Python [35693]
Path:                  /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/Resources/Python.app/Contents/MacOS/Python
Identifier:            com.apple.python3
Version:               3.9.6 (3.9.6)
Build Info:            python3-141000000000000~1681
Code Type:             ARM-64 (Native)
Parent Process:        zsh [942]
Responsible:           Terminal [655]
User ID:               501

Date/Time:             2024-07-07 15:22:55.2055 +0200
OS Version:            macOS 14.5 (23F79)
Report Version:        12


Time Awake Since Boot: 96000 seconds
Time Since Wake:       393 seconds

System Integrity Protection: enabled

Crashed Thread:        0  Dispatch queue: com.apple.main-thread

Exception Type:        EXC_BAD_ACCESS (SIGSEGV)
Exception Codes:       KERN_INVALID_ADDRESS at 0x0000000000597858
Exception Codes:       0x0000000000000001, 0x0000000000597858

Termination Reason:    Namespace SIGNAL, Code 11 Segmentation fault: 11
Terminating Process:   exc handler [35693]

VM Region Info: 0x597858 is not in any region.  Bytes before following region: 4359817128
      REGION TYPE                    START - END         [ VSIZE] PRT/MAX SHRMOD  REGION DETAIL
      UNUSED SPACE AT START
--->  
      __TEXT                      104370000-104374000    [   16K] r-x/r-x SM=COW  /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/Resources/Python.app/Contents/MacOS/Python

Thread 0 Crashed::  Dispatch queue: com.apple.main-thread
0   libsaxon-hec-12.5.0.dylib     	       0x1087233a4 0x10865c000 + 816036
1   saxonche.cpython-39-darwin.so 	       0x10465a750 __pyx_getprop_8saxonche_16PySaxonProcessor_exception_occurred(_object*, void*) + 16
2   Python3                       	       0x104dd86a0 _PyObject_GenericGetAttrWithDict + 196
3   Python3                       	       0x104dd3188 0x104d50000 + 536968
4   Python3                       	       0x104e62a38 0x104d50000 + 1124920
5   Python3                       	       0x104e5fbf4 _PyEval_EvalFrameDefault + 22824
6   Python3                       	       0x104d90fd0 0x104d50000 + 266192
7   Python3                       	       0x104e62a38 0x104d50000 + 1124920
8   Python3                       	       0x104e5fb54 _PyEval_EvalFrameDefault + 22664
9   Python3                       	       0x104d90fd0 0x104d50000 + 266192
10  Python3                       	       0x104d931f0 0x104d50000 + 274928
11  Python3                       	       0x104d91574 0x104d50000 + 267636
12  Python3                       	       0x104d913c4 PyObject_CallFunction + 52
13  readline.cpython-39-darwin.so 	       0x104536708 0x104530000 + 26376
14  libedit.3.dylib               	       0x1cffc320c rl_completion_matches + 60
15  readline.cpython-39-darwin.so 	       0x1045364e0 0x104530000 + 25824
16  libedit.3.dylib               	       0x1cffbb860 0x1cffb7000 + 18528
17  libedit.3.dylib               	       0x1cffc2974 rl_complete + 292
18  libedit.3.dylib               	       0x1cffc0308 0x1cffb7000 + 37640
19  libedit.3.dylib               	       0x1cffbfa9c el_wgets + 468
20  libedit.3.dylib               	       0x1cffcaf68 el_gets + 52
21  libedit.3.dylib               	       0x1cffc2d98 rl_callback_read_char + 44
22  readline.cpython-39-darwin.so 	       0x104535050 0x104530000 + 20560
23  Python3                       	       0x104d71490 PyOS_Readline + 228
24  Python3                       	       0x104d747a0 0x104d50000 + 149408
25  Python3                       	       0x104d72bc8 0x104d50000 + 142280
26  Python3                       	       0x104d72b20 0x104d50000 + 142112
27  Python3                       	       0x104d5716c 0x104d50000 + 29036
28  Python3                       	       0x104d5b19c 0x104d50000 + 45468
29  Python3                       	       0x104d58028 0x104d50000 + 32808
30  Python3                       	       0x104d582cc 0x104d50000 + 33484
31  Python3                       	       0x104e9c988 0x104d50000 + 1362312
32  Python3                       	       0x104e9c160 PyRun_InteractiveLoopFlags + 156
33  Python3                       	       0x104e9c080 PyRun_AnyFileExFlags + 72
34  Python3                       	       0x104eb9ac0 Py_RunMain + 2360
35  Python3                       	       0x104eb9c3c 0x104d50000 + 1481788
36  Python3                       	       0x104eb9cdc Py_BytesMain + 40
37  dyld                          	       0x1853460e0 start + 2360

Thread 1:: ference Handler
0   libsystem_kernel.dylib        	       0x1856919ec __psynch_cvwait + 8
1   libsystem_pthread.dylib       	       0x1856cf55c _pthread_cond_wait + 1228
2   libsaxon-hec-12.5.0.dylib     	       0x10872f194 0x10865c000 + 864660
3   libsystem_pthread.dylib       	       0x1856c9d34 thread_start + 8


Thread 0 crashed with ARM Thread State (64-bit):
    x0: 0x00000000013b1820   x1: 0x0000000000597858   x2: 0x0000000000000000   x3: 0x000000000000000b
    x4: 0x000000016ba8d520   x5: 0x00000000013b1820   x6: 0x0000000000597858   x7: 0x0000000000000000
    x8: 0x0000000121704180   x9: 0x0000000000000002  x10: 0x0000000000000018  x11: 0x00000000000000da
   x12: 0x000000010456fc58  x13: 0x0000000000000000  x14: 0x0000000000000018  x15: 0x000000000000000a
   x16: 0x00000001086a9880  x17: 0x0000000000000000  x18: 0x0000000000000000  x19: 0x00000001044e8580
   x20: 0x00000001044e5e40  x21: 0x0000000000000000  x22: 0x00000001044e6490  x23: 0x00000001046c3750
   x24: 0x0000000000000002  x25: 0x0000000000000000  x26: 0x0000000104d98bb0  x27: 0x0000000000000000
   x28: 0x0000000121704080   fp: 0x000000016ba8d860   lr: 0x0000000108703cc0
    sp: 0x000000016ba8d4f0   pc: 0x00000001087233a4 cpsr: 0x20001000
   far: 0x0000000000597858  esr: 0x92000006 (Data Abort) byte read Translation fault

Binary Images:
       0x1045c8000 -        0x1045cffff _heapq.cpython-39-darwin.so (*) <b7834f0f-6879-32e9-86dc-214fe45b58bd> /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/lib/python3.9/lib-dynload/_heapq.cpython-39-darwin.so
       0x104628000 -        0x1046a7fff saxonche.cpython-39-darwin.so (*) <d755935d-cf9a-3126-a4c4-2ec28652eaef> /Users/USER/Library/Python/3.9/lib/python/site-packages/saxonche.cpython-39-darwin.so
       0x10865c000 -        0x10a0a3fff libsaxon-hec-12.5.0.dylib (*) <c4a216c9-8bb8-35a9-98f3-28833b4e6155> /Users/USER/Library/Python/3.9/lib/python/site-packages/saxonche.dylibs/libsaxon-hec-12.5.0.dylib
       0x104530000 -        0x104537fff readline.cpython-39-darwin.so (*) <5eb4dd87-2b43-3aac-a790-2e7495e2b13b> /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/lib/python3.9/lib-dynload/readline.cpython-39-darwin.so
       0x104d50000 -        0x104fabfff com.apple.python3 (3.9.6) <e9e1d956-52be-3c08-942d-a2ee518130a3> /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/Python3
       0x104370000 -        0x104373fff com.apple.python3 (3.9.6) <a325eb77-7b03-3888-9ec1-5c4f09be1ee1> /Applications/Xcode.app/Contents/Developer/Library/Frameworks/Python3.framework/Versions/3.9/Resources/Python.app/Contents/MacOS/Python
       0x1cffb7000 -        0x1cffd4fff libedit.3.dylib (*) <8fcb95a4-aa04-3875-974a-57d69834e151> /usr/lib/libedit.3.dylib
       0x185340000 -        0x1853c8a17 dyld (*) <37bbc384-0755-31c7-a808-0ed49e44dd8e> /usr/lib/dyld
               0x0 - 0xffffffffffffffff ??? (*) <00000000-0000-0000-0000-000000000000> ???
       0x18568d000 -        0x1856c7ffb libsystem_kernel.dylib (*) <9b8b53f9-e2b6-36df-98e9-28d8fca732f2> /usr/lib/system/libsystem_kernel.dylib
       0x1856c8000 -        0x1856d4fff libsystem_pthread.dylib (*) <386b0fc1-7873-3328-8e71-43269fd1b2c7> /usr/lib/system/libsystem_pthread.dylib

External Modification Summary:
  Calls made by other processes targeting this process:
    task_for_pid: 0
    thread_create: 0
    thread_set_state: 0
  Calls made by this process:
    task_for_pid: 0
    thread_create: 0
    thread_set_state: 0
  Calls made by all processes on this machine:
    task_for_pid: 0
    thread_create: 0
    thread_set_state: 0

VM Region Summary:
ReadOnly portion of Libraries: Total=686.3M resident=0K(0%) swapped_out_or_unallocated=686.3M(100%)
Writable regions: Total=954.1M written=0K(0%) resident=0K(0%) swapped_out=0K(0%) unallocated=954.1M(100%)

                                VIRTUAL   REGION 
REGION TYPE                        SIZE    COUNT (non-coalesced) 
===========                     =======  ======= 
Kernel Alloc Once                   32K        1 
MALLOC                           933.2M       21 
MALLOC guard page                   96K        6 
STACK GUARD                         32K        2 
Stack                             16.5M        2 
VM_ALLOCATE                       5376K       12 
__AUTH                             343K       69 
__AUTH_CONST                      4089K      150 
__DATA                            29.5M      151 
__DATA_CONST                      4290K      157 
__DATA_DIRTY                       365K       58 
__LINKEDIT                       534.0M        7 
__OBJC_RO                         71.9M        1 
__OBJC_RW                         2199K        1 
__TEXT                           152.3M      164 
dyld private memory                272K        1 
mapped file                       27.2M        3 
shared memory                       32K        2 
===========                     =======  ======= 
TOTAL                              1.7G      808 
Actions #8

Updated by Matt Patterson 6 months ago

  • Status changed from Rejected to In Progress
Actions #9

Updated by Matt Patterson 6 months ago

  • Assignee set to Matt Patterson
Actions #10

Updated by Matt Patterson 6 months ago

  • Status changed from In Progress to AwaitingInfo
  • SaxonC Architecture deleted (x86_64)
  • SaxonC Platforms Linux added

Reading around it seems like Readline causing segfaults in the REPL is a thing that has happened outside SaxonC in the past, with the culprits being versions of Readline Python was compiled against not quite matching with installed versions, or versions being too old.

I haven't yet managed to persuade SaxonC to segfault in the REPL, which makes me wonder if there's a version/installation method trigger.

If anyone is able to reliably make their REPL segfault, could you please make a screen recording of a terminal session where you trigger it? I think that there's probably a whole lot of timing / exact steps stuff that's very hard to communicate in a screenshot or pasting text from the terminal. (Something like https://asciinema.org should also work here.)

If you can trigger it at all (reliably or not), can you let me know exactly what Python you're using, your OS, how you installed Python, and probably the terminal and shell you're using (I'm not sure how these all affect Readline, but I'm pretty sure they do).

Leaving these here as pointers for later: https://community.intel.com/t5/Intel-Distribution-for-Python/Segmentation-fault-on-tab-completion/m-p/1456128 https://github.com/ludwigschwardt/python-readline/issues/1

Actions #11

Updated by Martin Honnen 6 months ago

Hi Matt,

I agree it will be hard to identify the relevant configurations.

But I get some error at some point with Python 3.12.3 under Ubuntu 24.04 Linux run under WSL, shell is bash. Saxon installed with pip install after creating a venv with python3 -m venv and activating that.

I will attach a screen recording.

I also thought I could reproduce it on Windows but some, since I started to try to record it, it seems a Heisenbug and doesn't manifest itself.

Actions #12

Updated by Martin Honnen 6 months ago

I also got a segmentation fault on my MacBook Pro M3 with Python 3.9.6:

martin@MacBook-Pro-von-Martin ~ % python3 -m pip list
Package    Version
---------- -------
altgraph   0.17.2
future     0.18.2
macholib   1.15.2
pip        24.1.1
saxonche   12.5.0
setuptools 58.0.4
six        1.15.0
wheel      0.37.0
martin@MacBook-Pro-von-Martin ~ % python3
Python 3.9.6 (default, Mar 29 2024, 10:51:09) 
[Clang 15.0.0 (clang-1500.3.9.4)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> from saxonche import *
>>> saxon_proc = PySaxonProcessor()
>>> saxon_proc.zsh: segmentation fault  python3

I will attach a recording

Actions #13

Updated by Martin Honnen 6 months ago

Now managed to record a crash with Windows 11 cmd shell and Python 3.12 and SaxonCHE 12.5 installed with pip.

C:\Users\marti>python
Python 3.12.4 (tags/v3.12.4:8e8a4ba, Jun  6 2024, 19:30:16) [MSC v.1940 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>> from saxonche import *
>>> saxon_proc = PySaxonProcessor()
>>> saxon_proc.Fatal error: Must either be at a safepoint or in native mode

Current timestamp: 1720438522267

Printing Instructions (ip=0x00007ff8c2882e40):
  0x00007ff8c2882e20: 0x00 0x41 0xc7 0x87 0xfc 0x00 0x00 0x00 0xfe 0xfe 0xfe 0x7e 0x48 0x8b 0x54 0x24
  0x00007ff8c2882e30: 0x20 0x4c 0x8b 0x44 0x24 0x10 0x4c 0x8b 0x4c 0x24 0x18 0xe8 0x80 0xfc 0xff 0xff
  0x00007ff8c2882e40: 0x90 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc 0xcc
  0x00007ff8c2882e50: 0x48 0x83 0xec 0x28 0x48 0x89 0x54 0x24 0x20 0x49 0x3b 0x67 0x08 0x0f 0x86 0x66

Top of stack (sp=0x0000008ef93ea880):
  0x0000008ef93ea880: 0x0000025de06a2b38 0x00007ff8c28d5e7e
  0x0000008ef93ea890: 0x0000025ddf79a9c8 0x0000025ddf200000
  0x0000008ef93ea8a0: 0x00007ff8c28d2aa7 0x00007ff8c28d9a14
  0x0000008ef93ea8b0: 0x0000025de0491068 0x00007ff8c28d2aa7
  0x0000008ef93ea8c0: 0x00007ffa15cd2658 0x00007ffa7b50d5e8
  0x0000008ef93ea8d0: 0x0000000100000000 0x00007ff8c281ce1d
  0x0000008ef93ea8e0: 0x0000025ddc515bd0 0x0000025ddc515bd0
  0x0000008ef93ea8f0: 0x00007ff900000003 0x0000025ddcb4ee80
  0x0000008ef93ea900: 0x0000000000000000 0x0000000000000000
  0x0000008ef93ea910: 0x0000000000000000 0x0000000000000000
  0x0000008ef93ea920: 0xc1e0000000000000 0x0000000000000000
  0x0000008ef93ea930: 0x7ff0000000000000 0x0000000000000000
  0x0000008ef93ea940: 0x7fffffffffffffff 0x0000000000000000
  0x0000008ef93ea950: 0x41e0000000000000 0x0000000000000000
  0x0000008ef93ea960: 0x8000000000000000 0x0000000000000000
  0x0000008ef93ea970: 0xbff0000000000000 0x0000000000000000
  0x0000008ef93ea980: 0x0000000000000000 0x0000000000000000
  0x0000008ef93ea990: 0x0000000000000000 0x0000000000000000
  0x0000008ef93ea9a0: 0x00007ff9220df018 0x00007ffa15cfcbe0
  0x0000008ef93ea9b0: 0x0000000000000000 0x0000025ddcb74270
  0x0000008ef93ea9c0: 0x00007ff922081768 0x00007ff921acbc8c
  0x0000008ef93ea9d0: 0x0000025ddf0cd4f0 0x0000000000000000
  0x0000008ef93ea9e0: 0x0000025ddf0cd4c0 0x00007ffa15cc17e5
  0x0000008ef93ea9f0: 0x0000025ddc630658 0x0000025ddcad7280
  0x0000008ef93eaa00: 0x0000025ddf0cd4c0 0x00007ff921f46a30
  0x0000008ef93eaa10: 0x0000000000000000 0x00007ff921aca19b
  0x0000008ef93eaa20: 0x00007ff922081768 0x00007ffa15cfcbe0
  0x0000008ef93eaa30: 0x0000008ef93eaab8 0x00007ff900000001
  0x0000008ef93eaa40: 0x0000025ddf0cd4c0 0x00007ff921ac9585
  0x0000008ef93eaa50: 0x00007ffa15cfcbe0 0x00007ff921f46890
  0x0000008ef93eaa60: 0x00007ff9220df018 0x0000025ddc630670
  0x0000008ef93eaa70: 0x0000025ddf0cd4f0 0x0000025ddc630580

Top frame info:
  TotalFrameSize in CodeInfoTable 48

Threads:
  0x0000025ddc5f7cc0 STATUS_IN_NATIVE (ALLOW_SAFEPOINT) "Reference Handler" - 0x0000025de02cc6c8, daemon, stack(0x0000008ef99c0000,0x0000008ef9bb0000)

VM thread locals for the failing thread 0x0000025ddcb4ee80:
  0 (8 bytes): JNIThreadLocalEnvironment.jniFunctions = (bytes)
    0x0000025ddcb4ee80: 0x0000025ddf9f4010
  8 (8 bytes): StackOverflowCheckImpl.stackBoundaryTL = (Word) 1 (0x0000000000000001)
  16 (4 bytes): Safepoint.safepointRequested = (int) 2147391330 (0x7ffe9762)
  20 (4 bytes): StatusSupport.statusTL = (int) 1 (0x00000001)
  24 (32 bytes): ThreadLocalAllocation.regularTLAB = (bytes)
    0x0000025ddcb4ee98: 0x0000000000000000 0x0000000000000000
    0x0000025ddcb4eea8: 0x0000000000000000 0x0000000000000000
  56 (8 bytes): PlatformThreads.currentThread = (Object) java.lang.Thread (0x0000025de02cc618)
  64 (8 bytes): JavaFrameAnchors.lastAnchor = (Word) 0 (0x0000000000000000)
  72 (8 bytes): AccessControlContextStack = (Object) java.util.ArrayDeque (0x0000025de0e32f60)
  80 (8 bytes): ExceptionUnwind.currentException = (Object) null
  88 (8 bytes): IdentityHashCodeSupport.hashCodeGeneratorTL = (Object) java.util.SplittableRandom (0x0000025de0e988a8)
  96 (8 bytes): IsolatedCompileClient.currentClient = (Object) null
  104 (8 bytes): IsolatedCompileContext.currentContext = (Object) null
  112 (8 bytes): JNIObjectHandles.handles = (Object) com.oracle.svm.core.handles.ThreadLocalHandles (0x0000025de0e01158)
  120 (8 bytes): JNIThreadLocalPendingException.pendingException = (Object) null
  128 (8 bytes): JNIThreadLocalPinnedObjects.pinnedObjectsListHead = (Object) null
  136 (8 bytes): JNIThreadOwnedMonitors.ownedMonitors = (Object) null
  144 (8 bytes): NoAllocationVerifier.openVerifiers = (Object) null
  152 (8 bytes): ThreadingSupportImpl.activeTimer = (Object) null
  160 (8 bytes): SubstrateDiagnostics.threadOnlyAttachedForCrashHandler = (bytes)
    0x0000025ddcb4ef20: 0x0000000000000000
  168 (8 bytes): ThreadLocalAllocation.allocatedBytes = (Word) 620992 (0x00000000000979c0)
  176 (8 bytes): VMThreads.IsolateTL = (Word) 2602198630400 (0x0000025ddf200000)
  184 (8 bytes): VMThreads.OSThreadHandleTL = (Word) 936 (0x00000000000003a8)
  192 (8 bytes): VMThreads.OSThreadIdTL = (Word) 138548 (0x0000000000021d34)
  200 (8 bytes): VMThreads.StackBase = (Word) 614067011584 (0x0000008ef93f0000)
  208 (8 bytes): VMThreads.StackEnd = (Word) 614064979968 (0x0000008ef9200000)
  216 (8 bytes): VMThreads.StartedByCurrentIsolate = (bytes)
    0x0000025ddcb4ef58: 0x0000000000000000
  224 (8 bytes): VMThreads.nextTL = (Word) 2602158059136 (0x0000025ddcb4ee80)
  232 (8 bytes): VMThreads.unalignedIsolateThreadMemoryTL = (Word) 2602158059120 (0x0000025ddcb4ee70)
  240 (4 bytes): ActionOnExitSafepointSupport.actionTL = (int) 0 (0x00000000)
  244 (4 bytes): ActionOnTransitionToJavaSupport.actionTL = (int) 0 (0x00000000)
  248 (4 bytes): ImplicitExceptions.implicitExceptionsAreFatal = (int) 0 (0x00000000)
  252 (4 bytes): StackOverflowCheckImpl.yellowZoneStateTL = (int) 2130640638 (0x7efefefe)
  256 (4 bytes): StatusSupport.safepointBehaviorTL = (int) 1 (0x00000001)
  260 (4 bytes): ThreadingSupportImpl.currentPauseDepth = (int) 0 (0x00000000)

No VMOperation in progress

The 15 most recent VM operation status changes (oldest first):

Counters:

Java frame anchors for the failing thread 0x0000025ddcb4ee80:
  No anchors

Stacktrace for the failing thread 0x0000025ddcb4ee80:
  SP 0x0000008ef93ea880 IP 0x00007ff8c2882e40  [image code] com.oracle.svm.core.jdk.VMErrorSubstitutions.shutdown(VMErrorSubstitutions.java:116)
  SP 0x0000008ef93ea880 IP 0x00007ff8c2882e40  [image code] com.oracle.svm.core.jdk.VMErrorSubstitutions.shouldNotReachHere(VMErrorSubstitutions.java:109)
  SP 0x0000008ef93ea8b0 IP 0x00007ff8c28d9a14  [image code] com.oracle.svm.core.util.VMError.shouldNotReachHere(VMError.java:65)
  SP 0x0000008ef93ea8c0 IP 0x00007ff8c28d2aa7  [image code] com.oracle.svm.core.util.VMError.guarantee(VMError.java:89)
  SP 0x0000008ef93ea8c0 IP 0x00007ff8c28d2aa7  [image code] com.oracle.svm.core.thread.Safepoint.enterSlowPathTransitionFromNativeToNewStatus(Safepoint.java:547)
  SP 0x0000008ef93ea8e0 IP 0x00007ff8c281ce1d  [image code] com.oracle.svm.core.code.IsolateEnterStub.SaxonCException_checkForException_98a6e5b9c0cdad1387477917fdcfde8ca66fc74a(IsolateEnterStub.java:0)

VM mutexes:
  mutex "thread" is unlocked.
  mutex "mainVMOperationControlWorkQueue" is unlocked.
  mutex "referencePendingList" is unlocked.

AOT compiled code is mapped at 0x00007ff8c27c1000 - 0x00007ff8c4164a2f

Heap settings and statistics:
  Supports isolates: true
  Heap base: 0x0000025ddf200000
  Object reference size: 8
  Aligned chunk size: 1048576
  Incremental collections: 0
  Complete collections: 0

Native image heap boundaries:
  ReadOnly Primitives: 0x0000025ddf301028 - 0x0000025ddf709760
  ReadOnly References: 0x0000025ddf709760 - 0x0000025ddf9f3248
  ReadOnly Relocatables: 0x0000025ddf9f4000 - 0x0000025ddfc41d50
  Writable Primitives: 0x0000025ddfc42000 - 0x0000025de01bb2b0
  Writable References: 0x0000025de01bb2b0 - 0x0000025de06a7830
  Writable Huge: 0x0000025de0700030 - 0x0000025de0773af0
  ReadOnly Huge: 0x0000025de0774030 - 0x0000025de0d96e08

Heap:
  Young generation:
    Eden:
      edenSpace:
        aligned: 1048576/1 unaligned: 0/0
        aligned chunks:
          0x0000025de0e00000 (0x0000025de0e01028-0x0000025de0e989e8)
    Survivors:
      Survivor-1 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-1 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-2 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-2 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-3 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-3 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-4 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-4 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-5 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-5 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-6 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-6 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-7 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-7 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-8 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-8 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-9 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-9 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-10 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-10 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-11 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-11 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-12 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-12 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-13 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-13 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-14 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-14 To:
        aligned: 0/0 unaligned: 0/0
      Survivor-15 From:
        aligned: 0/0 unaligned: 0/0
      Survivor-15 To:
        aligned: 0/0 unaligned: 0/0
  Old generation:
    oldFromSpace:
      aligned: 0/0 unaligned: 0/0
    oldToSpace:
      aligned: 0/0 unaligned: 0/0

  Unused:
    aligned: 0/0

Fatal error: Must either be at a safepoint or in native mode

Screen recording added.

Actions #14

Updated by Matt Patterson 6 months ago

  • Status changed from AwaitingInfo to In Progress

Thanks, Martin.

I can reproduce it with saxonche too, after following your example.

Actions #15

Updated by Matt Patterson 6 months ago

  • Fix Committed on Branch 12 added
  • SaxonC Languages C++ added
  • SaxonC Platforms All added
  • SaxonC Platforms deleted (Linux, macOS)

We managed to reproduce the report and find some places where we were incorrectly managing C++ resources, and fixing that stopped those segfaults from occuring.

We need to do some more testing to ensure we've fixed all the problems with incorrect resource handling.

Please register to edit this issue

Also available in: Atom PDF