Eric Faurot writes:

> Hi.
>
> When using the internal io api, the caller had to explicitely reset an
> io event in some cases (basically when data is buffered outside of an
> io callback context) which could easily be missed.  This has been the
> cause of some of smtpd bugs in the past (hanging sessions).
>
> After the recent changes, it's now possible to make it a lot simpler
> by triggering an event reload internally when data is queued. So the
> api user does not have to worry about it.
>
> Eric.

Ok sunil@

>
> Index: ioev.c
> ===================================================================
> RCS file: /cvs/src/usr.sbin/smtpd/ioev.c,v
> retrieving revision 1.31
> diff -u -p -r1.31 ioev.c
> --- ioev.c    22 Nov 2016 07:28:42 -0000      1.31
> +++ ioev.c    22 Nov 2016 22:24:25 -0000
> @@ -370,13 +370,25 @@ io_set_write(struct io *io)
>  int
>  io_write(struct io *io, const void *buf, size_t len)
>  {
> -     return iobuf_queue(io->iobuf, buf, len);
> +     int r;
> +
> +     r = iobuf_queue(io->iobuf, buf, len);
> +
> +     io_reload(io);
> +
> +     return r;
>  }
>  
>  int
>  io_writev(struct io *io, const struct iovec *iov, int iovcount)
>  {
> -     return iobuf_queuev(io->iobuf, iov, iovcount);
> +     int r;
> +
> +     r = iobuf_queuev(io->iobuf, iov, iovcount);
> +
> +     io_reload(io);
> +
> +     return r;
>  }
>  
>  int
> Index: mta_session.c
> ===================================================================
> RCS file: /cvs/src/usr.sbin/smtpd/mta_session.c,v
> retrieving revision 1.89
> diff -u -p -r1.89 mta_session.c
> --- mta_session.c     22 Nov 2016 07:28:42 -0000      1.89
> +++ mta_session.c     22 Nov 2016 22:24:26 -0000
> @@ -280,7 +280,6 @@ mta_session_imsg(struct mproc *p, struct
>                       mta_flush_task(s, IMSG_MTA_DELIVERY_TEMPFAIL,
>                           "Could not get message fd", 0, 0);
>                       mta_enter_state(s, MTA_READY);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -289,7 +288,6 @@ mta_session_imsg(struct mproc *p, struct
>                       fatal("mta: fdopen");
>  
>               mta_enter_state(s, MTA_MAIL);
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_MTA_DNS_PTR:
> @@ -366,7 +364,6 @@ mta_session_imsg(struct mproc *p, struct
>  
>               mta_tls_verified(s);
>               io_resume(&s->io, IO_PAUSE_IN);
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_MTA_LOOKUP_HELO:
> @@ -456,7 +453,6 @@ mta_on_timeout(struct runq *runq, void *
>       s->hangon++;
>  
>       mta_enter_state(s, MTA_READY);
> -     io_reload(&s->io);
>  }
>  
>  static void
> Index: smtp_session.c
> ===================================================================
> RCS file: /cvs/src/usr.sbin/smtpd/smtp_session.c,v
> retrieving revision 1.295
> diff -u -p -r1.295 smtp_session.c
> --- smtp_session.c    22 Nov 2016 07:28:42 -0000      1.295
> +++ smtp_session.c    22 Nov 2016 22:24:26 -0000
> @@ -738,14 +738,12 @@ smtp_session_imsg(struct mproc *p, struc
>                       smtp_filter_tx_rollback(s);
>                       smtp_tx_free(s->tx);
>                       smtp_reply(s, "%d %s", 530, "Sender rejected");
> -                     io_reload(&s->io);
>                       break;
>               case LKA_TEMPFAIL:
>                       smtp_filter_tx_rollback(s);
>                       smtp_tx_free(s->tx);
>                       smtp_reply(s, "421 %s: Temporary Error",
>                           esc_code(ESC_STATUS_TEMPFAIL, 
> ESC_OTHER_MAIL_SYSTEM_STATUS));
> -                     io_reload(&s->io);
>                       break;
>               }
>               return;
> @@ -766,7 +764,6 @@ smtp_session_imsg(struct mproc *p, struc
>               case LKA_TEMPFAIL:
>                       smtp_reply(s, "%s", line);
>               }
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_SMTP_LOOKUP_HELO:
> @@ -802,7 +799,6 @@ smtp_session_imsg(struct mproc *p, struc
>                       smtp_enter_state(s, STATE_QUIT);
>               }
>               m_end(&m);
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_SMTP_MESSAGE_OPEN:
> @@ -818,7 +814,6 @@ smtp_session_imsg(struct mproc *p, struc
>                       smtp_reply(s, "421 %s: Temporary Error",
>                           esc_code(ESC_STATUS_TEMPFAIL, 
> ESC_OTHER_MAIL_SYSTEM_STATUS));
>                       smtp_enter_state(s, STATE_QUIT);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -872,7 +867,6 @@ smtp_session_imsg(struct mproc *p, struc
>                           esc_code(ESC_STATUS_OK, 
> ESC_DESTINATION_ADDRESS_VALID),
>                           esc_description(ESC_DESTINATION_ADDRESS_VALID));
>               }
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_SMTP_MESSAGE_COMMIT:
> @@ -887,7 +881,6 @@ smtp_session_imsg(struct mproc *p, struc
>                       smtp_reply(s, "421 %s: Temporary failure",
>                           esc_code(ESC_STATUS_TEMPFAIL, 
> ESC_OTHER_MAIL_SYSTEM_STATUS));
>                       smtp_enter_state(s, STATE_QUIT);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -915,7 +908,6 @@ smtp_session_imsg(struct mproc *p, struc
>               smtp_tx_free(s->tx);
>               s->mailcount++;
>               smtp_enter_state(s, STATE_HELO);
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_SMTP_AUTHENTICATE:
> @@ -955,7 +947,6 @@ smtp_session_imsg(struct mproc *p, struc
>                       fatalx("bad lka response");
>  
>               smtp_enter_state(s, STATE_HELO);
> -             io_reload(&s->io);
>               return;
>  
>       case IMSG_SMTP_TLS_INIT:
> @@ -1045,7 +1036,6 @@ smtp_filter_response(uint64_t id, int qu
>               line = line ? line : "Temporary failure";
>               smtp_reply(s, "%d %s", code, line);
>               smtp_enter_state(s, STATE_QUIT);
> -             io_reload(&s->io);
>               return;
>       }
>  
> @@ -1085,7 +1075,6 @@ smtp_filter_response(uint64_t id, int qu
>                       code = code ? code : 530;
>                       line = line ? line : "Hello rejected";
>                       smtp_reply(s, "%d %s", code, line);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -1108,7 +1097,6 @@ smtp_filter_response(uint64_t id, int qu
>                               smtp_reply(s, "250-AUTH PLAIN LOGIN");
>                       smtp_reply(s, "250 HELP");
>               }
> -             io_reload(&s->io);
>               return;
>  
>       case QUERY_MAIL:
> @@ -1118,7 +1106,6 @@ smtp_filter_response(uint64_t id, int qu
>                       code = code ? code : 530;
>                       line = line ? line : "Sender rejected";
>                       smtp_reply(s, "%d %s", code, line);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -1141,7 +1128,6 @@ smtp_filter_response(uint64_t id, int qu
>                       code = code ? code : 530;
>                       line = line ? line : "Recipient rejected";
>                       smtp_reply(s, "%d %s", code, line);
> -                     io_reload(&s->io);
>                       return;
>               }
>  
> @@ -1157,7 +1143,6 @@ smtp_filter_response(uint64_t id, int qu
>                       code = code ? code : 530;
>                       line = line ? line : "Message rejected";
>                       smtp_reply(s, "%d %s", code, line);
> -                     io_reload(&s->io);
>                       return;
>               }
>               smtp_queue_open_message(s);
> @@ -1173,7 +1158,6 @@ smtp_filter_response(uint64_t id, int qu
>                       line = line ? line : "Message rejected";
>                       smtp_reply(s, "%d %s", code, line);
>                       smtp_enter_state(s, STATE_HELO);
> -                     io_reload(&s->io);
>                       return;
>               }
>               smtp_message_end(s);
> @@ -1198,7 +1182,6 @@ smtp_filter_fd(uint64_t id, int fd)
>               smtp_reply(s, "421 %s: Temporary Error",
>                   esc_code(ESC_STATUS_TEMPFAIL, 
> ESC_OTHER_MAIL_SYSTEM_STATUS));
>               smtp_enter_state(s, STATE_QUIT);
> -             io_reload(&s->io);
>               return;
>       }
>  
> @@ -1257,7 +1240,6 @@ smtp_filter_fd(uint64_t id, int fd)
>           " on a line by itself");
>  
>       tree_xset(&wait_filter_data, s->id, s);
> -     io_reload(&s->io);
>  }
>  
>  static void
> @@ -1341,8 +1323,6 @@ smtp_io(struct io *io, int evt, void *ar
>                       s->tx->dataeom = 1;
>                       if (io_queued(&s->tx->oev) == 0)
>                               smtp_data_io_done(s);
> -                     else
> -                             io_reload(&s->tx->oev);
>                       return;
>               }
>  
> @@ -1547,7 +1527,6 @@ smtp_data_io_done(struct smtp_session *s
>                       smtp_reply(s, "421 Internal server error");
>               smtp_tx_free(s->tx);
>               smtp_enter_state(s, STATE_HELO);
> -             io_reload(&s->io);
>       }
>       else {
>               smtp_filter_eom(s);
> @@ -2137,7 +2116,6 @@ static void
>  smtp_send_banner(struct smtp_session *s)
>  {
>       smtp_reply(s, "220 %s ESMTP %s", s->smtpname, SMTPD_NAME);
> -     io_reload(&s->io);
>  }
>  
>  void
> @@ -2466,7 +2444,6 @@ smtp_auth_failure_resume(int fd, short e
>  
>       smtp_reply(s, "535 Authentication failed");
>       smtp_enter_state(s, STATE_HELO);
> -     io_reload(&s->io);
>  }
>  
>  static void
> @@ -2662,7 +2639,6 @@ smtp_filter_dataline(struct smtp_session
>               log_debug("debug: smtp: %p: filter congestion over: pausing 
> session", s);
>               io_pause(&s->io, IO_PAUSE_IN);
>       }
> -     io_reload(&s->tx->oev);
>  }
>  
>  #define CASE(x) case x : return #x

Reply via email to