readable_conn.c 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /* include readable_conn1 */
  2. #include "icmpd.h"
  3. int
  4. readable_conn(int i)
  5. {
  6. int unixfd, recvfd;
  7. char c;
  8. ssize_t n;
  9. socklen_t len;
  10. struct sockaddr_storage ss;
  11. unixfd = client[i].connfd;
  12. recvfd = -1;
  13. if ( (n = Read_fd(unixfd, &c, 1, &recvfd)) == 0) {
  14. err_msg("client %d terminated, recvfd = %d", i, recvfd);
  15. goto clientdone; /* client probably terminated */
  16. }
  17. /* 4data from client; should be descriptor */
  18. if (recvfd < 0) {
  19. err_msg("read_fd did not return descriptor");
  20. goto clienterr;
  21. }
  22. /* end readable_conn1 */
  23. /* include readable_conn2 */
  24. len = sizeof(ss);
  25. if (getsockname(recvfd, (SA *) &ss, &len) < 0) {
  26. err_ret("getsockname error");
  27. goto clienterr;
  28. }
  29. client[i].family = ss.ss_family;
  30. if ( (client[i].lport = sock_get_port((SA *)&ss, len)) == 0) {
  31. client[i].lport = sock_bind_wild(recvfd, client[i].family);
  32. if (client[i].lport <= 0) {
  33. err_ret("error binding ephemeral port");
  34. goto clienterr;
  35. }
  36. }
  37. Write(unixfd, "1", 1); /* tell client all OK */
  38. Close(recvfd); /* all done with client's UDP socket */
  39. return(--nready);
  40. clienterr:
  41. Write(unixfd, "0", 1); /* tell client error occurred */
  42. clientdone:
  43. Close(unixfd);
  44. if (recvfd >= 0)
  45. Close(recvfd);
  46. FD_CLR(unixfd, &allset);
  47. client[i].connfd = -1;
  48. return(--nready);
  49. }
  50. /* end readable_conn2 */