--- mqtt/src/daemon.c 2012/06/20 09:23:28 1.2.2.37 +++ mqtt/src/daemon.c 2012/06/26 08:05:58 1.2.2.38 @@ -24,7 +24,6 @@ initSession(int sock, ait_val_t * __restrict v) memset(sess, 0, sizeof(struct tagSession)); SLIST_INIT(&sess->sess_subscr); - SLIST_INIT(&sess->sess_sndpkt); str = cfg_getAttribute(&cfg, "mqttd", "retry"); if (!str) @@ -65,7 +64,6 @@ static void finiSession(struct tagSession *sess) { struct tagStore *store; - struct tagPkt *p; ioTRACE(5); @@ -92,13 +90,6 @@ finiSession(struct tagSession *sess) io_free(store); } - while ((p = SLIST_FIRST(&sess->sess_sndpkt))) { - SLIST_REMOVE_HEAD(&sess->sess_sndpkt, pkt_node); - - io_freeVar(&p->pkt_data); - io_free(p); - } - if (sess->sess_will.msg) free(sess->sess_will.msg); if (sess->sess_will.topic) @@ -164,6 +155,7 @@ dispatchSession(sched_task_t *task) finiSession(sess); return NULL; } + ioDEBUG(0, "++++++ret=%d\n", ret); do { /* dispatch message type */