Blame SOURCES/ghostscript-cve-2013-5653.patch

ea5d11
From 950c602dc2dbbcbf5a856e85dba99bc8ac8420b9 Mon Sep 17 00:00:00 2001
ea5d11
From: Chris Liddell <chris.liddell@artifex.com>
ea5d11
Date: Sat, 5 Mar 2016 14:56:03 -0800
ea5d11
Subject: [PATCH 1/1] Bug 694724: Have filenameforall and getenv honor SAFER
ea5d11
ea5d11
---
ea5d11
 Resource/Init/gs_init.ps |  1 +
ea5d11
 psi/zfile.c              | 36 ++++++++++++++++++++----------------
ea5d11
 2 files changed, 21 insertions(+), 16 deletions(-)
ea5d11
ea5d11
diff --git a/Resource/Init/gs_init.ps b/Resource/Init/gs_init.ps
ea5d11
index c3f567d..abb9489 100644
ea5d11
--- a/Resource/Init/gs_init.ps
ea5d11
+++ b/Resource/Init/gs_init.ps
ea5d11
@@ -2019,6 +2019,7 @@ readonly def
ea5d11
       /LockFilePermissions //true
ea5d11
     >> setuserparams
ea5d11
   }
ea5d11
+  systemdict /getenv {pop //false} put
ea5d11
   if
ea5d11
   % setpagedevice has the side effect of clearing the page, but
ea5d11
   % we will just document that. Using setpagedevice keeps the device
ea5d11
diff --git a/psi/zfile.c b/psi/zfile.c
ea5d11
index 4011789..dd05919 100644
ea5d11
--- a/psi/zfile.c
ea5d11
+++ b/psi/zfile.c
ea5d11
@@ -371,22 +371,26 @@ file_continue(i_ctx_t *i_ctx_p)
ea5d11
 
ea5d11
     if (len < devlen)
ea5d11
         return_error(e_rangecheck);     /* not even room for device len */
ea5d11
-    memcpy((char *)pscratch->value.bytes, iodev->dname, devlen);
ea5d11
-    code = iodev->procs.enumerate_next(pfen, (char *)pscratch->value.bytes + devlen,
ea5d11
-                len - devlen);
ea5d11
-    if (code == ~(uint) 0) {    /* all done */
ea5d11
-        esp -= 5;               /* pop proc, pfen, devlen, iodev , mark */
ea5d11
-        return o_pop_estack;
ea5d11
-    } else if (code > len)      /* overran string */
ea5d11
-        return_error(e_rangecheck);
ea5d11
-    else {
ea5d11
-        push(1);
ea5d11
-        ref_assign(op, pscratch);
ea5d11
-        r_set_size(op, code + devlen);
ea5d11
-        push_op_estack(file_continue);  /* come again */
ea5d11
-        *++esp = pscratch[2];   /* proc */
ea5d11
-        return o_push_estack;
ea5d11
-    }
ea5d11
+
ea5d11
+    do {
ea5d11
+        memcpy((char *)pscratch->value.bytes, iodev->dname, devlen);
ea5d11
+        code = iodev->procs.enumerate_next(pfen, (char *)pscratch->value.bytes + devlen,
ea5d11
+                    len - devlen);
ea5d11
+        if (code == ~(uint) 0) {    /* all done */
ea5d11
+            esp -= 5;               /* pop proc, pfen, devlen, iodev , mark */
ea5d11
+            return o_pop_estack;
ea5d11
+        } else if (code > len)      /* overran string */
ea5d11
+            return_error(gs_error_rangecheck);
ea5d11
+        else if (iodev != iodev_default(imemory)
ea5d11
+              || (check_file_permissions_reduced(i_ctx_p, (char *)pscratch->value.bytes, code + devlen, "PermitFileReading")) == 0) {
ea5d11
+            push(1);
ea5d11
+            ref_assign(op, pscratch);
ea5d11
+            r_set_size(op, code + devlen);
ea5d11
+            push_op_estack(file_continue);  /* come again */
ea5d11
+            *++esp = pscratch[2];   /* proc */
ea5d11
+            return o_push_estack;
ea5d11
+        }
ea5d11
+    } while(1);
ea5d11
 }
ea5d11
 /* Cleanup procedure for enumerating files */
ea5d11
 static int
ea5d11
-- 
ea5d11
2.7.4
ea5d11