diff options
author | Tim Peters <tim.peters@gmail.com> | 2001-07-18 20:47:31 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2001-07-18 20:47:31 (GMT) |
commit | 3dac559299100c135fded9bb22536dbb1379a9bc (patch) | |
tree | 3a026da48e984aaf08e47be1bc3f93f625be6f0a | |
parent | cdab3bf7eb0810fcda21be065868f3da330779a1 (diff) | |
download | cpython-3dac559299100c135fded9bb22536dbb1379a9bc.zip cpython-3dac559299100c135fded9bb22536dbb1379a9bc.tar.gz cpython-3dac559299100c135fded9bb22536dbb1379a9bc.tar.bz2 |
SF bug #442520: test_struct fails on SPARC.
The ob_sval member of a string object isn't necessarily aligned to better
than a native long, so the new "q" and "Q" struct codes can't get away w/
casting tricks on platforms where LONG_LONG requires stricter-than-long
alignment. After I thought of a few elaborate workarounds, Guido bashed
me over the head with the obvious memcpy approach, herewith implemented.
-rw-r--r-- | Modules/structmodule.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/Modules/structmodule.c b/Modules/structmodule.c index 66b3ac3..46aa75b 100644 --- a/Modules/structmodule.c +++ b/Modules/structmodule.c @@ -547,13 +547,19 @@ nu_ulong(const char *p, const formatdef *f) static PyObject * nu_longlong(const char *p, const formatdef *f) { - return PyLong_FromLongLong(*(LONG_LONG *)p); + /* p may not be properly aligned */ + LONG_LONG x; + memcpy(&x, p, sizeof(LONG_LONG)); + return PyLong_FromLongLong(x); } static PyObject * nu_ulonglong(const char *p, const formatdef *f) { - return PyLong_FromUnsignedLongLong(*(unsigned LONG_LONG *)p); + /* p may not be properly aligned */ + unsigned LONG_LONG x; + memcpy(&x, p, sizeof(unsigned LONG_LONG)); + return PyLong_FromUnsignedLongLong(x); } #endif @@ -700,7 +706,7 @@ np_longlong(char *p, PyObject *v, const formatdef *f) LONG_LONG x; if (get_longlong(v, &x) < 0) return -1; - * (LONG_LONG *)p = x; + memcpy(p, &x, sizeof(LONG_LONG)); return 0; } @@ -710,7 +716,7 @@ np_ulonglong(char *p, PyObject *v, const formatdef *f) unsigned LONG_LONG x; if (get_ulonglong(v, &x) < 0) return -1; - * (unsigned LONG_LONG *)p = x; + memcpy(p, &x, sizeof(unsigned LONG_LONG)); return 0; } #endif |