162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Declarations of Rose type objects. 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Jonathan Naylor G4KLX 25/8/96 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#ifndef _ROSE_H 962306a36Sopenharmony_ci#define _ROSE_H 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include <linux/rose.h> 1262306a36Sopenharmony_ci#include <net/ax25.h> 1362306a36Sopenharmony_ci#include <net/sock.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#define ROSE_ADDR_LEN 5 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#define ROSE_MIN_LEN 3 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci#define ROSE_CALL_REQ_ADDR_LEN_OFF 3 2062306a36Sopenharmony_ci#define ROSE_CALL_REQ_ADDR_LEN_VAL 0xAA /* each address is 10 digits */ 2162306a36Sopenharmony_ci#define ROSE_CALL_REQ_DEST_ADDR_OFF 4 2262306a36Sopenharmony_ci#define ROSE_CALL_REQ_SRC_ADDR_OFF 9 2362306a36Sopenharmony_ci#define ROSE_CALL_REQ_FACILITIES_OFF 14 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci#define ROSE_GFI 0x10 2662306a36Sopenharmony_ci#define ROSE_Q_BIT 0x80 2762306a36Sopenharmony_ci#define ROSE_D_BIT 0x40 2862306a36Sopenharmony_ci#define ROSE_M_BIT 0x10 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci#define ROSE_CALL_REQUEST 0x0B 3162306a36Sopenharmony_ci#define ROSE_CALL_ACCEPTED 0x0F 3262306a36Sopenharmony_ci#define ROSE_CLEAR_REQUEST 0x13 3362306a36Sopenharmony_ci#define ROSE_CLEAR_CONFIRMATION 0x17 3462306a36Sopenharmony_ci#define ROSE_DATA 0x00 3562306a36Sopenharmony_ci#define ROSE_INTERRUPT 0x23 3662306a36Sopenharmony_ci#define ROSE_INTERRUPT_CONFIRMATION 0x27 3762306a36Sopenharmony_ci#define ROSE_RR 0x01 3862306a36Sopenharmony_ci#define ROSE_RNR 0x05 3962306a36Sopenharmony_ci#define ROSE_REJ 0x09 4062306a36Sopenharmony_ci#define ROSE_RESET_REQUEST 0x1B 4162306a36Sopenharmony_ci#define ROSE_RESET_CONFIRMATION 0x1F 4262306a36Sopenharmony_ci#define ROSE_REGISTRATION_REQUEST 0xF3 4362306a36Sopenharmony_ci#define ROSE_REGISTRATION_CONFIRMATION 0xF7 4462306a36Sopenharmony_ci#define ROSE_RESTART_REQUEST 0xFB 4562306a36Sopenharmony_ci#define ROSE_RESTART_CONFIRMATION 0xFF 4662306a36Sopenharmony_ci#define ROSE_DIAGNOSTIC 0xF1 4762306a36Sopenharmony_ci#define ROSE_ILLEGAL 0xFD 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_ci/* Define Link State constants. */ 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_cienum { 5262306a36Sopenharmony_ci ROSE_STATE_0, /* Ready */ 5362306a36Sopenharmony_ci ROSE_STATE_1, /* Awaiting Call Accepted */ 5462306a36Sopenharmony_ci ROSE_STATE_2, /* Awaiting Clear Confirmation */ 5562306a36Sopenharmony_ci ROSE_STATE_3, /* Data Transfer */ 5662306a36Sopenharmony_ci ROSE_STATE_4, /* Awaiting Reset Confirmation */ 5762306a36Sopenharmony_ci ROSE_STATE_5 /* Deferred Call Acceptance */ 5862306a36Sopenharmony_ci}; 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci#define ROSE_DEFAULT_T0 180000 /* Default T10 T20 value */ 6162306a36Sopenharmony_ci#define ROSE_DEFAULT_T1 200000 /* Default T11 T21 value */ 6262306a36Sopenharmony_ci#define ROSE_DEFAULT_T2 180000 /* Default T12 T22 value */ 6362306a36Sopenharmony_ci#define ROSE_DEFAULT_T3 180000 /* Default T13 T23 value */ 6462306a36Sopenharmony_ci#define ROSE_DEFAULT_HB 5000 /* Default Holdback value */ 6562306a36Sopenharmony_ci#define ROSE_DEFAULT_IDLE 0 /* No Activity Timeout - none */ 6662306a36Sopenharmony_ci#define ROSE_DEFAULT_ROUTING 1 /* Default routing flag */ 6762306a36Sopenharmony_ci#define ROSE_DEFAULT_FAIL_TIMEOUT 120000 /* Time until link considered usable */ 6862306a36Sopenharmony_ci#define ROSE_DEFAULT_MAXVC 50 /* Maximum number of VCs per neighbour */ 6962306a36Sopenharmony_ci#define ROSE_DEFAULT_WINDOW_SIZE 7 /* Default window size */ 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci#define ROSE_MODULUS 8 7262306a36Sopenharmony_ci#define ROSE_MAX_PACKET_SIZE 251 /* Maximum packet size */ 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ci#define ROSE_COND_ACK_PENDING 0x01 7562306a36Sopenharmony_ci#define ROSE_COND_PEER_RX_BUSY 0x02 7662306a36Sopenharmony_ci#define ROSE_COND_OWN_RX_BUSY 0x04 7762306a36Sopenharmony_ci 7862306a36Sopenharmony_ci#define FAC_NATIONAL 0x00 7962306a36Sopenharmony_ci#define FAC_CCITT 0x0F 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci#define FAC_NATIONAL_RAND 0x7F 8262306a36Sopenharmony_ci#define FAC_NATIONAL_FLAGS 0x3F 8362306a36Sopenharmony_ci#define FAC_NATIONAL_DEST_DIGI 0xE9 8462306a36Sopenharmony_ci#define FAC_NATIONAL_SRC_DIGI 0xEB 8562306a36Sopenharmony_ci#define FAC_NATIONAL_FAIL_CALL 0xED 8662306a36Sopenharmony_ci#define FAC_NATIONAL_FAIL_ADD 0xEE 8762306a36Sopenharmony_ci#define FAC_NATIONAL_DIGIS 0xEF 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci#define FAC_CCITT_DEST_NSAP 0xC9 9062306a36Sopenharmony_ci#define FAC_CCITT_SRC_NSAP 0xCB 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_cistruct rose_neigh { 9362306a36Sopenharmony_ci struct rose_neigh *next; 9462306a36Sopenharmony_ci ax25_address callsign; 9562306a36Sopenharmony_ci ax25_digi *digipeat; 9662306a36Sopenharmony_ci ax25_cb *ax25; 9762306a36Sopenharmony_ci struct net_device *dev; 9862306a36Sopenharmony_ci unsigned short count; 9962306a36Sopenharmony_ci unsigned short use; 10062306a36Sopenharmony_ci unsigned int number; 10162306a36Sopenharmony_ci char restarted; 10262306a36Sopenharmony_ci char dce_mode; 10362306a36Sopenharmony_ci char loopback; 10462306a36Sopenharmony_ci struct sk_buff_head queue; 10562306a36Sopenharmony_ci struct timer_list t0timer; 10662306a36Sopenharmony_ci struct timer_list ftimer; 10762306a36Sopenharmony_ci}; 10862306a36Sopenharmony_ci 10962306a36Sopenharmony_cistruct rose_node { 11062306a36Sopenharmony_ci struct rose_node *next; 11162306a36Sopenharmony_ci rose_address address; 11262306a36Sopenharmony_ci unsigned short mask; 11362306a36Sopenharmony_ci unsigned char count; 11462306a36Sopenharmony_ci char loopback; 11562306a36Sopenharmony_ci struct rose_neigh *neighbour[3]; 11662306a36Sopenharmony_ci}; 11762306a36Sopenharmony_ci 11862306a36Sopenharmony_cistruct rose_route { 11962306a36Sopenharmony_ci struct rose_route *next; 12062306a36Sopenharmony_ci unsigned int lci1, lci2; 12162306a36Sopenharmony_ci rose_address src_addr, dest_addr; 12262306a36Sopenharmony_ci ax25_address src_call, dest_call; 12362306a36Sopenharmony_ci struct rose_neigh *neigh1, *neigh2; 12462306a36Sopenharmony_ci unsigned int rand; 12562306a36Sopenharmony_ci}; 12662306a36Sopenharmony_ci 12762306a36Sopenharmony_cistruct rose_sock { 12862306a36Sopenharmony_ci struct sock sock; 12962306a36Sopenharmony_ci rose_address source_addr, dest_addr; 13062306a36Sopenharmony_ci ax25_address source_call, dest_call; 13162306a36Sopenharmony_ci unsigned char source_ndigis, dest_ndigis; 13262306a36Sopenharmony_ci ax25_address source_digis[ROSE_MAX_DIGIS]; 13362306a36Sopenharmony_ci ax25_address dest_digis[ROSE_MAX_DIGIS]; 13462306a36Sopenharmony_ci struct rose_neigh *neighbour; 13562306a36Sopenharmony_ci struct net_device *device; 13662306a36Sopenharmony_ci netdevice_tracker dev_tracker; 13762306a36Sopenharmony_ci unsigned int lci, rand; 13862306a36Sopenharmony_ci unsigned char state, condition, qbitincl, defer; 13962306a36Sopenharmony_ci unsigned char cause, diagnostic; 14062306a36Sopenharmony_ci unsigned short vs, vr, va, vl; 14162306a36Sopenharmony_ci unsigned long t1, t2, t3, hb, idle; 14262306a36Sopenharmony_ci#ifdef M_BIT 14362306a36Sopenharmony_ci unsigned short fraglen; 14462306a36Sopenharmony_ci struct sk_buff_head frag_queue; 14562306a36Sopenharmony_ci#endif 14662306a36Sopenharmony_ci struct sk_buff_head ack_queue; 14762306a36Sopenharmony_ci struct rose_facilities_struct facilities; 14862306a36Sopenharmony_ci struct timer_list timer; 14962306a36Sopenharmony_ci struct timer_list idletimer; 15062306a36Sopenharmony_ci}; 15162306a36Sopenharmony_ci 15262306a36Sopenharmony_ci#define rose_sk(sk) ((struct rose_sock *)(sk)) 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci/* af_rose.c */ 15562306a36Sopenharmony_ciextern ax25_address rose_callsign; 15662306a36Sopenharmony_ciextern int sysctl_rose_restart_request_timeout; 15762306a36Sopenharmony_ciextern int sysctl_rose_call_request_timeout; 15862306a36Sopenharmony_ciextern int sysctl_rose_reset_request_timeout; 15962306a36Sopenharmony_ciextern int sysctl_rose_clear_request_timeout; 16062306a36Sopenharmony_ciextern int sysctl_rose_no_activity_timeout; 16162306a36Sopenharmony_ciextern int sysctl_rose_ack_hold_back_timeout; 16262306a36Sopenharmony_ciextern int sysctl_rose_routing_control; 16362306a36Sopenharmony_ciextern int sysctl_rose_link_fail_timeout; 16462306a36Sopenharmony_ciextern int sysctl_rose_maximum_vcs; 16562306a36Sopenharmony_ciextern int sysctl_rose_window_size; 16662306a36Sopenharmony_ci 16762306a36Sopenharmony_ciint rosecmp(const rose_address *, const rose_address *); 16862306a36Sopenharmony_ciint rosecmpm(const rose_address *, const rose_address *, unsigned short); 16962306a36Sopenharmony_cichar *rose2asc(char *buf, const rose_address *); 17062306a36Sopenharmony_cistruct sock *rose_find_socket(unsigned int, struct rose_neigh *); 17162306a36Sopenharmony_civoid rose_kill_by_neigh(struct rose_neigh *); 17262306a36Sopenharmony_ciunsigned int rose_new_lci(struct rose_neigh *); 17362306a36Sopenharmony_ciint rose_rx_call_request(struct sk_buff *, struct net_device *, 17462306a36Sopenharmony_ci struct rose_neigh *, unsigned int); 17562306a36Sopenharmony_civoid rose_destroy_socket(struct sock *); 17662306a36Sopenharmony_ci 17762306a36Sopenharmony_ci/* rose_dev.c */ 17862306a36Sopenharmony_civoid rose_setup(struct net_device *); 17962306a36Sopenharmony_ci 18062306a36Sopenharmony_ci/* rose_in.c */ 18162306a36Sopenharmony_ciint rose_process_rx_frame(struct sock *, struct sk_buff *); 18262306a36Sopenharmony_ci 18362306a36Sopenharmony_ci/* rose_link.c */ 18462306a36Sopenharmony_civoid rose_start_ftimer(struct rose_neigh *); 18562306a36Sopenharmony_civoid rose_stop_ftimer(struct rose_neigh *); 18662306a36Sopenharmony_civoid rose_stop_t0timer(struct rose_neigh *); 18762306a36Sopenharmony_ciint rose_ftimer_running(struct rose_neigh *); 18862306a36Sopenharmony_civoid rose_link_rx_restart(struct sk_buff *, struct rose_neigh *, 18962306a36Sopenharmony_ci unsigned short); 19062306a36Sopenharmony_civoid rose_transmit_clear_request(struct rose_neigh *, unsigned int, 19162306a36Sopenharmony_ci unsigned char, unsigned char); 19262306a36Sopenharmony_civoid rose_transmit_link(struct sk_buff *, struct rose_neigh *); 19362306a36Sopenharmony_ci 19462306a36Sopenharmony_ci/* rose_loopback.c */ 19562306a36Sopenharmony_civoid rose_loopback_init(void); 19662306a36Sopenharmony_civoid rose_loopback_clear(void); 19762306a36Sopenharmony_ciint rose_loopback_queue(struct sk_buff *, struct rose_neigh *); 19862306a36Sopenharmony_ci 19962306a36Sopenharmony_ci/* rose_out.c */ 20062306a36Sopenharmony_civoid rose_kick(struct sock *); 20162306a36Sopenharmony_civoid rose_enquiry_response(struct sock *); 20262306a36Sopenharmony_ci 20362306a36Sopenharmony_ci/* rose_route.c */ 20462306a36Sopenharmony_ciextern struct rose_neigh *rose_loopback_neigh; 20562306a36Sopenharmony_ciextern const struct seq_operations rose_neigh_seqops; 20662306a36Sopenharmony_ciextern const struct seq_operations rose_node_seqops; 20762306a36Sopenharmony_ciextern struct seq_operations rose_route_seqops; 20862306a36Sopenharmony_ci 20962306a36Sopenharmony_civoid rose_add_loopback_neigh(void); 21062306a36Sopenharmony_ciint __must_check rose_add_loopback_node(const rose_address *); 21162306a36Sopenharmony_civoid rose_del_loopback_node(const rose_address *); 21262306a36Sopenharmony_civoid rose_rt_device_down(struct net_device *); 21362306a36Sopenharmony_civoid rose_link_device_down(struct net_device *); 21462306a36Sopenharmony_cistruct net_device *rose_dev_first(void); 21562306a36Sopenharmony_cistruct net_device *rose_dev_get(rose_address *); 21662306a36Sopenharmony_cistruct rose_route *rose_route_free_lci(unsigned int, struct rose_neigh *); 21762306a36Sopenharmony_cistruct rose_neigh *rose_get_neigh(rose_address *, unsigned char *, 21862306a36Sopenharmony_ci unsigned char *, int); 21962306a36Sopenharmony_ciint rose_rt_ioctl(unsigned int, void __user *); 22062306a36Sopenharmony_civoid rose_link_failed(ax25_cb *, int); 22162306a36Sopenharmony_ciint rose_route_frame(struct sk_buff *, ax25_cb *); 22262306a36Sopenharmony_civoid rose_rt_free(void); 22362306a36Sopenharmony_ci 22462306a36Sopenharmony_ci/* rose_subr.c */ 22562306a36Sopenharmony_civoid rose_clear_queues(struct sock *); 22662306a36Sopenharmony_civoid rose_frames_acked(struct sock *, unsigned short); 22762306a36Sopenharmony_civoid rose_requeue_frames(struct sock *); 22862306a36Sopenharmony_ciint rose_validate_nr(struct sock *, unsigned short); 22962306a36Sopenharmony_civoid rose_write_internal(struct sock *, int); 23062306a36Sopenharmony_ciint rose_decode(struct sk_buff *, int *, int *, int *, int *, int *); 23162306a36Sopenharmony_ciint rose_parse_facilities(unsigned char *, unsigned int, 23262306a36Sopenharmony_ci struct rose_facilities_struct *); 23362306a36Sopenharmony_civoid rose_disconnect(struct sock *, int, int, int); 23462306a36Sopenharmony_ci 23562306a36Sopenharmony_ci/* rose_timer.c */ 23662306a36Sopenharmony_civoid rose_start_heartbeat(struct sock *); 23762306a36Sopenharmony_civoid rose_start_t1timer(struct sock *); 23862306a36Sopenharmony_civoid rose_start_t2timer(struct sock *); 23962306a36Sopenharmony_civoid rose_start_t3timer(struct sock *); 24062306a36Sopenharmony_civoid rose_start_hbtimer(struct sock *); 24162306a36Sopenharmony_civoid rose_start_idletimer(struct sock *); 24262306a36Sopenharmony_civoid rose_stop_heartbeat(struct sock *); 24362306a36Sopenharmony_civoid rose_stop_timer(struct sock *); 24462306a36Sopenharmony_civoid rose_stop_idletimer(struct sock *); 24562306a36Sopenharmony_ci 24662306a36Sopenharmony_ci/* sysctl_net_rose.c */ 24762306a36Sopenharmony_civoid rose_register_sysctl(void); 24862306a36Sopenharmony_civoid rose_unregister_sysctl(void); 24962306a36Sopenharmony_ci 25062306a36Sopenharmony_ci#endif 251