dn_nsp.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. #ifndef _NET_DN_NSP_H
  2. #define _NET_DN_NSP_H
  3. /******************************************************************************
  4. (c) 1995-1998 E.M. Serrat emserrat@geocities.com
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; either version 2 of the License, or
  8. any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. *******************************************************************************/
  14. /* dn_nsp.c functions prototyping */
  15. void dn_nsp_send_data_ack(struct sock *sk);
  16. void dn_nsp_send_oth_ack(struct sock *sk);
  17. void dn_nsp_delayed_ack(struct sock *sk);
  18. void dn_send_conn_ack(struct sock *sk);
  19. void dn_send_conn_conf(struct sock *sk, gfp_t gfp);
  20. void dn_nsp_send_disc(struct sock *sk, unsigned char type,
  21. unsigned short reason, gfp_t gfp);
  22. void dn_nsp_return_disc(struct sk_buff *skb, unsigned char type,
  23. unsigned short reason);
  24. void dn_nsp_send_link(struct sock *sk, unsigned char lsflags, char fcval);
  25. void dn_nsp_send_conninit(struct sock *sk, unsigned char flags);
  26. void dn_nsp_output(struct sock *sk);
  27. int dn_nsp_check_xmit_queue(struct sock *sk, struct sk_buff *skb,
  28. struct sk_buff_head *q, unsigned short acknum);
  29. void dn_nsp_queue_xmit(struct sock *sk, struct sk_buff *skb, gfp_t gfp,
  30. int oob);
  31. unsigned long dn_nsp_persist(struct sock *sk);
  32. int dn_nsp_xmit_timeout(struct sock *sk);
  33. int dn_nsp_rx(struct sk_buff *);
  34. int dn_nsp_backlog_rcv(struct sock *sk, struct sk_buff *skb);
  35. struct sk_buff *dn_alloc_skb(struct sock *sk, int size, gfp_t pri);
  36. struct sk_buff *dn_alloc_send_skb(struct sock *sk, size_t *size, int noblock,
  37. long timeo, int *err);
  38. #define NSP_REASON_OK 0 /* No error */
  39. #define NSP_REASON_NR 1 /* No resources */
  40. #define NSP_REASON_UN 2 /* Unrecognised node name */
  41. #define NSP_REASON_SD 3 /* Node shutting down */
  42. #define NSP_REASON_ID 4 /* Invalid destination end user */
  43. #define NSP_REASON_ER 5 /* End user lacks resources */
  44. #define NSP_REASON_OB 6 /* Object too busy */
  45. #define NSP_REASON_US 7 /* Unspecified error */
  46. #define NSP_REASON_TP 8 /* Third-Party abort */
  47. #define NSP_REASON_EA 9 /* End user has aborted the link */
  48. #define NSP_REASON_IF 10 /* Invalid node name format */
  49. #define NSP_REASON_LS 11 /* Local node shutdown */
  50. #define NSP_REASON_LL 32 /* Node lacks logical-link resources */
  51. #define NSP_REASON_LE 33 /* End user lacks logical-link resources */
  52. #define NSP_REASON_UR 34 /* Unacceptable RQSTRID or PASSWORD field */
  53. #define NSP_REASON_UA 36 /* Unacceptable ACCOUNT field */
  54. #define NSP_REASON_TM 38 /* End user timed out logical link */
  55. #define NSP_REASON_NU 39 /* Node unreachable */
  56. #define NSP_REASON_NL 41 /* No-link message */
  57. #define NSP_REASON_DC 42 /* Disconnect confirm */
  58. #define NSP_REASON_IO 43 /* Image data field overflow */
  59. #define NSP_DISCINIT 0x38
  60. #define NSP_DISCCONF 0x48
  61. /*------------------------- NSP - messages ------------------------------*/
  62. /* Data Messages */
  63. /*---------------*/
  64. /* Data Messages (data segment/interrupt/link service) */
  65. struct nsp_data_seg_msg {
  66. __u8 msgflg;
  67. __le16 dstaddr;
  68. __le16 srcaddr;
  69. } __packed;
  70. struct nsp_data_opt_msg {
  71. __le16 acknum;
  72. __le16 segnum;
  73. __le16 lsflgs;
  74. } __packed;
  75. struct nsp_data_opt_msg1 {
  76. __le16 acknum;
  77. __le16 segnum;
  78. } __packed;
  79. /* Acknowledgment Message (data/other data) */
  80. struct nsp_data_ack_msg {
  81. __u8 msgflg;
  82. __le16 dstaddr;
  83. __le16 srcaddr;
  84. __le16 acknum;
  85. } __packed;
  86. /* Connect Acknowledgment Message */
  87. struct nsp_conn_ack_msg {
  88. __u8 msgflg;
  89. __le16 dstaddr;
  90. } __packed;
  91. /* Connect Initiate/Retransmit Initiate/Connect Confirm */
  92. struct nsp_conn_init_msg {
  93. __u8 msgflg;
  94. #define NSP_CI 0x18 /* Connect Initiate */
  95. #define NSP_RCI 0x68 /* Retrans. Conn Init */
  96. __le16 dstaddr;
  97. __le16 srcaddr;
  98. __u8 services;
  99. #define NSP_FC_NONE 0x00 /* Flow Control None */
  100. #define NSP_FC_SRC 0x04 /* Seg Req. Count */
  101. #define NSP_FC_SCMC 0x08 /* Sess. Control Mess */
  102. #define NSP_FC_MASK 0x0c /* FC type mask */
  103. __u8 info;
  104. __le16 segsize;
  105. } __packed;
  106. /* Disconnect Initiate/Disconnect Confirm */
  107. struct nsp_disconn_init_msg {
  108. __u8 msgflg;
  109. __le16 dstaddr;
  110. __le16 srcaddr;
  111. __le16 reason;
  112. } __packed;
  113. struct srcobj_fmt {
  114. __u8 format;
  115. __u8 task;
  116. __le16 grpcode;
  117. __le16 usrcode;
  118. __u8 dlen;
  119. } __packed;
  120. /*
  121. * A collection of functions for manipulating the sequence
  122. * numbers used in NSP. Similar in operation to the functions
  123. * of the same name in TCP.
  124. */
  125. static __inline__ int dn_before(__u16 seq1, __u16 seq2)
  126. {
  127. seq1 &= 0x0fff;
  128. seq2 &= 0x0fff;
  129. return (int)((seq1 - seq2) & 0x0fff) > 2048;
  130. }
  131. static __inline__ int dn_after(__u16 seq1, __u16 seq2)
  132. {
  133. seq1 &= 0x0fff;
  134. seq2 &= 0x0fff;
  135. return (int)((seq2 - seq1) & 0x0fff) > 2048;
  136. }
  137. static __inline__ int dn_equal(__u16 seq1, __u16 seq2)
  138. {
  139. return ((seq1 ^ seq2) & 0x0fff) == 0;
  140. }
  141. static __inline__ int dn_before_or_equal(__u16 seq1, __u16 seq2)
  142. {
  143. return (dn_before(seq1, seq2) || dn_equal(seq1, seq2));
  144. }
  145. static __inline__ void seq_add(__u16 *seq, __u16 off)
  146. {
  147. (*seq) += off;
  148. (*seq) &= 0x0fff;
  149. }
  150. static __inline__ int seq_next(__u16 seq1, __u16 seq2)
  151. {
  152. return dn_equal(seq1 + 1, seq2);
  153. }
  154. /*
  155. * Can we delay the ack ?
  156. */
  157. static __inline__ int sendack(__u16 seq)
  158. {
  159. return (int)((seq & 0x1000) ? 0 : 1);
  160. }
  161. /*
  162. * Is socket congested ?
  163. */
  164. static __inline__ int dn_congested(struct sock *sk)
  165. {
  166. return atomic_read(&sk->sk_rmem_alloc) > (sk->sk_rcvbuf >> 1);
  167. }
  168. #define DN_MAX_NSP_DATA_HEADER (11)
  169. #endif /* _NET_DN_NSP_H */