diff options
| author | Even Rouault <even.rouault@spatialys.com> | 2019-04-01 22:05:22 +0200 |
|---|---|---|
| committer | Even Rouault <even.rouault@spatialys.com> | 2019-04-01 22:06:03 +0200 |
| commit | 530913a5517fea6d23daecdb6b4d8d62fcb0a9cc (patch) | |
| tree | 7b7195d49f32dd865bcef2456394831cbccad27e /src | |
| parent | 54b21b1e97f149dce43a9199d13e421f24b6984e (diff) | |
| download | PROJ-530913a5517fea6d23daecdb6b4d8d62fcb0a9cc.tar.gz PROJ-530913a5517fea6d23daecdb6b4d8d62fcb0a9cc.zip | |
pj_gauss_ini(): fix division by zero
Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=14003
Credit to OSS Fuzz
Diffstat (limited to 'src')
| -rw-r--r-- | src/gauss.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/gauss.cpp b/src/gauss.cpp index 49ccfa1c..a34a8f5b 100644 --- a/src/gauss.cpp +++ b/src/gauss.cpp @@ -65,13 +65,18 @@ void *pj_gauss_ini(double e, double phi0, double *chi, double *rc) { } *chi = asin(sphi / en->C); en->ratexp = 0.5 * en->C * e; + double srat_val = srat(en->e * sphi, en->ratexp); + if (srat_val == 0.0) { + free(en); + return nullptr; + } if( .5 * phi0 + M_FORTPI < 1e-10 ) { - en->K = 1.0 / srat(en->e * sphi, en->ratexp); + en->K = 1.0 / srat_val; } else { en->K = tan(.5 * *chi + M_FORTPI) / ( pow(tan(.5 * phi0 + M_FORTPI), en->C) * - srat(en->e * sphi, en->ratexp) ); + srat_val ); } return ((void *)en); } |
