diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2015-06-21 21:17:42 -0700 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-06-21 21:17:42 -0700 |
commit | ce1be9c2eb7df515690d4861a5ed3f813b82c076 (patch) | |
tree | 333ec55e71bb04990eba0987a7adfe497d58ac32 | |
parent | f5726c3d184dce88822fd84dbe994d6fa92c089b (diff) | |
download | subsurface-ce1be9c2eb7df515690d4861a5ed3f813b82c076.tar.gz |
Prevent theoretical out of bounds access
When I stare at the code enough I can convince myself that cylinderindex
will always be assigned a sane value, but on the flip side, making sure
nothing stupid happens is cheap insurance.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | gaspressures.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/gaspressures.c b/gaspressures.c index 4edcf7e35..5f46d6080 100644 --- a/gaspressures.c +++ b/gaspressures.c @@ -417,7 +417,8 @@ void populate_pressure_information(struct dive *dive, struct divecomputer *dc, s /* transmitter stopped transmitting cylinder pressure data */ current = pr_track_alloc(pressure, entry->sec); - track_pr[cylinderindex] = list_add(track_pr[cylinderindex], current); + if (cylinderindex >= 0) + track_pr[cylinderindex] = list_add(track_pr[cylinderindex], current); } if (missing_pr) { |