aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEven Rouault <even.rouault@spatialys.com>2019-02-03 12:23:50 +0100
committerEven Rouault <even.rouault@spatialys.com>2019-02-03 12:23:50 +0100
commitb30ed5cba50688cea9ac2af90855177f84efea5a (patch)
tree27ca2d29d8cef803a5659f61d3b0bb48a6771426
parentabad23412f0920276c32567c8f237be23aa94941 (diff)
downloadPROJ-b30ed5cba50688cea9ac2af90855177f84efea5a.tar.gz
PROJ-b30ed5cba50688cea9ac2af90855177f84efea5a.zip
labrd: avoid floating point division by zero. Fixes https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=12849. Credit to OSS Fuzz
-rw-r--r--src/projections/labrd.cpp4
-rw-r--r--test/gie/builtins.gie4
2 files changed, 8 insertions, 0 deletions
diff --git a/src/projections/labrd.cpp b/src/projections/labrd.cpp
index 330c105f..85ab3ddd 100644
--- a/src/projections/labrd.cpp
+++ b/src/projections/labrd.cpp
@@ -108,6 +108,10 @@ PJ *PROJECTION(labrd) {
return pj_default_destructor (P, ENOMEM);
P->opaque = Q;
+ if (P->phi0 == 0.) {
+ return pj_default_destructor(P, PJD_ERR_LAT_0_IS_ZERO);
+ }
+
Az = pj_param(P->ctx, P->params, "razi").f;
sinp = sin(P->phi0);
t = 1. - P->es * sinp * sinp;
diff --git a/test/gie/builtins.gie b/test/gie/builtins.gie
index bc9374a5..82222210 100644
--- a/test/gie/builtins.gie
+++ b/test/gie/builtins.gie
@@ -2243,6 +2243,10 @@ expect 0.498202281 2.000904357
accept -200 -100
expect 0.498202283 1.999095641
+-------------------------------------------------------------------------------
+operation +proj=labrd +ellps=GRS80 +lat_0=0
+accept 0 0
+expect failure errno lat_0_is_zero
===============================================================================
Lambert Azimuthal Equal Area