]> granicus.if.org Git - python/commitdiff
bpo-35847: RISC-V needs CTYPES_PASS_BY_REF_HACK (GH-11694)
authorAndreas Schwab <schwab@linux-m68k.org>
Tue, 29 Jan 2019 16:16:10 +0000 (17:16 +0100)
committerMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Tue, 29 Jan 2019 16:16:10 +0000 (08:16 -0800)
This fixes the ctypes.test.test_structures.StructureTestCase test.

https://bugs.python.org/issue35847

Misc/NEWS.d/next/Library/2019-01-29-09-11-09.bpo-35847.eiSi4t.rst [new file with mode: 0644]
Modules/_ctypes/callproc.c

diff --git a/Misc/NEWS.d/next/Library/2019-01-29-09-11-09.bpo-35847.eiSi4t.rst b/Misc/NEWS.d/next/Library/2019-01-29-09-11-09.bpo-35847.eiSi4t.rst
new file mode 100644 (file)
index 0000000..e3775f9
--- /dev/null
@@ -0,0 +1 @@
+RISC-V needed the CTYPES_PASS_BY_REF_HACK.  Fixes ctypes Structure test_pass_by_value.
index a7965c19b70c65d35943ef1e3bb488820cded792..bed5364020233705317de5e33d309c59e1286b71 100644 (file)
@@ -1058,7 +1058,7 @@ GetComError(HRESULT errcode, GUID *riid, IUnknown *pIunk)
 #endif
 
 #if (defined(__x86_64__) && (defined(__MINGW64__) || defined(__CYGWIN__))) || \
-    defined(__aarch64__)
+    defined(__aarch64__) || defined(__riscv)
 #define CTYPES_PASS_BY_REF_HACK
 #define POW2(x) (((x & ~(x - 1)) == x) ? x : 0)
 #define IS_PASS_BY_REF(x) (x > 8 || !POW2(x))