Samuel Ortiz | c6ae522 | 2006-05-25 16:19:22 -0700 | [diff] [blame] | 1 | /***************************************************************************** |
| 2 | * |
| 3 | * Filename: mcs7780.h |
| 4 | * Version: 0.2-alpha |
| 5 | * Description: Irda MosChip USB Dongle |
| 6 | * Status: Experimental |
| 7 | * Authors: Lukasz Stelmach <stlman@poczta.fm> |
| 8 | * Brian Pugh <bpugh@cs.pdx.edu> |
| 9 | * |
| 10 | * Copyright (C) 2005, Lukasz Stelmach <stlman@poczta.fm> |
| 11 | * Copyright (C) 2005, Brian Pugh <bpugh@cs.pdx.edu> |
| 12 | * |
| 13 | * This program is free software; you can redistribute it and/or modify |
| 14 | * it under the terms of the GNU General Public License as published by |
| 15 | * the Free Software Foundation; either version 2 of the License, or |
| 16 | * (at your option) any later version. |
| 17 | * |
| 18 | * This program is distributed in the hope that it will be useful, |
| 19 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 20 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 21 | * GNU General Public License for more details. |
| 22 | * |
| 23 | * You should have received a copy of the GNU General Public License |
| 24 | * along with this program; if not, write to the Free Software |
| 25 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. |
| 26 | * |
| 27 | *****************************************************************************/ |
| 28 | #ifndef _MCS7780_H |
| 29 | #define _MCS7780_H |
| 30 | |
| 31 | #define MCS_MODE_SIR 0 |
| 32 | #define MCS_MODE_MIR 1 |
| 33 | #define MCS_MODE_FIR 2 |
| 34 | |
| 35 | #define MCS_CTRL_TIMEOUT 500 |
| 36 | #define MCS_XMIT_TIMEOUT 500 |
| 37 | /* Possible transceiver types */ |
| 38 | #define MCS_TSC_VISHAY 0 /* Vishay TFD, default choice */ |
| 39 | #define MCS_TSC_AGILENT 1 /* Agilent 3602/3600 */ |
| 40 | #define MCS_TSC_SHARP 2 /* Sharp GP2W1000YP */ |
| 41 | |
| 42 | /* Requests */ |
| 43 | #define MCS_RD_RTYPE 0xC0 |
| 44 | #define MCS_WR_RTYPE 0x40 |
| 45 | #define MCS_RDREQ 0x0F |
| 46 | #define MCS_WRREQ 0x0E |
| 47 | |
| 48 | /* Register 0x00 */ |
| 49 | #define MCS_MODE_REG 0 |
| 50 | #define MCS_FIR ((__u16)0x0001) |
| 51 | #define MCS_SIR16US ((__u16)0x0002) |
| 52 | #define MCS_BBTG ((__u16)0x0004) |
| 53 | #define MCS_ASK ((__u16)0x0008) |
| 54 | #define MCS_PARITY ((__u16)0x0010) |
| 55 | |
| 56 | /* SIR/MIR speed constants */ |
| 57 | #define MCS_SPEED_SHIFT 5 |
| 58 | #define MCS_SPEED_MASK ((__u16)0x00E0) |
| 59 | #define MCS_SPEED(x) ((x & MCS_SPEED_MASK) >> MCS_SPEED_SHIFT) |
| 60 | #define MCS_SPEED_2400 ((0 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 61 | #define MCS_SPEED_9600 ((1 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 62 | #define MCS_SPEED_19200 ((2 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 63 | #define MCS_SPEED_38400 ((3 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 64 | #define MCS_SPEED_57600 ((4 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 65 | #define MCS_SPEED_115200 ((5 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 66 | #define MCS_SPEED_576000 ((6 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 67 | #define MCS_SPEED_1152000 ((7 << MCS_SPEED_SHIFT) & MCS_SPEED_MASK) |
| 68 | |
| 69 | #define MCS_PLLPWDN ((__u16)0x0100) |
| 70 | #define MCS_DRIVER ((__u16)0x0200) |
| 71 | #define MCS_DTD ((__u16)0x0400) |
| 72 | #define MCS_DIR ((__u16)0x0800) |
| 73 | #define MCS_SIPEN ((__u16)0x1000) |
| 74 | #define MCS_SENDSIP ((__u16)0x2000) |
| 75 | #define MCS_CHGDIR ((__u16)0x4000) |
| 76 | #define MCS_RESET ((__u16)0x8000) |
| 77 | |
| 78 | /* Register 0x02 */ |
| 79 | #define MCS_XCVR_REG 2 |
| 80 | #define MCS_MODE0 ((__u16)0x0001) |
| 81 | #define MCS_STFIR ((__u16)0x0002) |
| 82 | #define MCS_XCVR_CONF ((__u16)0x0004) |
| 83 | #define MCS_RXFAST ((__u16)0x0008) |
| 84 | /* TXCUR [6:4] */ |
| 85 | #define MCS_TXCUR_SHIFT 4 |
| 86 | #define MCS_TXCUR_MASK ((__u16)0x0070) |
| 87 | #define MCS_TXCUR(x) ((x & MCS_TXCUR_MASK) >> MCS_TXCUR_SHIFT) |
| 88 | #define MCS_SETTXCUR(x,y) \ |
| 89 | ((x & ~MCS_TXCUR_MASK) | (y << MCS_TXCUR_SHIFT) & MCS_TXCUR_MASK) |
| 90 | |
| 91 | #define MCS_MODE1 ((__u16)0x0080) |
| 92 | #define MCS_SMODE0 ((__u16)0x0100) |
| 93 | #define MCS_SMODE1 ((__u16)0x0200) |
| 94 | #define MCS_INVTX ((__u16)0x0400) |
| 95 | #define MCS_INVRX ((__u16)0x0800) |
| 96 | |
| 97 | #define MCS_MINRXPW_REG 4 |
| 98 | |
| 99 | #define MCS_RESV_REG 7 |
| 100 | #define MCS_IRINTX ((__u16)0x0001) |
| 101 | #define MCS_IRINRX ((__u16)0x0002) |
| 102 | |
| 103 | struct mcs_cb { |
| 104 | struct usb_device *usbdev; /* init: probe_irda */ |
| 105 | struct net_device *netdev; /* network layer */ |
| 106 | struct irlap_cb *irlap; /* The link layer we are binded to */ |
Samuel Ortiz | c6ae522 | 2006-05-25 16:19:22 -0700 | [diff] [blame] | 107 | struct qos_info qos; |
| 108 | unsigned int speed; /* Current speed */ |
| 109 | unsigned int new_speed; /* new speed */ |
| 110 | |
| 111 | struct work_struct work; /* Change speed work */ |
| 112 | |
| 113 | struct sk_buff *tx_pending; |
| 114 | char in_buf[4096]; /* transmit/receive buffer */ |
| 115 | char out_buf[4096]; /* transmit/receive buffer */ |
| 116 | __u8 *fifo_status; |
| 117 | |
| 118 | iobuff_t rx_buff; /* receive unwrap state machine */ |
Samuel Ortiz | c6ae522 | 2006-05-25 16:19:22 -0700 | [diff] [blame] | 119 | spinlock_t lock; |
| 120 | int receiving; |
| 121 | |
| 122 | __u8 ep_in; |
| 123 | __u8 ep_out; |
| 124 | |
| 125 | struct urb *rx_urb; |
| 126 | struct urb *tx_urb; |
| 127 | |
| 128 | int transceiver_type; |
| 129 | int sir_tweak; |
| 130 | int receive_mode; |
| 131 | }; |
| 132 | |
| 133 | static int mcs_set_reg(struct mcs_cb *mcs, __u16 reg, __u16 val); |
| 134 | static int mcs_get_reg(struct mcs_cb *mcs, __u16 reg, __u16 * val); |
| 135 | |
| 136 | static inline int mcs_setup_transceiver_vishay(struct mcs_cb *mcs); |
| 137 | static inline int mcs_setup_transceiver_agilent(struct mcs_cb *mcs); |
| 138 | static inline int mcs_setup_transceiver_sharp(struct mcs_cb *mcs); |
| 139 | static inline int mcs_setup_transceiver(struct mcs_cb *mcs); |
| 140 | static inline int mcs_wrap_sir_skb(struct sk_buff *skb, __u8 * buf); |
| 141 | static unsigned mcs_wrap_fir_skb(const struct sk_buff *skb, __u8 *buf); |
| 142 | static unsigned mcs_wrap_mir_skb(const struct sk_buff *skb, __u8 *buf); |
| 143 | static void mcs_unwrap_mir(struct mcs_cb *mcs, __u8 *buf, int len); |
| 144 | static void mcs_unwrap_fir(struct mcs_cb *mcs, __u8 *buf, int len); |
| 145 | static inline int mcs_setup_urbs(struct mcs_cb *mcs); |
| 146 | static inline int mcs_receive_start(struct mcs_cb *mcs); |
| 147 | static inline int mcs_find_endpoints(struct mcs_cb *mcs, |
| 148 | struct usb_host_endpoint *ep, int epnum); |
| 149 | |
| 150 | static int mcs_speed_change(struct mcs_cb *mcs); |
| 151 | |
| 152 | static int mcs_net_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd); |
| 153 | static int mcs_net_close(struct net_device *netdev); |
| 154 | static int mcs_net_open(struct net_device *netdev); |
Samuel Ortiz | c6ae522 | 2006-05-25 16:19:22 -0700 | [diff] [blame] | 155 | |
David Howells | 7d12e78 | 2006-10-05 14:55:46 +0100 | [diff] [blame] | 156 | static void mcs_receive_irq(struct urb *urb); |
| 157 | static void mcs_send_irq(struct urb *urb); |
Stephen Hemminger | 6518bbb | 2009-08-31 19:50:50 +0000 | [diff] [blame] | 158 | static netdev_tx_t mcs_hard_xmit(struct sk_buff *skb, |
| 159 | struct net_device *netdev); |
Samuel Ortiz | c6ae522 | 2006-05-25 16:19:22 -0700 | [diff] [blame] | 160 | |
| 161 | static int mcs_probe(struct usb_interface *intf, |
| 162 | const struct usb_device_id *id); |
| 163 | static void mcs_disconnect(struct usb_interface *intf); |
| 164 | |
| 165 | #endif /* _MCS7780_H */ |