diff --git a/pearl.c b/pearl.c index 7a9e854..9603bec 100644 --- a/pearl.c +++ b/pearl.c @@ -35,6 +35,7 @@ #include #include #include +#include #include #include "puzzles.h" @@ -272,6 +273,8 @@ static const char *validate_params(const game_params *params, bool full) { if (params->w < 5) return "Width must be at least five"; if (params->h < 5) return "Height must be at least five"; + if (params->w > INT_MAX / params->h) + return "Width times height must not be unreasonably large"; if (params->difficulty < 0 || params->difficulty >= DIFFCOUNT) return "Unknown difficulty level"; if (params->difficulty >= DIFF_TRICKY && params->w + params->h < 11)