Diff for /libaitrpc/src/srv.c between versions 1.21 and 1.21.2.2

version 1.21, 2013/11/14 21:44:14 version 1.21.2.2, 2013/11/14 23:38:41
Line 359  rxPacket(sched_task_t *task) Line 359  rxPacket(sched_task_t *task)
                         return NULL;                          return NULL;
                 }                  }
         }          }
           len = estlen;
   
 #if 0  #if 0
         /* check integrity of packet */          /* check integrity of packet */
Line 449  txUDPPacket(sched_task_t *task) Line 450  txUDPPacket(sched_task_t *task)
         struct tagRPCCall *rpc = (struct tagRPCCall*) buf;          struct tagRPCCall *rpc = (struct tagRPCCall*) buf;
         int ret, wlen = sizeof(struct tagRPCCall);          int ret, wlen = sizeof(struct tagRPCCall);
         struct timespec ts = { DEF_RPC_TIMEOUT, 0 };          struct timespec ts = { DEF_RPC_TIMEOUT, 0 };
           struct pollfd pfd;
   
         schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_DATA, TASK_ARG(task), NULL);          schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_DATA, TASK_ARG(task), NULL);
         schedTimer(TASK_ROOT(task), cbProto[s->srv_proto][CB_CLOSECLIENT],           schedTimer(TASK_ROOT(task), cbProto[s->srv_proto][CB_CLOSECLIENT], 
Line 485  txUDPPacket(sched_task_t *task) Line 487  txUDPPacket(sched_task_t *task)
         rpc->call_crc = htons(crcFletcher16((u_short*) buf, wlen / 2));          rpc->call_crc = htons(crcFletcher16((u_short*) buf, wlen / 2));
   
         /* send reply */          /* send reply */
        ret = sendto(TASK_FD(task), buf, wlen, MSG_NOSIGNAL,         pfd.fd = TASK_FD(task);
                        &c->cli_sa.sa, c->cli_sa.sa.sa_len);        pfd.events = POLLOUT;
        if (ret == -1 || ret != wlen) {        for (; wlen > 0; wlen -= ret, buf += ret) {
                /* close connection */                if ((ret = poll(&pfd, 1, DEF_RPC_TIMEOUT * 1000)) < 1 || 
                schedEvent(TASK_ROOT(task), cbProto[s->srv_proto][CB_CLOSECLIENT],                                 pfd.revents & (POLLERR | POLLHUP | POLLNVAL)) {
                                 TASK_ARG(task), 0, NULL, 0);                        if (ret)
                                 LOGERR;
                         else
                                 rpc_SetErr(ETIMEDOUT, "Timeout reached! Server not respond");
                         /* close connection */
                         schedEvent(TASK_ROOT(task), cbProto[s->srv_proto][CB_CLOSECLIENT], 
                                         TASK_ARG(task), 0, NULL, 0);
                         return NULL;
                 }
                 ret = sendto(TASK_FD(task), buf, MIN(wlen, s->srv_netbuf), MSG_NOSIGNAL, 
                                 &c->cli_sa.sa, c->cli_sa.sa.sa_len);
                 if (ret == -1) {
                         /* close connection */
                         schedEvent(TASK_ROOT(task), cbProto[s->srv_proto][CB_CLOSECLIENT], 
                                         TASK_ARG(task), 0, NULL, 0);
                         return NULL;
                 }
         }          }
   
         return NULL;          return NULL;
Line 501  rxUDPPacket(sched_task_t *task) Line 519  rxUDPPacket(sched_task_t *task)
 {  {
         rpc_srv_t *srv = TASK_ARG(task);          rpc_srv_t *srv = TASK_ARG(task);
         rpc_cli_t *c = NULL;          rpc_cli_t *c = NULL;
        int len, rlen, noreply;        int len, rlen, noreply, estlen;
        u_short crc, off = 0;        u_short crc;
        u_char buf[USHRT_MAX + 1];        u_char *buf, b[sizeof(struct tagRPCCall)];
        struct tagRPCCall *rpc = (struct tagRPCCall*) buf;        struct tagRPCCall *rpc = (struct tagRPCCall*) b;
         sockaddr_t sa;          sockaddr_t sa;
         socklen_t salen;          socklen_t salen;
         struct timespec ts = { DEF_RPC_TIMEOUT, 0 };          struct timespec ts = { DEF_RPC_TIMEOUT, 0 };
           struct pollfd pfd;
   
         /* receive connect packet */          /* receive connect packet */
         salen = sa.ss.ss_len = sizeof(sockaddr_t);          salen = sa.ss.ss_len = sizeof(sockaddr_t);
        rlen = recvfrom(TASK_FD(task), buf, sizeof buf, 0, &sa.sa, &salen);        rlen = recvfrom(TASK_FD(task), b, sizeof b, MSG_PEEK, &sa.sa, &salen);
        if (rlen < 1)        if (rlen < sizeof(struct tagRPCCall)) {
                 rpc_SetErr(ERPCMISMATCH, "Short RPC packet");
                 goto end;                  goto end;
           }
   
         c = _allocClient(srv, &sa);          c = _allocClient(srv, &sa);
         if (!c)          if (!c)
                 goto end;                  goto end;
         else {          else {
                   estlen = ntohl(rpc->call_len);
                   if (estlen > AIT_LEN(&c->cli_buf))
                           AIT_RE_BUF(&c->cli_buf, estlen);
                   rpc = (struct tagRPCCall*) AIT_GET_BUF(&c->cli_buf);
                   buf = AIT_GET_BUF(&c->cli_buf);
                   len = estlen;
   
                 c->cli_sock = TASK_FD(task);                  c->cli_sock = TASK_FD(task);
                 memcpy(&c->cli_sa, &sa, sizeof c->cli_sa);                  memcpy(&c->cli_sa, &sa, sizeof c->cli_sa);
                memcpy(AIT_GET_BUF(&c->cli_buf), buf, AIT_LEN(&c->cli_buf));
                 /* armed timer for close stateless connection */                  /* armed timer for close stateless connection */
                 schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_DATA, c, NULL);                  schedCancelby(TASK_ROOT(task), taskTIMER, CRITERIA_DATA, c, NULL);
                 schedTimer(TASK_ROOT(task), cbProto[srv->srv_proto][CB_CLOSECLIENT],                   schedTimer(TASK_ROOT(task), cbProto[srv->srv_proto][CB_CLOSECLIENT], 
                                 c, ts, c, 0);                                  c, ts, c, 0);
         }          }
   
        do {        /* get next part of packet */
                /* check RPC packet */        memset(buf, 0, len);
                if (rlen < sizeof(struct tagRPCCall)) {        pfd.fd = TASK_FD(task);
                        rpc_SetErr(ERPCMISMATCH, "Short RPC packet");        pfd.events = POLLIN | POLLPRI;
                        break;        for (; len > 0; len -= rlen, buf += rlen) {
                } else                if ((rlen = poll(&pfd, 1, DEF_RPC_TIMEOUT * 1000)) < 1 || 
                        rpc = (struct tagRPCCall*) (AIT_GET_BUF(&c->cli_buf) + off);                                pfd.revents & (POLLERR | POLLHUP | POLLNVAL)) {
                        if (rlen)
                len = ntohl(rpc->call_len);                                LOGERR;
                rlen -= len;                        else
                                rpc_SetErr(ETIMEDOUT, "Timeout reached! Server not respond");
                /* check RPC packet lengths */                        schedEvent(TASK_ROOT(task), cbProto[srv->srv_proto][CB_CLOSECLIENT], 
                if (rlen < 0 || len < sizeof(struct tagRPCCall)) {                                        c, 0, NULL, 0);
                        rpc_SetErr(ERPCMISMATCH, "Broken RPC packet length");                        return NULL;
                        /* skip entire packet */ 
                        break; 
                 }                  }
                rlen = recvfrom(TASK_FD(task), buf, len, 0, &sa.sa, &salen);
                /* check integrity of packet */                if (rlen == -1) {
                crc = ntohs(rpc->call_crc);                        /* close connection */
                rpc->call_crc ^= rpc->call_crc;                        schedEvent(TASK_ROOT(task), cbProto[srv->srv_proto][CB_CLOSECLIENT], 
                if (crc != crcFletcher16((u_short*) rpc, len / 2)) {                                        c, 0, NULL, 0);
                        rpc_SetErr(ERPCMISMATCH, "Bad CRC RPC packet");                        return NULL;
 
                        off += len; 
                        /* try next packet remaining into buffer */ 
                        continue; 
                 }                  }
           }
           len = estlen;
   
                noreply = RPC_CHK_NOREPLY(rpc);        /* check integrity of packet */
         crc = ntohs(rpc->call_crc);
         rpc->call_crc ^= rpc->call_crc;
         if (crc != crcFletcher16((u_short*) rpc, len / 2)) {
                 rpc_SetErr(ERPCMISMATCH, "Bad CRC RPC packet");
                 return NULL;
         }
   
                /* check RPC packet session info */        noreply = RPC_CHK_NOREPLY(rpc);
                if (rpc_chkPktSession(&rpc->call_session, &srv->srv_session)) { 
                        rpc_SetErr(ERPCMISMATCH, "Get invalid RPC session"); 
   
                        rpc->call_argc ^= rpc->call_argc;        /* check RPC packet session info */
                        rpc->call_rep.ret = RPC_ERROR(-1);        if (rpc_chkPktSession(&rpc->call_session, &srv->srv_session)) {
                        rpc->call_rep.eno = RPC_ERROR(errno);                rpc_SetErr(ERPCMISMATCH, "Get invalid RPC session");
                } else { 
                        /* execute RPC call */ 
                        schedEvent(TASK_ROOT(task), execCall, c,  
                                        (int) noreply, rpc, len); 
                } 
   
                /* send RPC reply */                rpc->call_argc ^= rpc->call_argc;
                if (!noreply)                rpc->call_rep.ret = RPC_ERROR(-1);
                        schedWrite(TASK_ROOT(task), cbProto[srv->srv_proto][CB_TXPACKET],                 rpc->call_rep.eno = RPC_ERROR(errno);
                                        c, TASK_FD(task), rpc, len);        } else {
                 /* execute RPC call */
                 schedEvent(TASK_ROOT(task), execCall, c, (int) noreply, rpc, len);
         }
   
                off += len;        /* send RPC reply */
        } while (rlen > 0);        if (!noreply)
                schedWrite(TASK_ROOT(task), cbProto[srv->srv_proto][CB_TXPACKET], 
                                 c, TASK_FD(task), rpc, len);
 end:  end:
         schedReadSelf(task);          schedReadSelf(task);
         return NULL;          return NULL;

Removed from v.1.21  
changed lines
  Added in v.1.21.2.2


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>