version 1.1.1.1.2.1, 2010/06/18 13:36:01
|
version 1.1.1.1.2.3, 2010/06/23 07:50:01
|
Line 74 rpc_srv_dispatchCall(void *arg)
|
Line 74 rpc_srv_dispatchCall(void *arg)
|
v[i].val.string = (int8_t*) data; |
v[i].val.string = (int8_t*) data; |
data += v[i].val_len + 1; |
data += v[i].val_len + 1; |
break; |
break; |
case array: | case blob: |
v[i].val.array = (int8_t**) data; | v[i].val.blob = (int8_t**) data; |
data += v[i].val_len; |
data += v[i].val_len; |
break; |
break; |
default: |
default: |
Line 135 rpc_srv_dispatchCall(void *arg)
|
Line 135 rpc_srv_dispatchCall(void *arg)
|
data += vals[i].val_len + 1; |
data += vals[i].val_len + 1; |
Limit += vals[i].val_len + 1; |
Limit += vals[i].val_len + 1; |
break; |
break; |
case array: | case blob: |
if (ret || Limit + vals[i].val_len > BUFSIZ) { |
if (ret || Limit + vals[i].val_len > BUFSIZ) { |
rpc_SetErr(EMSGSIZE, "Error:: in prepare RPC packet (-7) ...\n"); |
rpc_SetErr(EMSGSIZE, "Error:: in prepare RPC packet (-7) ...\n"); |
rrpc.ret_retcode = ret = -7; |
rrpc.ret_retcode = ret = -7; |
Line 143 rpc_srv_dispatchCall(void *arg)
|
Line 143 rpc_srv_dispatchCall(void *arg)
|
break; |
break; |
} |
} |
|
|
memcpy(data, vals[i].val.array, vals[i].val_len); | memcpy(data, vals[i].val.blob, vals[i].val_len); |
data += vals[i].val_len; |
data += vals[i].val_len; |
Limit += vals[i].val_len; |
Limit += vals[i].val_len; |
break; |
break; |
Line 243 rpc_srv_initServer(u_int regProgID, u_int regProcID, i
|
Line 243 rpc_srv_initServer(u_int regProgID, u_int regProcID, i
|
srv->srv_session.sess_program = regProgID; |
srv->srv_session.sess_program = regProgID; |
srv->srv_session.sess_process = regProcID; |
srv->srv_session.sess_process = regProcID; |
|
|
|
srv->srv_server.cli_tid = pthread_self(); |
srv->srv_server.cli_parent = srv; |
srv->srv_server.cli_parent = srv; |
if (family == AF_INET) |
if (family == AF_INET) |
memcpy(&srv->srv_server.cli_sa, &sin, sizeof srv->srv_server.cli_sa); |
memcpy(&srv->srv_server.cli_sa, &sin, sizeof srv->srv_server.cli_sa); |
Line 334 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
Line 335 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
socklen_t salen = sizeof(struct sockaddr); |
socklen_t salen = sizeof(struct sockaddr); |
register int i; |
register int i; |
rpc_cli_t *c; |
rpc_cli_t *c; |
|
fd_set fds; |
|
int ret; |
|
struct timeval tv = { DEF_RPC_TIMEOUT, 0 }; |
|
|
if (!srv) { |
if (!srv) { |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t start RPC server ...\n"); |
rpc_SetErr(EINVAL, "Error:: Invalid parameter can`t start RPC server ...\n"); |
Line 353 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
Line 357 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
usleep(1000000); |
usleep(1000000); |
continue; |
continue; |
} |
} |
|
|
|
FD_ZERO(&fds); |
|
FD_SET(srv->srv_server.cli_sock, &fds); |
|
ret = select(srv->srv_server.cli_sock + 1, &fds, NULL, NULL, &tv); |
|
if (ret == -1) { |
|
LOGERR; |
|
ret = 1; |
|
break; |
|
} |
|
if (!ret) |
|
continue; |
|
|
c->cli_sock = accept(srv->srv_server.cli_sock, &c->cli_sa, &salen); |
c->cli_sock = accept(srv->srv_server.cli_sock, &c->cli_sa, &salen); |
if (c->cli_sock == -1) { |
if (c->cli_sock == -1) { |
printf("%s(%d): #%d - %s\n", __func__, __LINE__, errno, strerror(errno)); |
|
LOGERR; |
LOGERR; |
continue; |
continue; |
} else |
} else |
Line 367 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
Line 382 rpc_srv_execServer(rpc_srv_t * __restrict srv)
|
} |
} |
} |
} |
|
|
/* not reached !!! */ |
|
return 0; |
return 0; |
} |
} |
|
|