X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=regress%2Fhfuzzraw.c.m4;h=00d7030f6b447e8cbbca2a0b73fd25c00b54dc3d;hb=5e067362f7da2a4b42143475e8e847cce5318beb;hp=24aff421d8c97bda8b1e7f1c174dd23c919f8f4c;hpb=b99b97f7ad6fecf61c598ca05847cfd13e790f89;p=adns.git diff --git a/regress/hfuzzraw.c.m4 b/regress/hfuzzraw.c.m4 index 24aff42..00d7030 100644 --- a/regress/hfuzzraw.c.m4 +++ b/regress/hfuzzraw.c.m4 @@ -47,8 +47,17 @@ static vbuf fdtab; #define FDF_NONBLOCK 002u static FILE *Tinputfile; +static int stdout_enable; -void Q_vb(void) { abort(); /* we neve called Q_anythig */ } +static void Tflushstdout( void) { + if (fflush(stdout)) Toutputerr(); +} + +void Q_vb(void) { + if (!adns__vbuf_append(&vb,"",1)) Tnomem(); + if (fprintf(stdout," %s\n",vb.buf) == EOF) Toutputerr(); + Tflushstdout(); +} static void Pformat(const char *what) { fprintf(stderr,"adns test harness: format error in raw log input file: %s\n",what); @@ -56,6 +65,9 @@ static void Pformat(const char *what) { } extern void Tshutdown(void) { + int c= fgetc(Tinputfile); + if (c!=EOF) Pformat("unwanted additional syscall reply data"); + if (ferror(Tinputfile)) Tfailed("read test log input (at end)"); } static void Pcheckinput(void) { @@ -64,6 +76,11 @@ static void Pcheckinput(void) { } void Tensurerecordfile(void) { + static int done; + + if (done) return; + done++; + int fd; fd = Ttestinputfd(); @@ -75,15 +92,38 @@ void Tensurerecordfile(void) { const char fdfstd = FDF_OPEN; if (!adns__vbuf_append(&fdtab,&fdfstd,1)) Tnomem(); } + + const char *proutstr= getenv("ADNS_TEST_FUZZRAW_STDOUT_ENABLE"); + if (proutstr) stdout_enable= atoi(proutstr); } -static void P_read(void *p, size_t sz) { - ssize_t got = fread(&p,1,sz,Tinputfile); + +static void P_read_dump(const unsigned char *p0, size_t count, ssize_t d) { + fputs(" | ",stdout); + while (count) { + fprintf(stdout,"%02x", *p0); + p0 += d; + count--; + } +} + +static void P_read(void *p, size_t sz, const char *what) { + long pos = ftell(Tinputfile); + ssize_t got = fread(p,1,sz,Tinputfile); Pcheckinput(); assert(got==sz); + if (stdout_enable && sz) { + fprintf(stdout,"%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(); + } } -#define P_READ(x) (P_read(&(x), sizeof((x)))) +#define P_READ(x) (P_read(&(x), sizeof((x)), #x)) static unsigned P_fdf(int fd) { assert(fd>=0 && fdmaxlen) Pformat("bad byte block len"); - P_read(buf, l); + P_read(buf, l, "bytes"); return l; } -static void Pfdset(fd_set *set, int max) { - uint16_t got; - int fd, ngot=0; +static void Pfdset(fd_set *set, int max, int *r_io) { + uint16_t fdmap; + int fd, nfdmap=0; + + if (!set) + return; + + for (fd=max-1; fd>=0; fd--) { + if (nfdmap==0) { + P_READ(fdmap); + nfdmap= 16; + } + _Bool y = fdmap & 1u; + fdmap >>= 1; + nfdmap--; - for (fd=0; fd>= 1; - ngot--; } } +#ifdef FUZZRAW_SYNC +static void Psync(const char *exp, char *got, size_t sz, const char *what) { + P_read(got,sz,"syscall"); + if (memcmp(exp,got,sz)) Pformat(what); +} +#endif + #ifdef HAVE_POLL -static void Ppollfds(struct pollfd *fds, int nfds) { -int fd; +static void Ppollfds(struct pollfd *fds, int nfds, int *r_io) { + int fd; for (fd=0; fd0 && e<=255) { + errno= e; + return -1; + } else if (e) { + Pformat("wrong errno value"); + } + return 0; +} + m4_define(`hm_syscall', ` hm_create_proto_h int H$1(hm_args_massage($3,void)) { int r; - m4_define(`hm_rv_fd',`') - m4_define(`hm_rv_any',`') - m4_define(`hm_rv_len',`') - m4_define(`hm_rv_must',`') - m4_define(`hm_rv_succfail',`') - m4_define(`hm_rv_fcntl',`') + hm_create_nothing $2 hm_create_hqcall_vars @@ -171,18 +239,20 @@ int H$1(hm_args_massage($3,void)) { Tensurerecordfile(); + if (stdout_enable) { + hm_create_hqcall_args + Q$1(hm_args_massage($3)); + } + +#ifdef FUZZRAW_SYNC + static const char sync_expect[]= "$1"; + static char sync_got[sizeof(sync_expect)]; + Psync(sync_expect, sync_got, sizeof(sync_got), "sync lost: exp=$1"); +#endif + m4_define(`hm_rv_succfail',` - P_READ(r); - if (r<0 && -r0 && r<=255) { - errno= r; - return -1; - } else if (r) { - Pformat("wrong errno value"); - } - r= 0; + r= P_succfail(); + if (r<0) return r; ') m4_define(`hm_rv_any',` @@ -199,6 +269,8 @@ int H$1(hm_args_massage($3,void)) { m4_define(`hm_rv_must',` r= 0; ') + m4_define(`hm_rv_select',`hm_rv_succfail') + m4_define(`hm_rv_poll',`hm_rv_succfail') m4_define(`hm_rv_fcntl',` unsigned flg = P_fdf(fd); if (cmd == F_GETFL) { @@ -216,22 +288,24 @@ int H$1(hm_args_massage($3,void)) { m4_define(`hm_rv_fd',` hm_rv_succfail if (!r) { - for (;;) { - assert(r < 1000); - if (r >= fdtab.used) - if (!adns__vbuf_append(&fdtab,"\0",1)) Tnomem(); - assert(r < fdtab.used); - if (!(fdtab.buf[r] & FDF_OPEN)) break; - r++; + int newfd; + P_READ(newfd); + if (newfd<0 || newfd>1000) Pformat("new fd out of range"); + adns__vbuf_ensure(&fdtab, newfd+1); + if (fdtab.used <= newfd) { + memset(fdtab.buf+fdtab.used, 0, newfd+1-fdtab.used); + fdtab.used= newfd+1; } - fdtab.buf[r] |= FDF_OPEN; + if (fdtab.buf[newfd]) Pformat("new fd already in use"); + fdtab.buf[newfd] |= FDF_OPEN; + r= newfd; } ') $2 hm_create_nothing - m4_define(`hm_arg_fdset_io',`Pfdset($'`1,$'`2);') - m4_define(`hm_arg_pollfds_io',`Ppollfds($'`1,$'`2);') + m4_define(`hm_arg_fdset_io',`Pfdset($'`1,$'`2,&r);') + m4_define(`hm_arg_pollfds_io',`Ppollfds($'`1,$'`2,&r);') m4_define(`hm_arg_addr_out',`Paddr($'`1,$'`2);') $3 @@ -239,6 +313,14 @@ int H$1(hm_args_massage($3,void)) { m4_define(`hm_arg_bytes_out',`r= Pbytes($'`2,$'`4);') $3 + hm_create_nothing + m4_define(`hm_rv_selectpoll',` + if (($'`1) && !r) Pformat("select/poll returning 0 but infinite timeout"); + ') + m4_define(`hm_rv_select',`hm_rv_selectpoll(!to)') + m4_define(`hm_rv_poll',`hm_rv_selectpoll(timeout<0)') + $2 + return r; } ') @@ -248,9 +330,7 @@ m4_define(`hm_specsyscall', `') m4_include(`hsyscalls.i4') int Hclose(int fd) { - int r; P_fdf(fd); fdtab.buf[fd]= 0; - hm_rv_succfail - return r; + return P_succfail(); }