X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=regress%2Fhfuzzraw.c.m4;h=0ed71a2c326232cba12bb4e72fdac6b58ea575ec;hb=a469269abe5aefc86ca0ef6344eb1359985759f5;hp=04f802f3362ea2f8d0642854526405d59456aa62;hpb=e18d88ce9eeb95d68a8853ea935ac9dcfef7b933;p=adns.git diff --git a/regress/hfuzzraw.c.m4 b/regress/hfuzzraw.c.m4 index 04f802f..0ed71a2 100644 --- a/regress/hfuzzraw.c.m4 +++ b/regress/hfuzzraw.c.m4 @@ -46,11 +46,11 @@ static vbuf fdtab; #define FDF_OPEN 001u #define FDF_NONBLOCK 002u -static FILE *Tinputfile; -static int stdout_enable; +static FILE *Tinputfile, *traceout; +static int traceprint; -static void Tflushstdout( void) { - if (fflush(stdout)) Toutputerr(); +static void Tflushtrace( void) { + if (fflush(traceout)) Toutputerr(); } void Tensuresetup(void) { @@ -71,14 +71,18 @@ void Tensuresetup(void) { if (!adns__vbuf_append(&fdtab,&fdfstd,1)) Tnomem(); } - const char *proutstr= getenv("ADNS_TEST_FUZZRAW_STDOUT_ENABLE"); - if (proutstr) stdout_enable= atoi(proutstr); + const char *traceprintstr= getenv("ADNS_TEST_FUZZRAW_TRACEPRINT"); + if (traceprintstr) { + traceprint= atoi(traceprintstr); + traceout= fdopen(2,"w"); if (!traceout) Tfailed("fdopen for traceout"); + } } void Q_vb(void) { + if (!traceprint) return; /* hcommon.c.m4 can call Q_vb directly */ if (!adns__vbuf_append(&vb,"",1)) Tnomem(); - if (fprintf(stdout," %s\n",vb.buf) == EOF) Toutputerr(); - Tflushstdout(); + if (fprintf(traceout," %s\n",vb.buf) == EOF) Toutputerr(); + Tflushtrace(); } static void Pformat(const char *what) { @@ -98,9 +102,9 @@ static void Pcheckinput(void) { } static void P_read_dump(const unsigned char *p0, size_t count, ssize_t d) { - fputs(" | ",stdout); + fputs(" | ",traceout); while (count) { - fprintf(stdout,"%02x", *p0); + fprintf(traceout,"%02x", *p0); p0 += d; count--; } @@ -111,14 +115,14 @@ static void P_read(void *p, size_t sz, const char *what) { ssize_t got = fread(p,1,sz,Tinputfile); Pcheckinput(); assert(got==sz); - if (stdout_enable && sz) { - fprintf(stdout,"%8lx %8s:",pos,what); + if (traceprint>1 && sz) { + fprintf(traceout,"%8lx %8s:",pos,what); P_read_dump(p, sz, +1); if (sz<=16) { P_read_dump((const unsigned char *)p+sz-1, sz, -1); } - fputs(" |\n",stdout); - Tflushstdout(); + fputs(" |\n",traceout); + Tflushtrace(); } } @@ -199,7 +203,7 @@ m4_define(`syscall_sync',` #ifdef FUZZRAW_SYNC hm_fr_syscall_ident($'`1) static char sync_got[sizeof(sync_expect)]; - Psync(sync_expect, sync_got, sizeof(sync_got), "sync lost: exp=$1"); + Psync(sync_expect, sync_got, sizeof(sync_got), "sync lost: program did $1"); #endif ') @@ -243,7 +247,7 @@ int H$1(hm_args_massage($3,void)) { Tensuresetup(); - if (stdout_enable) { + if (traceprint) { hm_create_hqcall_args Q$1(hm_args_massage($3)); }