summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2016-10-23 22:53:05 -0400
committermidipix <writeonce@midipix.org>2016-11-11 00:22:48 -0500
commit4eae2803e736b7b083652c733b121fad00cc6672 (patch)
treed95e7baa60b4ea1061b5f0e905b0dc53b3352658
parent4ecd081e04021478af3ae9879bdc6b228dbc8c05 (diff)
downloadmdso-4eae2803e736b7b083652c733b121fad00cc6672.tar.bz2
mdso-4eae2803e736b7b083652c733b121fad00cc6672.tar.xz
driver: unit context: added error trace support.
-rw-r--r--src/driver/mdso_unit_ctx.c23
1 files changed, 17 insertions, 6 deletions
diff --git a/src/driver/mdso_unit_ctx.c b/src/driver/mdso_unit_ctx.c
index 244912d..7181982 100644
--- a/src/driver/mdso_unit_ctx.c
+++ b/src/driver/mdso_unit_ctx.c
@@ -14,6 +14,7 @@
#include <mdso/mdso.h>
#include "mdso_driver_impl.h"
+#include "mdso_errinfo_impl.h"
static int mdso_free_unit_ctx_impl(struct mdso_unit_ctx_impl * ctx, int status)
{
@@ -169,26 +170,36 @@ int mdso_get_unit_ctx(
FILE * ftmp;
int fd;
- if (!dctx || !(ctx = calloc(1,sizeof(*ctx))))
- return -1;
+ if (!dctx)
+ return MDSO_CUSTOM_ERROR(dctx,0);
+
+ else if (!(ctx = calloc(1,sizeof(*ctx))))
+ return MDSO_BUFFER_ERROR(dctx);
if (strcmp(path,"-"))
fd = -1;
+
else if (!(ftmp = mdso_stdin_to_tmp(dctx)))
- return mdso_free_unit_ctx_impl(ctx,-1);
+ return mdso_free_unit_ctx_impl(
+ ctx,MDSO_FILE_ERROR(dctx));
+
else if ((fd = dup(fileno(ftmp))) < 0)
- return mdso_free_unit_ctx_impl(ctx,-1);
+ return mdso_free_unit_ctx_impl(
+ ctx,MDSO_SYSTEM_ERROR(dctx));
+
else
fclose(ftmp);
if (mdso_map_input(fd,path,PROT_READ,&ctx->map))
- return mdso_free_unit_ctx_impl(ctx,-1);
+ return mdso_free_unit_ctx_impl(
+ ctx,MDSO_SYSTEM_ERROR(dctx));
if (fd > 0)
close(fd);
if (mdso_create_symbol_vector(ctx))
- return mdso_free_unit_ctx_impl(ctx,-1);
+ return mdso_free_unit_ctx_impl(
+ ctx,MDSO_BUFFER_ERROR(dctx));
memcpy(&ctx->cctx,dctx->cctx,
sizeof(ctx->cctx));