Blame SOURCES/ghostscript-cve-2016-7979.patch

ea5d11
From b80fc8cd2469fcdab0630cd507f42b410bb96fda Mon Sep 17 00:00:00 2001
ea5d11
From: Ken Sharp <ken.sharp@artifex.com>
ea5d11
Date: Wed, 5 Oct 2016 10:10:58 +0100
ea5d11
Subject: [PATCH] DSC parser - validate parameters
ea5d11
ea5d11
Bug #697190 ".initialize_dsc_parser doesn't validate the parameter is a dict type before using it."
ea5d11
ea5d11
Regardless of any security implications, its simply wrong for a PostScript
ea5d11
operator not to validate its parameter(s).
ea5d11
ea5d11
No differences expected.
ea5d11
---
ea5d11
 psi/zdscpars.c | 13 +++++++++----
ea5d11
 1 file changed, 9 insertions(+), 4 deletions(-)
ea5d11
ea5d11
diff --git a/psi/zdscpars.c b/psi/zdscpars.c
ea5d11
index a6f8fc9..fa61d88 100644
ea5d11
--- a/psi/zdscpars.c
ea5d11
+++ b/psi/zdscpars.c
ea5d11
@@ -132,11 +132,16 @@ zinitialize_dsc_parser(i_ctx_t *i_ctx_p)
ea5d11
     ref local_ref;
ea5d11
     int code;
ea5d11
     os_ptr const op = osp;
ea5d11
-    dict * const pdict = op->value.pdict;
ea5d11
-    gs_memory_t * const mem = (gs_memory_t *)dict_memory(pdict);
ea5d11
-    dsc_data_t * const data =
ea5d11
-        gs_alloc_struct(mem, dsc_data_t, &st_dsc_data_t, "DSC parser init");
ea5d11
+    dict *pdict;
ea5d11
+    gs_memory_t *mem;
ea5d11
+    dsc_data_t *data;
ea5d11
 
ea5d11
+    check_read_type(*op, t_dictionary);
ea5d11
+
ea5d11
+    pdict = op->value.pdict;
ea5d11
+    mem = (gs_memory_t *)dict_memory(pdict);
ea5d11
+
ea5d11
+    data = gs_alloc_struct(mem, dsc_data_t, &st_dsc_data_t, "DSC parser init");
ea5d11
     if (!data)
ea5d11
         return_error(e_VMerror);
ea5d11
     data->document_level = 0;
ea5d11
-- 
ea5d11
2.7.4
ea5d11