/* * 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_ */ d6b8a2685849c83e7810d17'>root/drivers/usb/usbip
diff options
context:
space:
mode:
authorSinclair Yeh <syeh@vmware.com>2017-01-18 14:14:01 -0800
committerSinclair Yeh <syeh@vmware.com>2017-01-26 19:53:34 -0800
commit242ef5d483594a2bed6b8a2685849c83e7810d17 (patch)
tree7ed12099198823ccb1d41180be6b85cee5ecce3f /drivers/usb/usbip
parent54a07c7bb0da0343734c78212bbe9f3735394962 (diff)
drm/vmwgfx: Fix depth input into drm_mode_legacy_fb_format
Currently the pitch is passed in as depth. This causes drm_mode_legacy_fb_format() to return the wrong pixel format. The wrong pixel format will be rejected by vmw_kms_new_framebuffer(), thus leaving par->set_fb to NULL. This eventually causes a crash in vmw_fb_setcolreg() when the code tries to dereference par->set_fb. Signed-off-by: Sinclair Yeh <syeh@vmware.com> Reviewed-by: Thomas Hellstrom <thellstrom@vmware.com>
Diffstat (limited to 'drivers/usb/usbip')