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 */ 418420e1b5SArnaldo Carvalho de Melo u32 copied_seq; /* head of yet unread data */ 421da177e4SLinus Torvalds u8 retry_count; /* number of retries */ 431da177e4SLinus Torvalds u8 ack_must_be_send; 441da177e4SLinus Torvalds u8 first_pdu_Ns; 451da177e4SLinus Torvalds u8 npta; 461da177e4SLinus Torvalds struct llc_timer ack_timer; 471da177e4SLinus Torvalds struct llc_timer pf_cycle_timer; 481da177e4SLinus Torvalds struct llc_timer rej_sent_timer; 491da177e4SLinus Torvalds struct llc_timer busy_state_timer; /* ind busy clr at remote LLC */ 501da177e4SLinus Torvalds u8 vS; /* seq# next in-seq I-PDU tx'd*/ 511da177e4SLinus Torvalds u8 vR; /* seq# next in-seq I-PDU rx'd*/ 521da177e4SLinus Torvalds u32 n2; /* max nbr re-tx's for timeout*/ 531da177e4SLinus Torvalds u32 n1; /* max nbr octets in I PDU */ 541da177e4SLinus Torvalds u8 k; /* tx window size; max = 127 */ 551da177e4SLinus Torvalds u8 rw; /* rx window size; max = 127 */ 561da177e4SLinus Torvalds u8 p_flag; /* state flags */ 571da177e4SLinus Torvalds u8 f_flag; 581da177e4SLinus Torvalds u8 s_flag; 591da177e4SLinus Torvalds u8 data_flag; 601da177e4SLinus Torvalds u8 remote_busy_flag; 611da177e4SLinus Torvalds u8 cause_flag; 621da177e4SLinus Torvalds struct sk_buff_head pdu_unack_q; /* PUDs sent/waiting ack */ 631da177e4SLinus Torvalds u16 link; /* network layer link number */ 641da177e4SLinus Torvalds u8 X; /* a temporary variable */ 651da177e4SLinus Torvalds u8 ack_pf; /* this flag indicates what is 661da177e4SLinus Torvalds the P-bit of acknowledge */ 671da177e4SLinus Torvalds u8 failed_data_req; /* recognize that already exist a 681da177e4SLinus Torvalds failed llc_data_req_handler 691da177e4SLinus Torvalds (tx_buffer_full or unacceptable 701da177e4SLinus Torvalds state */ 711da177e4SLinus Torvalds u8 dec_step; 721da177e4SLinus Torvalds u8 inc_cntr; 731da177e4SLinus Torvalds u8 dec_cntr; 741da177e4SLinus Torvalds u8 connect_step; 751da177e4SLinus Torvalds u8 last_nr; /* NR of last pdu received */ 761da177e4SLinus Torvalds u32 rx_pdu_hdr; /* used for saving header of last pdu 771da177e4SLinus Torvalds received and caused sending FRMR. 781da177e4SLinus Torvalds Used for resending FRMR */ 79e5cd6fe3SOctavian Purdila u32 cmsg_flags; 806d2e3ea2SOctavian Purdila struct hlist_node dev_hash_node; 811da177e4SLinus Torvalds }; 821da177e4SLinus Torvalds 831da177e4SLinus Torvalds static inline struct llc_sock *llc_sk(const struct sock *sk) 841da177e4SLinus Torvalds { 851da177e4SLinus Torvalds return (struct llc_sock *)sk; 861da177e4SLinus Torvalds } 871da177e4SLinus Torvalds 881da177e4SLinus Torvalds static __inline__ void llc_set_backlog_type(struct sk_buff *skb, char type) 891da177e4SLinus Torvalds { 901da177e4SLinus Torvalds skb->cb[sizeof(skb->cb) - 1] = type; 911da177e4SLinus Torvalds } 921da177e4SLinus Torvalds 931da177e4SLinus Torvalds static __inline__ char llc_backlog_type(struct sk_buff *skb) 941da177e4SLinus Torvalds { 951da177e4SLinus Torvalds return skb->cb[sizeof(skb->cb) - 1]; 961da177e4SLinus Torvalds } 971da177e4SLinus Torvalds 98bf3c710fSJoe Perches struct sock *llc_sk_alloc(struct net *net, int family, gfp_t priority, 9911aa9c28SEric W. Biederman struct proto *prot, int kern); 100*b905ef9aSCong Wang void llc_sk_stop_all_timers(struct sock *sk, bool sync); 101bf3c710fSJoe Perches void llc_sk_free(struct sock *sk); 1021da177e4SLinus Torvalds 103bf3c710fSJoe Perches void llc_sk_reset(struct sock *sk); 1041da177e4SLinus Torvalds 1051da177e4SLinus Torvalds /* Access to a connection */ 106bf3c710fSJoe Perches int llc_conn_state_process(struct sock *sk, struct sk_buff *skb); 107b85ab56cSCong Wang int llc_conn_send_pdu(struct sock *sk, struct sk_buff *skb); 108bf3c710fSJoe Perches void llc_conn_rtn_pdu(struct sock *sk, struct sk_buff *skb); 109bf3c710fSJoe Perches void llc_conn_resend_i_pdu_as_cmd(struct sock *sk, u8 nr, u8 first_p_bit); 110bf3c710fSJoe Perches void llc_conn_resend_i_pdu_as_rsp(struct sock *sk, u8 nr, u8 first_f_bit); 111bf3c710fSJoe Perches int llc_conn_remove_acked_pdus(struct sock *conn, u8 nr, u16 *how_many_unacked); 112bf3c710fSJoe Perches struct sock *llc_lookup_established(struct llc_sap *sap, struct llc_addr *daddr, 1131da177e4SLinus Torvalds struct llc_addr *laddr); 114bf3c710fSJoe Perches void llc_sap_add_socket(struct llc_sap *sap, struct sock *sk); 115bf3c710fSJoe Perches void llc_sap_remove_socket(struct llc_sap *sap, struct sock *sk); 1161da177e4SLinus Torvalds 117bf3c710fSJoe Perches u8 llc_data_accept_state(u8 state); 118bf3c710fSJoe Perches void llc_build_offset_table(void); 1191da177e4SLinus Torvalds #endif /* LLC_CONN_H */ 120