sctpserv05.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #include "unp.h"
  2. int
  3. main(int argc, char **argv)
  4. {
  5. uint8_t *readbuf;
  6. int sock_fd,msg_flags;
  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. rd_sz = 0;
  27. /* include mod_serv05 */
  28. for ( ; ; ) {
  29. len = sizeof(struct sockaddr_in);
  30. bzero(&sri,sizeof(sri));
  31. readbuf = pdapi_recvmsg(sock_fd, &rd_sz,
  32. (SA *)&cliaddr, &len,
  33. &sri,&msg_flags);
  34. if(readbuf == NULL)
  35. continue;
  36. /* end mod_serv05 */
  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. }