diff options
author | Stefan Krah <skrah@bytereef.org> | 2012-06-10 14:50:55 (GMT) |
---|---|---|
committer | Stefan Krah <skrah@bytereef.org> | 2012-06-10 14:50:55 (GMT) |
commit | 9253862f45047f66460949e474cf97fa19d2629c (patch) | |
tree | cdce10bafd00133c90d9a0c5862386bc73702b9f /Modules/_decimal/libmpdec | |
parent | 1c2018c311351ff90b0c278f289291822bcd1e83 (diff) | |
download | cpython-9253862f45047f66460949e474cf97fa19d2629c.zip cpython-9253862f45047f66460949e474cf97fa19d2629c.tar.gz cpython-9253862f45047f66460949e474cf97fa19d2629c.tar.bz2 |
1) State restrictions for the transform length.
2) Switch argument order to match the function signature of mpd_calloc()
(cosmetic change, since the order is irrelevant).
Diffstat (limited to 'Modules/_decimal/libmpdec')
-rw-r--r-- | Modules/_decimal/libmpdec/mpdecimal.c | 15 |
1 files changed, 10 insertions, 5 deletions
diff --git a/Modules/_decimal/libmpdec/mpdecimal.c b/Modules/_decimal/libmpdec/mpdecimal.c index 40d33cf..f5be747 100644 --- a/Modules/_decimal/libmpdec/mpdecimal.c +++ b/Modules/_decimal/libmpdec/mpdecimal.c @@ -5158,7 +5158,11 @@ _mpd_kmul(const mpd_uint_t *u, const mpd_uint_t *v, } -/* Determine the minimum length for the number theoretic transform. */ +/* + * Determine the minimum length for the number theoretic transform. Valid + * transform lengths are 2**n or 3*2**n, where 2**n <= MPD_MAXTRANSFORM_2N. + * The function finds the shortest length m such that rsize <= m. + */ static inline mpd_size_t _mpd_get_transform_len(mpd_size_t rsize) { @@ -5169,6 +5173,7 @@ _mpd_get_transform_len(mpd_size_t rsize) log2rsize = mpd_bsr(rsize); if (rsize <= 1024) { + /* 2**n is faster in this range. */ x = ((mpd_size_t)1)<<log2rsize; return (rsize == x) ? x : x<<1; } @@ -5264,13 +5269,13 @@ _mpd_fntmul(const mpd_uint_t *u, const mpd_uint_t *v, goto malloc_error; } - if ((c1 = mpd_calloc(sizeof *c1, n)) == NULL) { + if ((c1 = mpd_calloc(n, sizeof *c1)) == NULL) { goto malloc_error; } - if ((c2 = mpd_calloc(sizeof *c2, n)) == NULL) { + if ((c2 = mpd_calloc(n, sizeof *c2)) == NULL) { goto malloc_error; } - if ((c3 = mpd_calloc(sizeof *c3, n)) == NULL) { + if ((c3 = mpd_calloc(n, sizeof *c3)) == NULL) { goto malloc_error; } @@ -5286,7 +5291,7 @@ _mpd_fntmul(const mpd_uint_t *u, const mpd_uint_t *v, } } else { - if ((vtmp = mpd_calloc(sizeof *vtmp, n)) == NULL) { + if ((vtmp = mpd_calloc(n, sizeof *vtmp)) == NULL) { goto malloc_error; } |