Search code examples
cpython-extensions

_PyMem_DebugRawFree: bad ID: Allocated using API '', verified using API 'o'


My program crashed with the following message from CPython

Debug memory block at address p=0x8a6e80: API ''
    0 bytes originally requested
    The 7 pad bytes at p-7 are not all FORBIDDENBYTE (0xfd):
        at p-7: 0x00 *** OUCH
        at p-6: 0x00 *** OUCH
        at p-5: 0x00 *** OUCH
        at p-4: 0x00 *** OUCH
        at p-3: 0x00 *** OUCH
        at p-2: 0x00 *** OUCH
        at p-1: 0x00 *** OUCH
    Because memory is corrupted at the start, the count of bytes requested
       may be bogus, and checking the trailing pad bytes may segfault.
    The 8 pad bytes at tail=0x8a6e80 are not all FORBIDDENBYTE (0xfd):
        at tail+0: 0x00 *** OUCH
        at tail+1: 0x00 *** OUCH
        at tail+2: 0x00 *** OUCH
        at tail+3: 0x00 *** OUCH
        at tail+4: 0x00 *** OUCH
        at tail+5: 0x00 *** OUCH
        at tail+6: 0x00 *** OUCH
        at tail+7: 0x00 *** OUCH

Enable tracemalloc to get the memory block allocation traceback

Fatal Python error: _PyMem_DebugRawFree: bad ID: Allocated using API '', verified using API 'o'
Python runtime state: finalizing (tstate=0x0000000001f43c50)

Current thread 0x00007f3f562fa740 (most recent call first):
  Garbage-collecting
<no Python frame>

The stack trace from the program is

