#ifndef __LINUX_ATALK_H__ #define __LINUX_ATALK_H__ /* * AppleTalk networking structures * * The following are directly referenced from the University Of Michigan * netatalk for compatibility reasons. */ #define ATPORT_FIRST 1 #define ATPORT_RESERVED 128 #define ATPORT_LAST 254 /* 254 is only legal on localtalk */ #define ATADDR_ANYNET (__u16)0 #define ATADDR_ANYNODE (__u8)0 #define ATADDR_ANYPORT (__u8)0 #define ATADDR_BCAST (__u8)255 #define DDP_MAXSZ 587 #define DDP_MAXHOPS 15 /* 4 bits of hop counter */ #define SIOCATALKDIFADDR (SIOCPROTOPRIVATE + 0) struct atalk_addr { __be16 s_net; __u8 s_node; }; struct sockaddr_at { sa_family_t sat_family; __u8 sat_port; struct atalk_addr sat_addr; char sat_zero[8]; }; struct atalk_netrange { __u8 nr_phase; __be16 nr_firstnet; __be16 nr_lastnet; }; #ifdef __KERNEL__ #include struct atalk_route { struct net_device *dev; struct atalk_addr target; struct atalk_addr gateway; int flags; struct atalk_route *next; }; /** * struct atalk_iface - AppleTalk Interface * @dev - Network device associated with this interface * @address - Our address * @status - What are we doing? * @nets - Associated direct netrange * @next - next element in the list of interfaces */ struct atalk_iface { struct net_device *dev; struct atalk_addr address; int status; #define ATIF_PROBE 1 /* Probing for an address */ #define ATIF_PROBE_FAIL 2 /* Probe collided */ struct atalk_netrange nets; struct atalk_iface *next; }; struct atalk_sock { /* struct sock has to be the first member of atalk_sock */ struct sock sk; __be16 dest_net; __be16 src_net; unsigned char dest_node; unsigned char src_node; unsigned char dest_port; unsigned char src_port; }; static inline struct atalk_sock *at_sk(struct sock *sk) { return (struct atalk_sock *)sk; } #include struct ddpehdr { #ifdef __LITTLE_ENDIAN_BITFIELD __u16 deh_len:10, deh_hops:4, deh_pad:2; #else __u16 deh_pad:2, deh_hops:4, deh_len:10; #endif __be16 deh_sum; __be16 deh_dnet; __be16 deh_snet; __u8 deh_dnode; __u8 deh_snode; __u8 deh_dport; __u8 deh_sport; /* And netatalk apps expect to stick the type in themselves */ }; static __inline__ struct ddpehdr *ddp_hdr(struct sk_buff *skb) { return (struct ddpehdr *)skb->h.raw; } /* * Don't drop the struct into the struct above. You'll get some * surprise padding. */ struct ddpebits { #ifdef __LITTLE_ENDIAN_BITFIELD __u16 deh_len:10, deh_hops:4, deh_pad:2; #else __u16 deh_pad:2, deh_hops:4, deh_len:10; #endif }; /* Short form header */ struct ddpshdr { #ifdef __LITTLE_ENDIAN_BITFIELD __u16 dsh_len:10, dsh_pad:6; #else __u16 dsh_pad:6, dsh_len:10; #endif __u8 dsh_dport; __u8 dsh_sport; /* And netatalk apps expect to stick the type in themselves */ }; /* AppleTalk AARP headers */ struct elapaarp { __be16 hw_type; #define AARP_HW_TYPE_ETHERNET 1 #define AARP_HW_TYPE_TOKENRING 2 __be16 pa_type; __u8 hw_len; __u8 pa_len; #define AARP_PA_ALEN 4 __be16 function; #define AARP_REQUEST 1 #define AARP_REPLY 2 #define AARP_PROBE 3 __u8 hw_src[ETH_ALEN] __attribute__ ((packed)); __u8 pa_src_zero __attribute__ ((packed)); __be16 pa_src_net __attribute__ ((packed)); __u8 pa_src_node __attribute__ ((packed)); __u8 hw_dst[ETH_ALEN] __attribute__ ((packed)); __u8 pa_dst_zero __attribute__ ((packed)); __be16 pa_dst_net __attribute__ ((packed)); __u8 pa_dst_node __attribute__ ((packed)); }; static __inline__ struct elapaarp *aarp_hdr(struct sk_buff *skb) { return (struct elapaarp *)skb->h.raw; } /* Not specified - how long till we drop a resolved entry */ #define AARP_EXPIRY_TIME (5 * 60 * HZ) /* Size of hash table */ #define AARP_HASH_SIZE 16 /* Fast retransmission timer when resolving */ #define AARP_TICK_TIME (HZ / 5) /* Send 10 requests then give up (2 seconds) */ #define AARP_RETRANSMIT_LIMIT 10 /* * Some value bigger than total retransmit time + a bit for last reply to * appear and to stop continual requests */ #define AARP_RESOLVE_TIME (10 * HZ) extern struct datalink_proto *ddp_dl, *aarp_dl; extern void aarp_proto_init(void); /* Inter module exports */ /* Give a device find its atif control structure */ static inline struct atalk_iface *atalk_find_dev(struct net_device *dev) { return dev->atalk_ptr; } extern struct atalk_addr *atalk_find_dev_addr(struct net_device *dev); extern struct net_device *atrtr_get_dev(struct atalk_addr *sa); extern int aarp_send_ddp(struct net_device *dev, struct sk_buff *skb, struct atalk_addr *sa, void *hwaddr); extern void aarp_device_down(struct net_device *dev); extern void aarp_probe_network(struct atalk_iface *atif); extern int aarp_proxy_probe_network(struct atalk_iface *atif, struct atalk_addr *sa); extern void aarp_proxy_remove(struct net_device *dev, struct atalk_addr *sa); extern void aarp_cleanup_module(void); extern struct hlist_head atalk_sockets; extern rwlock_t atalk_sockets_lock; extern struct atalk_route *atalk_routes; extern rwlock_t atalk_routes_lock; extern struct atalk_iface *atalk_interfaces; extern rwlock_t atalk_interfaces_lock; extern struct atalk_route atrtr_default; extern struct file_operations atalk_seq_arp_fops; extern int sysctl_aarp_expiry_time; extern int sysctl_aarp_tick_time; extern int sysctl_aarp_retransmit_limit; extern int sysctl_aarp_resolve_time; #ifdef CONFIG_SYSCTL extern void atalk_register_sysctl(void); extern void atalk_unregister_sysctl(void); #else #define atalk_register_sysctl() do { } while(0) #define atalk_unregister_sysctl() do { } while(0) #endif #ifdef CONFIG_PROC_FS extern int atalk_proc_init(void); extern void atalk_proc_exit(void); #else #define atalk_proc_init() ({ 0; }) #define atalk_proc_exit() do { } while(0) #endif /* CONFIG_PROC_FS */ #endif /* __KERNEL__ */ #endif /* __LINUX_ATALK_H__ */