sctpserv04.c 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #include "unp.h"
  2. int
  3. main(int argc, char **argv)
  4. {
  5. int sock_fd,msg_flags;
  6. char readbuf[BUFFSIZE];
  7. struct sockaddr_in servaddr, cliaddr;
  8. struct sctp_sndrcvinfo sri;
  9. struct sctp_event_subscribe evnts;
  10. int stream_increment=1;
  11. int close_time;
  12. socklen_t len;
  13. size_t rd_sz;
  14. /* include mod_serv04 */
  15. if (argc == 2)
  16. stream_increment = atoi(argv[1]);
  17. sock_fd = Socket(AF_INET, SOCK_SEQPACKET, IPPROTO_SCTP);
  18. close_time = 120;
  19. Setsockopt(sock_fd, IPPROTO_SCTP, SCTP_AUTOCLOSE,
  20. &close_time, sizeof(close_time));
  21. bzero(&servaddr, sizeof(servaddr));
  22. servaddr.sin_family = AF_INET;
  23. servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
  24. servaddr.sin_port = htons(SERV_PORT);
  25. /* end mod_serv04 */
  26. Bind(sock_fd, (SA *) &servaddr, sizeof(servaddr));
  27. bzero(&evnts, sizeof(evnts));
  28. evnts.sctp_data_io_event = 1;
  29. Setsockopt(sock_fd, IPPROTO_SCTP, SCTP_EVENTS,
  30. &evnts, sizeof(evnts));
  31. Listen(sock_fd, LISTENQ);
  32. for ( ; ; ) {
  33. len = sizeof(struct sockaddr_in);
  34. rd_sz = Sctp_recvmsg(sock_fd, readbuf, sizeof(readbuf),
  35. (SA *)&cliaddr, &len,
  36. &sri,&msg_flags);
  37. if(stream_increment) {
  38. sri.sinfo_stream++;
  39. if(sri.sinfo_stream >= sctp_get_no_strms(sock_fd,(SA *)&cliaddr, len))
  40. sri.sinfo_stream = 0;
  41. }
  42. Sctp_sendmsg(sock_fd, readbuf, rd_sz,
  43. (SA *)&cliaddr, len,
  44. sri.sinfo_ppid,
  45. sri.sinfo_flags,
  46. sri.sinfo_stream,
  47. 0, 0);
  48. }
  49. }