lapb.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _LAPB_H
  3. #define _LAPB_H
  4. #include <linux/lapb.h>
  5. #include <linux/refcount.h>
  6. #define LAPB_HEADER_LEN 20 /* LAPB over Ethernet + a bit more */
  7. #define LAPB_ACK_PENDING_CONDITION 0x01
  8. #define LAPB_REJECT_CONDITION 0x02
  9. #define LAPB_PEER_RX_BUSY_CONDITION 0x04
  10. /* Control field templates */
  11. #define LAPB_I 0x00 /* Information frames */
  12. #define LAPB_S 0x01 /* Supervisory frames */
  13. #define LAPB_U 0x03 /* Unnumbered frames */
  14. #define LAPB_RR 0x01 /* Receiver ready */
  15. #define LAPB_RNR 0x05 /* Receiver not ready */
  16. #define LAPB_REJ 0x09 /* Reject */
  17. #define LAPB_SABM 0x2F /* Set Asynchronous Balanced Mode */
  18. #define LAPB_SABME 0x6F /* Set Asynchronous Balanced Mode Extended */
  19. #define LAPB_DISC 0x43 /* Disconnect */
  20. #define LAPB_DM 0x0F /* Disconnected mode */
  21. #define LAPB_UA 0x63 /* Unnumbered acknowledge */
  22. #define LAPB_FRMR 0x87 /* Frame reject */
  23. #define LAPB_ILLEGAL 0x100 /* Impossible to be a real frame type */
  24. #define LAPB_SPF 0x10 /* Poll/final bit for standard LAPB */
  25. #define LAPB_EPF 0x01 /* Poll/final bit for extended LAPB */
  26. #define LAPB_FRMR_W 0x01 /* Control field invalid */
  27. #define LAPB_FRMR_X 0x02 /* I field invalid */
  28. #define LAPB_FRMR_Y 0x04 /* I field too long */
  29. #define LAPB_FRMR_Z 0x08 /* Invalid N(R) */
  30. #define LAPB_POLLOFF 0
  31. #define LAPB_POLLON 1
  32. /* LAPB C-bit */
  33. #define LAPB_COMMAND 1
  34. #define LAPB_RESPONSE 2
  35. #define LAPB_ADDR_A 0x03
  36. #define LAPB_ADDR_B 0x01
  37. #define LAPB_ADDR_C 0x0F
  38. #define LAPB_ADDR_D 0x07
  39. /* Define Link State constants. */
  40. enum {
  41. LAPB_STATE_0, /* Disconnected State */
  42. LAPB_STATE_1, /* Awaiting Connection State */
  43. LAPB_STATE_2, /* Awaiting Disconnection State */
  44. LAPB_STATE_3, /* Data Transfer State */
  45. LAPB_STATE_4 /* Frame Reject State */
  46. };
  47. #define LAPB_DEFAULT_MODE (LAPB_STANDARD | LAPB_SLP | LAPB_DTE)
  48. #define LAPB_DEFAULT_WINDOW 7 /* Window=7 */
  49. #define LAPB_DEFAULT_T1 (5 * HZ) /* T1=5s */
  50. #define LAPB_DEFAULT_T2 (1 * HZ) /* T2=1s */
  51. #define LAPB_DEFAULT_N2 20 /* N2=20 */
  52. #define LAPB_SMODULUS 8
  53. #define LAPB_EMODULUS 128
  54. /*
  55. * Information about the current frame.
  56. */
  57. struct lapb_frame {
  58. unsigned short type; /* Parsed type */
  59. unsigned short nr, ns; /* N(R), N(S) */
  60. unsigned char cr; /* Command/Response */
  61. unsigned char pf; /* Poll/Final */
  62. unsigned char control[2]; /* Original control data*/
  63. };
  64. /*
  65. * The per LAPB connection control structure.
  66. */
  67. struct lapb_cb {
  68. struct list_head node;
  69. struct net_device *dev;
  70. /* Link status fields */
  71. unsigned int mode;
  72. unsigned char state;
  73. unsigned short vs, vr, va;
  74. unsigned char condition;
  75. unsigned short n2, n2count;
  76. unsigned short t1, t2;
  77. struct timer_list t1timer, t2timer;
  78. /* Internal control information */
  79. struct sk_buff_head write_queue;
  80. struct sk_buff_head ack_queue;
  81. unsigned char window;
  82. const struct lapb_register_struct *callbacks;
  83. /* FRMR control information */
  84. struct lapb_frame frmr_data;
  85. unsigned char frmr_type;
  86. refcount_t refcnt;
  87. };
  88. /* lapb_iface.c */
  89. void lapb_connect_confirmation(struct lapb_cb *lapb, int);
  90. void lapb_connect_indication(struct lapb_cb *lapb, int);
  91. void lapb_disconnect_confirmation(struct lapb_cb *lapb, int);
  92. void lapb_disconnect_indication(struct lapb_cb *lapb, int);
  93. int lapb_data_indication(struct lapb_cb *lapb, struct sk_buff *);
  94. int lapb_data_transmit(struct lapb_cb *lapb, struct sk_buff *);
  95. /* lapb_in.c */
  96. void lapb_data_input(struct lapb_cb *lapb, struct sk_buff *);
  97. /* lapb_out.c */
  98. void lapb_kick(struct lapb_cb *lapb);
  99. void lapb_transmit_buffer(struct lapb_cb *lapb, struct sk_buff *, int);
  100. void lapb_establish_data_link(struct lapb_cb *lapb);
  101. void lapb_enquiry_response(struct lapb_cb *lapb);
  102. void lapb_timeout_response(struct lapb_cb *lapb);
  103. void lapb_check_iframes_acked(struct lapb_cb *lapb, unsigned short);
  104. void lapb_check_need_response(struct lapb_cb *lapb, int, int);
  105. /* lapb_subr.c */
  106. void lapb_clear_queues(struct lapb_cb *lapb);
  107. void lapb_frames_acked(struct lapb_cb *lapb, unsigned short);
  108. void lapb_requeue_frames(struct lapb_cb *lapb);
  109. int lapb_validate_nr(struct lapb_cb *lapb, unsigned short);
  110. int lapb_decode(struct lapb_cb *lapb, struct sk_buff *, struct lapb_frame *);
  111. void lapb_send_control(struct lapb_cb *lapb, int, int, int);
  112. void lapb_transmit_frmr(struct lapb_cb *lapb);
  113. /* lapb_timer.c */
  114. void lapb_start_t1timer(struct lapb_cb *lapb);
  115. void lapb_start_t2timer(struct lapb_cb *lapb);
  116. void lapb_stop_t1timer(struct lapb_cb *lapb);
  117. void lapb_stop_t2timer(struct lapb_cb *lapb);
  118. int lapb_t1timer_running(struct lapb_cb *lapb);
  119. /*
  120. * Debug levels.
  121. * 0 = Off
  122. * 1 = State Changes
  123. * 2 = Packets I/O and State Changes
  124. * 3 = Hex dumps, Packets I/O and State Changes.
  125. */
  126. #define LAPB_DEBUG 0
  127. #define lapb_dbg(level, fmt, ...) \
  128. do { \
  129. if (level < LAPB_DEBUG) \
  130. pr_debug(fmt, ##__VA_ARGS__); \
  131. } while (0)
  132. #endif