summaryrefslogtreecommitdiff
path: root/contrib
diff options
context:
space:
mode:
authorMichael Vrhel <michael.vrhel@artifex.com>2021-12-04 22:49:41 -0800
committerMichael Vrhel <michael.vrhel@artifex.com>2021-12-05 10:13:26 -0800
commitbbb506865bfdbe884c33be837593517569ca6245 (patch)
tree1646e4908651c42de651fdbf84094d20668fe4dc /contrib
parent31a34ce0b6b944cc9a4ce6e6c4014f091e8338c5 (diff)
downloadghostpdl-bbb506865bfdbe884c33be837593517569ca6245.tar.gz
Coverity 374391: opvp device NULL dereference
Diffstat (limited to 'contrib')
-rw-r--r--contrib/opvp/gdevopvp.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/contrib/opvp/gdevopvp.c b/contrib/opvp/gdevopvp.c
index e29425460..1f5d8a52e 100644
--- a/contrib/opvp/gdevopvp.c
+++ b/contrib/opvp/gdevopvp.c
@@ -2357,14 +2357,14 @@ opvp_open(gx_device *dev)
apiVersion[1] = 0;
dc = OpenPrinterWrapper(dev, pdev->globals.outputFD, (opvp_char_t *)pdev->globals.printerModel,
apiVersion,&api_entry);
+
if (!(pdev->globals.apiEntry)) {
- if (!(pdev->globals.apiEntry = calloc(sizeof(opvp_api_procs_t), 1))) {
- ecode = -1;
- }
+ pdev->globals.apiEntry = calloc(sizeof(opvp_api_procs_t), 1);
} else {
memset(pdev->globals.apiEntry, 0, sizeof(opvp_api_procs_t));
}
- if (dc == -1) {
+
+ if (dc == -1 || pdev->globals.apiEntry == NULL) {
ecode = -1;
if (pdev->globals.apiEntry)
free(pdev->globals.apiEntry);
@@ -2375,6 +2375,7 @@ opvp_open(gx_device *dev)
else gdev_vector_close_file((gx_device_vector *)pdev);
return ecode;
}
+
pdev->globals.printerContext = dc;
pdev->globals.nApiEntry = sizeof(opvp_api_procs_t)/sizeof(void *);
memcpy(pdev->globals.apiEntry, api_entry, pdev->globals.nApiEntry*sizeof(void *));