(gdb) bt
#0  0x00007f8575deeb43 in _PyObject_DebugDumpAddress (p=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/obmalloc.c:2773
#1  0x00007f8575dee7c8 in _PyMem_DebugCheckAddress (func=0x7f8576056e70 <__func__.8.lto_priv.4> "_PyMem_DebugRawFree", api=111 'o', p=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/obmalloc.c:2691
#2  0x00007f8575dee1e3 in _PyMem_DebugRawFree (ctx=0x7f857616e5e0 <_PyMem_Debug+96>, p=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/obmalloc.c:2524
#3  0x00007f8575dee710 in _PyMem_DebugFree (ctx=0x7f857616e5e0 <_PyMem_Debug+96>, ptr=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/obmalloc.c:2661
#4  0x00007f8575debe51 in PyObject_Free (ptr=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/obmalloc.c:709
#5  0x00007f8575e0d687 in object_dealloc (self=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/typeobject.c:4510
#6  0x00007f8575deaa0f in _Py_Dealloc (op=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/object.c:2288
#7  0x00007f8575dfe879 in _Py_DECREF (filename=0x7f85760c9d30 "/builddir/build/BUILD/Python-3.10.2/Include/object.h", lineno=567, op=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:500
#8  0x00007f8575dfe8aa in _Py_XDECREF (op=0x503520 <_Py_TrueStruct>) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:567
#9  0x00007f8575dff99b in tupledealloc (op=0x7f85679e0f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/tupleobject.c:276
#10 0x00007f8575deaa0f in _Py_Dealloc (op=0x7f85679e0f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/object.c:2288
#11 0x00007f8575d76263 in _Py_DECREF (filename=0x7f85760c9d30 "/builddir/build/BUILD/Python-3.10.2/Include/object.h", lineno=567, op=0x7f85679e0f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:500
#12 0x00007f8575d76294 in _Py_XDECREF (op=0x7f85679e0f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:567
#13 0x00007f8575d79eb5 in code_dealloc (co=0x7f85679f9080) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/codeobject.c:658
#14 0x00007f8575deaa0f in _Py_Dealloc (op=0x7f85679f9080) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/object.c:2288
#15 0x00007f8575da3190 in _Py_DECREF (filename=0x7f85760dcf08 "/builddir/build/BUILD/Python-3.10.2/Objects/funcobject.c", lineno=623, op=0x7f85679f9080) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:500
#16 0x00007f8575da5239 in func_clear (op=0x7f8567a1dff0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/funcobject.c:623
#17 0x00007f8575da5510 in func_dealloc (op=0x7f8567a1dff0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/funcobject.c:645
#18 0x00007f8575deaa0f in _Py_Dealloc (op=0x7f8567a1dff0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/object.c:2288
#19 0x00007f8575dc36cf in _Py_DECREF (filename=0x7f85760c9d30 "/builddir/build/BUILD/Python-3.10.2/Include/object.h", lineno=567, op=0x7f8567a1dff0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:500
#20 0x00007f8575dc3722 in _Py_XDECREF (op=0x7f8567a1dff0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Include/object.h:567
#21 0x00007f8575dc57d8 in free_keys_object (keys=0x1c84a50) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/dictobject.c:628
#22 0x00007f8575dc4b85 in dictkeys_decref (dk=0x1c84a50) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/dictobject.c:337
#23 0x00007f8575dc943d in PyDict_Clear (op=0x7f8567a17bf0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/dictobject.c:1807
#24 0x00007f8575e0d17e in type_clear (type=0x1c7c340) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Objects/typeobject.c:4305
#25 0x00007f8575f951ed in delete_garbage (tstate=0x1b29f80, gcstate=0x1b0e158, collectable=0x7fff4fcf7140, old=0x1b0e1a0) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Modules/gcmodule.c:1017
#26 0x00007f8575f95942 in gc_collect_main (tstate=0x1b29f80, generation=2, n_collected=0x0, n_uncollectable=0x0, nofail=1) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Modules/gcmodule.c:1300
#27 0x00007f8575f9756d in _PyGC_CollectNoFail (tstate=0x1b29f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Modules/gcmodule.c:2123
#28 0x00007f8575f5b51e in interpreter_clear (interp=0x1b0def0, tstate=0x1b29f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Python/pystate.c:329
#29 0x00007f8575f5b63e in _PyInterpreterState_Clear (tstate=0x1b29f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Python/pystate.c:361
#30 0x00007f8575f57ca4 in finalize_interp_clear (tstate=0x1b29f80) at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Python/pylifecycle.c:1665
#31 0x00007f8575f57e46 in Py_FinalizeEx () at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Python/pylifecycle.c:1843
#32 0x00007f8575f57e91 in Py_Finalize () at /usr/src/debug/python3.10-3.10.2-1.fc35.x86_64/Python/pylifecycle.c:1870
#33 0x000000000046b08c in qd_python_finalize () at /home/jdanek/repos/qpid/qpid-dispatch/src/python_embedded.c:83
#34 0x000000000044ff4f in qd_dispatch_free (qd=0x1b09690) at /home/jdanek/repos/qpid/qpid-dispatch/src/dispatch.c:380
#35 0x00000000004bea88 in main_process (config_path=0x7fff4fcf8a4e "conn-limit-router.conf", python_pkgdir=0x7fff4fcf8a68 "/home/jdanek/repos/qpid/qpid-dispatch/python", test_hooks=false, fd=2)
    at /home/jdanek/repos/qpid/qpid-dispatch/router/src/main.c:119
#36 0x00000000004bf531 in main (argc=5, argv=0x7fff4fcf74e8) at /home/jdanek/repos/qpid/qpid-dispatch/router/src/main.c:369

What could've caused the crash? How do I investigate it in detail? How do I fix it?


Solution

  • In my experience, the Allocated using API '', verified using API 'o' error suggests that there is a reference counting mistake somewhere in your program.

    It's easy to add or forget a Py_INCREF or Py_DECREF. Adding Py_DECREF(Py_True) or Py_DECREF(Py_False) by mistake

    Therefore, start by reviewing all your usages of Py_True, Py_False, and also Py_None.

    Python 3.11 will have a more indicative message for this kind of a problem, when you use the debug version of libpython.

    Source: https://bugs.python.org/issue45061