/* * serial.h: Arch-dep definitions for the Etrax100 serial driver. * * Copyright (C) 1998-2007 Axis Communications AB */ #ifndef _ETRAX_SERIAL_H #define _ETRAX_SERIAL_H #include #include #include #include /* Software state per channel */ #ifdef __KERNEL__ /* * This is our internal structure for each serial port's state. * * Many fields are paralleled by the structure used by the serial_struct * structure. * * For definitions of the flags field, see tty.h */ #define SERIAL_RECV_DESCRIPTORS 8 struct etrax_recv_buffer { struct etrax_recv_buffer *next; unsigned short length; unsigned char error; unsigned char pad; unsigned char buffer[0]; }; struct e100_serial { struct tty_port port; int baud; volatile u8 *ioport; /* R_SERIALx_CTRL */ u32 irq; /* bitnr in R_IRQ_MASK2 for dmaX_descr */ /* Output registers */ volatile u8 *oclrintradr; /* adr to R_DMA_CHx_CLR_INTR */ volatile u32 *ofirstadr; /* adr to R_DMA_CHx_FIRST */ volatile u8 *ocmdadr; /* adr to R_DMA_CHx_CMD */ const volatile u8 *ostatusadr; /* adr to R_DMA_CHx_STATUS */ /* Input registers */ volatile u8 *iclrintradr; /* adr to R_DMA_CHx_CLR_INTR */ volatile u32 *ifirstadr; /* adr to R_DMA_CHx_FIRST */ volatile u8 *icmdadr; /* adr to R_DMA_CHx_CMD */ volatile u32 *idescradr; /* adr to R_DMA_CHx_DESCR */ u8 rx_ctrl; /* shadow for R_SERIALx_REC_CTRL */ u8 tx_ctrl; /* shadow for R_SERIALx_TR_CTRL */ u8 iseteop; /* bit number for R_SET_EOP for the input dma */ int enabled; /* Set to 1 if the port is enabled in HW config */ u8 dma_out_enabled; /* Set to 1 if DMA should be used */ u8 dma_in_enabled; /* Set to 1 if DMA should be used */ /* end of fields defined in rs_table[] in .c-file */ int dma_owner; unsigned int dma_in_nbr; unsigned int dma_out_nbr; unsigned int dma_in_irq_nbr; unsigned int dma_out_irq_nbr; unsigned long dma_in_irq_flags; unsigned long dma_out_irq_flags; char *dma_in_irq_description; char *dma_out_irq_description; enum cris_io_interface io_if; char *io_if_description; u8 uses_dma_in; /* Set to 1 if DMA is used */ u8 uses_dma_out; /* Set to 1 if DMA is used */ u8 forced_eop; /* a fifo eop has been forced */ int baud_base; /* For special baudrates */ int custom_divisor; /* For special baudrates */ struct etrax_dma_descr tr_descr; struct etrax_dma_descr rec_descr[SERIAL_RECV_DESCRIPTORS]; int cur_rec_descr; volatile int tr_running; /* 1 if output is running */ int x_char; /* xon/xoff character */ unsigned long event; int line; int type; /* PORT_ETRAX */ struct circ_buf xmit; struct etrax_recv_buffer *first_recv_buffer; struct etrax_recv_buffer *last_recv_buffer; unsigned int recv_cnt; unsigned int max_recv_cnt; struct work_struct work; struct async_icount icount; /* error-statistics etc.*/ unsigned long char_time_usec; /* The time for 1 char, in usecs */ unsigned long flush_time_usec; /* How often we should flush */ unsigned long last_tx_active_usec; /* Last tx usec in the jiffies */ unsigned long last_tx_active; /* Last tx time in jiffies */ unsigned long last_rx_active_usec; /* Last rx usec in the jiffies */ unsigned long last_rx_active; /* Last rx time in jiffies */ int break_detected_cnt; int errorcode; #ifdef CONFIG_ETRAX_RS485 struct serial_rs485 rs485; /* RS-485 support */ #endif }; /* this PORT is not in the standard serial.h. it's not actually used for * anything since we only have one type of async serial-port anyway in this * system. */ #define PORT_ETRAX 1 /* * Events are used to schedule things to happen at timer-interrupt * time, instead of at rs interrupt time. */ #define RS_EVENT_WRITE_WAKEUP 0 #endif /* __KERNEL__ */ #endif /* !_ETRAX_SERIAL_H */ t/net/mac80211?h=nds-private-remove&id=da7061c82e4a1bc6a5e134ef362c86261906c860'>mac80211: Fix adding of mesh vendor IEsThorsten Horstmann1-1/+1 The function ieee80211_ie_split_vendor doesn't return 0 on errors. Instead it returns any offset < ielen when WLAN_EID_VENDOR_SPECIFIC is found. The return value in mesh_add_vendor_ies must therefore be checked against ifmsh->ie_len and not 0. Otherwise all ifmsh->ie starting with WLAN_EID_VENDOR_SPECIFIC will be rejected. Fixes: 082ebb0c258d ("mac80211: fix mesh beacon format") Signed-off-by: Thorsten Horstmann <thorsten@defutech.de> Signed-off-by: Mathias Kretschmer <mathias.kretschmer@fit.fraunhofer.de> Signed-off-by: Simon Wunderlich <sw@simonwunderlich.de> [sven@narfation.org: Add commit message] Signed-off-by: Sven Eckelmann <sven@narfation.org> Signed-off-by: Johannes Berg <johannes.berg@intel.com> 2017-02-06mac80211: Allocate a sync skcipher explicitly for FILS AEADJouni Malinen1-2/+2 The skcipher could have been of the async variant which may return from skcipher_encrypt() with -EINPROGRESS after having queued the request. The FILS AEAD implementation here does not have code for dealing with that possibility, so allocate a sync cipher explicitly to avoid potential issues with hardware accelerators. This is based on the patch sent out by Ard. Fixes: 39404feee691 ("mac80211: FILS AEAD protection for station mode association frames") Reported-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com> 2017-02-06mac80211: Fix FILS AEAD protection in Association Request frameJouni Malinen1-1/+1 Incorrect num_elem parameter value (1 vs. 5) was used in the aes_siv_encrypt() call. This resulted in only the first one of the five AAD vectors to SIV getting included in calculation. This does not protect all the contents correctly and would not interoperate with a standard compliant implementation. Fix this by using the correct number. A matching fix is needed in the AP side (hostapd) to get FILS authentication working properly. Fixes: 39404feee691 ("mac80211: FILS AEAD protection for station mode association frames") Reported-by: Ard Biesheuvel <ard.biesheuvel@linaro.org> Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>