=================================================================== RCS file: /cvsrepo/anoncvs/cvs/src/usr.bin/ssh/dispatch.c,v retrieving revision 1.11.2.1 retrieving revision 1.12 diff -u -r1.11.2.1 -r1.12 --- src/usr.bin/ssh/dispatch.c 2002/03/07 17:37:46 1.11.2.1 +++ src/usr.bin/ssh/dispatch.c 2001/12/20 22:50:24 1.12 @@ -22,7 +22,7 @@ * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "includes.h" -RCSID("$OpenBSD: dispatch.c,v 1.11.2.1 2002/03/07 17:37:46 jason Exp $"); +RCSID("$OpenBSD: dispatch.c,v 1.12 2001/12/20 22:50:24 djm Exp $"); #include "ssh1.h" #include "ssh2.h" @@ -37,40 +37,19 @@ dispatch_fn *dispatch[DISPATCH_MAX]; void -dispatch_protocol_error(int type, u_int32_t seq, void *ctxt) +dispatch_protocol_error(int type, int plen, u_int32_t seq, void *ctxt) { - log("dispatch_protocol_error: type %d seq %u", type, seq); - if (!compat20) - fatal("protocol error"); - packet_start(SSH2_MSG_UNIMPLEMENTED); - packet_put_int(seq); - packet_send(); - packet_write_wait(); + fatal("dispatch_protocol_error: type %d seq %u plen %d", type, + seq, plen); } void -dispatch_protocol_ignore(int type, u_int32_t seq, void *ctxt) -{ - log("dispatch_protocol_ignore: type %d seq %u", type, seq); -} -void dispatch_init(dispatch_fn *dflt) { - u_int i; + int i; for (i = 0; i < DISPATCH_MAX; i++) dispatch[i] = dflt; } void -dispatch_range(u_int from, u_int to, dispatch_fn *fn) -{ - u_int i; - - for (i = from; i <= to; i++) { - if (i >= DISPATCH_MAX) - break; - dispatch[i] = fn; - } -} -void dispatch_set(int type, dispatch_fn *fn) { dispatch[type] = fn; @@ -79,18 +58,19 @@ dispatch_run(int mode, int *done, void *ctxt) { for (;;) { + int plen; int type; u_int32_t seqnr; if (mode == DISPATCH_BLOCK) { - type = packet_read_seqnr(&seqnr); + type = packet_read_seqnr(&plen, &seqnr); } else { - type = packet_read_poll_seqnr(&seqnr); + type = packet_read_poll_seqnr(&plen, &seqnr); if (type == SSH_MSG_NONE) return; } if (type > 0 && type < DISPATCH_MAX && dispatch[type] != NULL) - (*dispatch[type])(type, seqnr, ctxt); + (*dispatch[type])(type, plen, seqnr, ctxt); else packet_disconnect("protocol error: rcvd type %d", type); if (done != NULL && *done)