diff options
author | Damien George <damien.p.george@gmail.com> | 2015-04-25 23:51:14 +0100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2015-04-25 23:51:14 +0100 |
commit | 9472907ae1906ccff7ce5cab24f0fa9d146c4534 (patch) | |
tree | 68f5c29f761b7318f5f21f7bb82cbd305e92bce4 | |
parent | ae2c81ff388d9b06bc11ac1e14bd5d71b4f4637c (diff) | |
download | micropython-9472907ae1906ccff7ce5cab24f0fa9d146c4534.tar.gz micropython-9472907ae1906ccff7ce5cab24f0fa9d146c4534.zip |
py: Fix handling of negative numbers in struct.pack of q/Q.
-rw-r--r-- | py/binary.c | 4 | ||||
-rw-r--r-- | py/mpz.c | 4 |
2 files changed, 6 insertions, 2 deletions
diff --git a/py/binary.c b/py/binary.c index 8b5c05ab3e..ee00c4e348 100644 --- a/py/binary.c +++ b/py/binary.c @@ -291,6 +291,10 @@ void mp_binary_set_val(char struct_type, char val_type, mp_obj_t val_in, byte ** #endif { val = mp_obj_get_int(val_in); + // sign extend if needed + if (BYTES_PER_WORD < 8 && size > sizeof(val) && is_signed(val_type) && (mp_int_t)val < 0) { + memset(p + sizeof(val), 0xff, size - sizeof(val)); + } } } @@ -1441,8 +1441,8 @@ void mpz_as_bytes(const mpz_t *z, bool big_endian, mp_uint_t len, byte *buf) { for (; bits >= 8; bits -= 8, d >>= 8) { mpz_dig_t val = d; if (z->neg) { - d = (~d & 0xff) + carry; - carry = d >> 8; + val = (~val & 0xff) + carry; + carry = val >> 8; } if (big_endian) { *--b = val; |