Skip to content
Snippets Groups Projects
Unverified Commit d79dd929 authored by Michael Curran's avatar Michael Curran Committed by GitHub
Browse files

bpo-38748: Add ctypes test for stack corruption due to misaligned arguments (GH-26204)

parent 85752dec
No related branches found
No related tags found
No related merge requests found
import sys
import functools
import unittest
from test import support
......@@ -150,6 +151,18 @@ def __del__(self):
gc.collect()
CFUNCTYPE(None)(lambda x=Nasty(): None)
@need_symbol('WINFUNCTYPE')
def test_i38748_stackCorruption(self):
callback_funcType = WINFUNCTYPE(c_long, c_long, c_longlong)
@callback_funcType
def callback(a, b):
c = a + b
print(f"a={a}, b={b}, c={c}")
return c
dll = cdll[_ctypes_test.__file__]
# With no fix for i38748, the next line will raise OSError and cause the test to fail.
self.assertEqual(dll._test_i38748_runCallback(callback, 5, 10), 15)
@need_symbol('WINFUNCTYPE')
class StdcallCallbacks(Callbacks):
......
......@@ -1034,6 +1034,19 @@ EXPORT (HRESULT) KeepObject(IUnknown *punk)
#endif
#ifdef MS_WIN32
// i38748: c stub for testing stack corruption
// When executing a Python callback with a long and a long long
typedef long(__stdcall *_test_i38748_funcType)(long, long long);
EXPORT(long) _test_i38748_runCallback(_test_i38748_funcType callback, int a, int b) {
return callback(a, b);
}
#endif
static struct PyModuleDef_Slot _ctypes_test_slots[] = {
{0, NULL}
};
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment