/* * Lec arp cache * * Marko Kiiskila */ #ifndef _LEC_ARP_H_ #define _LEC_ARP_H_ #include #include #include #include struct lec_arp_table { struct hlist_node next; /* Linked entry list */ unsigned char atm_addr[ATM_ESA_LEN]; /* Atm address */ unsigned char mac_addr[ETH_ALEN]; /* Mac address */ int is_rdesc; /* Mac address is a route descriptor */ struct atm_vcc *vcc; /* Vcc this entry is attached */ struct atm_vcc *recv_vcc; /* Vcc we receive data from */ void (*old_push) (struct atm_vcc *vcc, struct sk_buff *skb); /* Push that leads to daemon */ void (*old_recv_push) (struct atm_vcc *vcc, struct sk_buff *skb); /* Push that leads to daemon */ unsigned long last_used; /* For expiry */ unsigned long timestamp; /* Used for various timestamping things: * 1. FLUSH started * (status=ESI_FLUSH_PENDING) * 2. Counting to * max_unknown_frame_time * (status=ESI_ARP_PENDING|| * status=ESI_VC_PENDING) */ unsigned char no_tries; /* No of times arp retry has been tried */ unsigned char status; /* Status of this entry */ unsigned short flags; /* Flags for this entry */ unsigned short packets_flooded; /* Data packets flooded */ unsigned long flush_tran_id; /* Transaction id in flush protocol */ struct timer_list timer; /* Arping timer */ struct lec_priv *priv; /* Pointer back */ u8 *tlvs; u32 sizeoftlvs; /* * LANE2: Each MAC address can have TLVs * associated with it. sizeoftlvs tells the * the length of the tlvs array */ struct sk_buff_head tx_wait; /* wait queue for outgoing packets */ atomic_t usage; /* usage count */ }; /* * LANE2: Template tlv struct for accessing * the tlvs in the lec_arp_table->tlvs array */ struct tlv { u32 type; u8 length; u8 value[255]; }; /* Status fields */ #define ESI_UNKNOWN 0 /* * Next packet sent to this mac address * causes ARP-request to be sent */ #define ESI_ARP_PENDING 1 /* * There is no ATM address associated with this * 48-bit address. The LE-ARP protocol is in * progress. */ #define ESI_VC_PENDING 2 /* * There is a valid ATM address associated with * this 48-bit address but there is no VC set * up to that ATM address. The signaling * protocol is in process. */ #define ESI_FLUSH_PENDING 4 /* * The LEC has been notified of the FLUSH_START * status and it is assumed that the flush * protocol is in process. */ #define ESI_FORWARD_DIRECT 5 /* * Either the Path Switching Delay (C22) has * elapsed or the LEC has notified the Mapping * that the flush protocol has completed. In * either case, it is safe to forward packets * to this address via the data direct VC. */ /* Flag values */ #define LEC_REMOTE_FLAG 0x0001 #define LEC_PERMANENT_FLAG 0x0002 #endif /* _LEC_ARP_H_ */ b22'>root/tools/arch/x86/include
diff options
context:
space:
mode:
authorStanislaw Gruszka <sgruszka@redhat.com>2017-01-29 12:40:52 +0100
committerKalle Valo <kvalo@codeaurora.org>2017-01-31 09:08:52 +0200
commit33e962c8871f015f5c8978384553dddcf5b81b22 (patch)
tree43aff96c2ee21d9e0fa2018457778a4de52053cd /tools/arch/x86/include
parent575ddce0507789bf9830d089557d2199d2f91865 (diff)
rt2x00: fix clk_get call
clk_get() takes two arguments and might return ERR_PTR(), so we have to nullify pointer on that case, to do not break further call to clk_get_rate(). Reported-by: Felix Fietkau <nbd@nbd.name> Fixes: 34db70b92fae ("rt2x00: add copy of clk for soc devices") Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
Diffstat (limited to 'tools/arch/x86/include')