11da177e4SLinus Torvalds #ifndef LLC_CONN_H
21da177e4SLinus Torvalds #define LLC_CONN_H
31da177e4SLinus Torvalds /*
41da177e4SLinus Torvalds * Copyright (c) 1997 by Procom Technology, Inc.
51da177e4SLinus Torvalds * 2001, 2002 by Arnaldo Carvalho de Melo <acme@conectiva.com.br>
61da177e4SLinus Torvalds *
71da177e4SLinus Torvalds * This program can be redistributed or modified under the terms of the
81da177e4SLinus Torvalds * GNU General Public License as published by the Free Software Foundation.
91da177e4SLinus Torvalds * This program is distributed without any warranty or implied warranty
101da177e4SLinus Torvalds * of merchantability or fitness for a particular purpose.
111da177e4SLinus Torvalds *
121da177e4SLinus Torvalds * See the GNU General Public License for more details.
131da177e4SLinus Torvalds */
141da177e4SLinus Torvalds #include <linux/timer.h>
151da177e4SLinus Torvalds #include <net/llc_if.h>
161da177e4SLinus Torvalds #include <net/sock.h>
171da177e4SLinus Torvalds #include <linux/llc.h>
181da177e4SLinus Torvalds
191da177e4SLinus Torvalds #define LLC_EVENT 1
201da177e4SLinus Torvalds #define LLC_PACKET 2
211da177e4SLinus Torvalds
22590232a7SArnaldo Carvalho de Melo #define LLC2_P_TIME 2
23590232a7SArnaldo Carvalho de Melo #define LLC2_ACK_TIME 1
24590232a7SArnaldo Carvalho de Melo #define LLC2_REJ_TIME 3
25590232a7SArnaldo Carvalho de Melo #define LLC2_BUSY_TIME 3
261da177e4SLinus Torvalds
271da177e4SLinus Torvalds struct llc_timer {
281da177e4SLinus Torvalds struct timer_list timer;
29590232a7SArnaldo Carvalho de Melo unsigned long expire; /* timer expire time */
301da177e4SLinus Torvalds };
311da177e4SLinus Torvalds
321da177e4SLinus Torvalds struct llc_sock {
331da177e4SLinus Torvalds /* struct sock must be the first member of llc_sock */
341da177e4SLinus Torvalds struct sock sk;
351da177e4SLinus Torvalds struct sockaddr_llc addr; /* address sock is bound to */
361da177e4SLinus Torvalds u8 state; /* state of connection */
371da177e4SLinus Torvalds struct llc_sap *sap; /* pointer to parent SAP */
381da177e4SLinus Torvalds struct llc_addr laddr; /* lsap/mac pair */
391da177e4SLinus Torvalds struct llc_addr daddr; /* dsap/mac pair */
401da177e4SLinus Torvalds struct net_device *dev; /* device to send to remote */
41615d069dSEric Dumazet netdevice_tracker dev_tracker;
428420e1b5SArnaldo Carvalho de Melo u32 copied_seq; /* head of yet unread data */
431da177e4SLinus Torvalds u8 retry_count; /* number of retries */
441da177e4SLinus Torvalds u8 ack_must_be_send;
451da177e4SLinus Torvalds u8 first_pdu_Ns;
461da177e4SLinus Torvalds u8 npta;
471da177e4SLinus Torvalds struct llc_timer ack_timer;
481da177e4SLinus Torvalds struct llc_timer pf_cycle_timer;
491da177e4SLinus Torvalds struct llc_timer rej_sent_timer;
501da177e4SLinus Torvalds struct llc_timer busy_state_timer; /* ind busy clr at remote LLC */
511da177e4SLinus Torvalds u8 vS; /* seq# next in-seq I-PDU tx'd*/
521da177e4SLinus Torvalds u8 vR; /* seq# next in-seq I-PDU rx'd*/
531da177e4SLinus Torvalds u32 n2; /* max nbr re-tx's for timeout*/
541da177e4SLinus Torvalds u32 n1; /* max nbr octets in I PDU */
551da177e4SLinus Torvalds u8 k; /* tx window size; max = 127 */
561da177e4SLinus Torvalds u8 rw; /* rx window size; max = 127 */
571da177e4SLinus Torvalds u8 p_flag; /* state flags */
581da177e4SLinus Torvalds u8 f_flag;
591da177e4SLinus Torvalds u8 s_flag;
601da177e4SLinus Torvalds u8 data_flag;
611da177e4SLinus Torvalds u8 remote_busy_flag;
621da177e4SLinus Torvalds u8 cause_flag;
631da177e4SLinus Torvalds struct sk_buff_head pdu_unack_q; /* PUDs sent/waiting ack */
641da177e4SLinus Torvalds u16 link; /* network layer link number */
651da177e4SLinus Torvalds u8 X; /* a temporary variable */
661da177e4SLinus Torvalds u8 ack_pf; /* this flag indicates what is
671da177e4SLinus Torvalds the P-bit of acknowledge */
681da177e4SLinus Torvalds u8 failed_data_req; /* recognize that already exist a
691da177e4SLinus Torvalds failed llc_data_req_handler
701da177e4SLinus Torvalds (tx_buffer_full or unacceptable
711da177e4SLinus Torvalds state */
721da177e4SLinus Torvalds u8 dec_step;
731da177e4SLinus Torvalds u8 inc_cntr;
741da177e4SLinus Torvalds u8 dec_cntr;
751da177e4SLinus Torvalds u8 connect_step;
761da177e4SLinus Torvalds u8 last_nr; /* NR of last pdu received */
771da177e4SLinus Torvalds u32 rx_pdu_hdr; /* used for saving header of last pdu
781da177e4SLinus Torvalds received and caused sending FRMR.
791da177e4SLinus Torvalds Used for resending FRMR */
80e5cd6fe3SOctavian Purdila u32 cmsg_flags;
816d2e3ea2SOctavian Purdila struct hlist_node dev_hash_node;
821da177e4SLinus Torvalds };
831da177e4SLinus Torvalds
llc_sk(const struct sock * sk)841da177e4SLinus Torvalds static inline struct llc_sock *llc_sk(const struct sock *sk)
851da177e4SLinus Torvalds {
861da177e4SLinus Torvalds return (struct llc_sock *)sk;
871da177e4SLinus Torvalds }
881da177e4SLinus Torvalds
llc_set_backlog_type(struct sk_buff * skb,char type)891da177e4SLinus Torvalds static __inline__ void llc_set_backlog_type(struct sk_buff *skb, char type)
901da177e4SLinus Torvalds {
911da177e4SLinus Torvalds skb->cb[sizeof(skb->cb) - 1] = type;
921da177e4SLinus Torvalds }
931da177e4SLinus Torvalds
llc_backlog_type(struct sk_buff * skb)941da177e4SLinus Torvalds static __inline__ char llc_backlog_type(struct sk_buff *skb)
951da177e4SLinus Torvalds {
961da177e4SLinus Torvalds return skb->cb[sizeof(skb->cb) - 1];
971da177e4SLinus Torvalds }
981da177e4SLinus Torvalds
99bf3c710fSJoe Perches struct sock *llc_sk_alloc(struct net *net, int family, gfp_t priority,
10011aa9c28SEric W. Biederman struct proto *prot, int kern);
101b905ef9aSCong Wang void llc_sk_stop_all_timers(struct sock *sk, bool sync);
102bf3c710fSJoe Perches void llc_sk_free(struct sock *sk);
1031da177e4SLinus Torvalds
104bf3c710fSJoe Perches void llc_sk_reset(struct sock *sk);
1051da177e4SLinus Torvalds
1061da177e4SLinus Torvalds /* Access to a connection */
107bf3c710fSJoe Perches int llc_conn_state_process(struct sock *sk, struct sk_buff *skb);
108b74555deSEric Biggers void llc_conn_send_pdu(struct sock *sk, struct sk_buff *skb);
109bf3c710fSJoe Perches void llc_conn_rtn_pdu(struct sock *sk, struct sk_buff *skb);
110bf3c710fSJoe Perches void llc_conn_resend_i_pdu_as_cmd(struct sock *sk, u8 nr, u8 first_p_bit);
111bf3c710fSJoe Perches void llc_conn_resend_i_pdu_as_rsp(struct sock *sk, u8 nr, u8 first_f_bit);
112bf3c710fSJoe Perches int llc_conn_remove_acked_pdus(struct sock *conn, u8 nr, u16 *how_many_unacked);
113bf3c710fSJoe Perches struct sock *llc_lookup_established(struct llc_sap *sap, struct llc_addr *daddr,
114*97b1d320SKuniyuki Iwashima struct llc_addr *laddr, const struct net *net);
115bf3c710fSJoe Perches void llc_sap_add_socket(struct llc_sap *sap, struct sock *sk);
116bf3c710fSJoe Perches void llc_sap_remove_socket(struct llc_sap *sap, struct sock *sk);
1171da177e4SLinus Torvalds
118bf3c710fSJoe Perches u8 llc_data_accept_state(u8 state);
119bf3c710fSJoe Perches void llc_build_offset_table(void);
1201da177e4SLinus Torvalds #endif /* LLC_CONN_H */
121