diff options
| author | Berker Peksag <berker.peksag@gmail.com> | 2016-08-22 18:05:56 +0300 |
|---|---|---|
| committer | Berker Peksag <berker.peksag@gmail.com> | 2016-08-22 18:05:56 +0300 |
| commit | 4b7b565c581f8f418df6e661ebf7d906794e7142 (patch) | |
| tree | 781a57310d7398b26e91bf46109bd02cb1a049fb | |
| parent | 844796530a21f2a8689f2b9e01035d4a64a95275 (diff) | |
| download | cpython-git-4b7b565c581f8f418df6e661ebf7d906794e7142.tar.gz | |
Issue #27587: Move null pointer check earlier in _PyState_AddModule()
This was found by PVS-Studio:
V595 The 'def' pointer was utilized before it was verified
against nullptr. Check lines: 286, 292. pystate.c 286
Initial patch by Christian Heimes.
| -rw-r--r-- | Misc/NEWS | 4 | ||||
| -rw-r--r-- | Python/pystate.c | 6 |
2 files changed, 8 insertions, 2 deletions
@@ -10,6 +10,10 @@ Release date: TBA Core and Builtins ----------------- +- Issue #27587: Fix another issue found by PVS-Studio: Null pointer check + after use of 'def' in _PyState_AddModule(). + Initial patch by Christian Heimes. + - Issue #27782: Multi-phase extension module import now correctly allows the ``m_methods`` field to be used to add module level functions to instances of non-module types returned from ``Py_create_mod``. Patch by Xiang Zhang. diff --git a/Python/pystate.c b/Python/pystate.c index 6d1c6d0a1f..24e20c3e23 100644 --- a/Python/pystate.c +++ b/Python/pystate.c @@ -281,14 +281,16 @@ int _PyState_AddModule(PyObject* module, struct PyModuleDef* def) { PyInterpreterState *state; + if (!def) { + assert(PyErr_Occurred()); + return -1; + } if (def->m_slots) { PyErr_SetString(PyExc_SystemError, "PyState_AddModule called on module with slots"); return -1; } state = GET_INTERP_STATE(); - if (!def) - return -1; if (!state->modules_by_index) { state->modules_by_index = PyList_New(0); if (!state->modules_by_index) |
