sctpserv01.c 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  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. socklen_t len;
  12. size_t rd_sz;
  13. if (argc == 2)
  14. stream_increment = atoi(argv[1]);
  15. sock_fd = Socket(AF_INET, SOCK_SEQPACKET, IPPROTO_SCTP);
  16. bzero(&servaddr, sizeof(servaddr));
  17. servaddr.sin_family = AF_INET;
  18. servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
  19. servaddr.sin_port = htons(SERV_PORT);
  20. Bind(sock_fd, (SA *) &servaddr, sizeof(servaddr));
  21. bzero(&evnts, sizeof(evnts));
  22. evnts.sctp_data_io_event = 1;
  23. Setsockopt(sock_fd, IPPROTO_SCTP, SCTP_EVENTS,
  24. &evnts, sizeof(evnts));
  25. Listen(sock_fd, LISTENQ);
  26. for ( ; ; ) {
  27. len = sizeof(struct sockaddr_in);
  28. rd_sz = Sctp_recvmsg(sock_fd, readbuf, sizeof(readbuf),
  29. (SA *)&cliaddr, &len,
  30. &sri,&msg_flags);
  31. if(stream_increment) {
  32. sri.sinfo_stream++;
  33. if(sri.sinfo_stream >= sctp_get_no_strms(sock_fd,(SA *)&cliaddr, len))
  34. sri.sinfo_stream = 0;
  35. }
  36. Sctp_sendmsg(sock_fd, readbuf, rd_sz,
  37. (SA *)&cliaddr, len,
  38. sri.sinfo_ppid,
  39. sri.sinfo_flags,
  40. sri.sinfo_stream,
  41. 0, 0);
  42. }
  43. }