blob: 36002df777153dbf2786a4c47f1eac1119b750e7 [file] [log] [blame]
/* Copyright (c) 2011-2013, The Linux Foundation. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 and
* only version 2 as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#ifndef __RMNET_USB_H
#define __RMNET_USB_H
#include <linux/mutex.h>
#include <linux/usb.h>
#include <linux/cdev.h>
#include <linux/usb/ch9.h>
#include <linux/usb/cdc.h>
#define MAX_RMNET_DEVS 4
#define MAX_RMNET_INSTS_PER_DEV 17
#define TOTAL_RMNET_DEV_COUNT (MAX_RMNET_DEVS * MAX_RMNET_INSTS_PER_DEV)
#define CTRL_DEV_MAX_LEN 10
#define RMNET_CTRL_DEV_OPEN 0
#define RMNET_CTRL_DEV_READY 1
#define RMNET_CTRL_DEV_MUX_EN 2
/*MUX header bit masks*/
#define MUX_CTRL_MASK 0x1
#define MUX_PAD_SHIFT 0x2
/*max padding bytes for n byte alignment*/
#define MAX_PAD_BYTES(n) (n-1)
/*
*MUX Header Format
*BIT 0 : Mux type 0: Data, 1: control
*BIT 1: Reserved
*BIT 2-7: Pad bytes
*BIT 8-15: Mux ID
*BIT 16-31: PACKET_LEN_WITH_PADDING (Bytes)
*/
struct mux_hdr {
__u8 padding_info;
__u8 mux_id;
__le16 pkt_len_w_padding;
} __packed;
struct rmnet_ctrl_dev {
/*for debugging purpose*/
char name[CTRL_DEV_MAX_LEN];
struct cdev cdev;
struct device *devicep;
unsigned ch_id;
/*to identify the usb device*/
unsigned id;
struct usb_interface *intf;
unsigned int int_pipe;
struct urb *rcvurb;
struct urb *inturb;
struct usb_anchor tx_submitted;
struct usb_anchor rx_submitted;
void *rcvbuf;
void *intbuf;
struct usb_ctrlrequest *in_ctlreq;
spinlock_t rx_lock;
struct mutex dev_lock;
struct list_head rx_list;
wait_queue_head_t read_wait_queue;
wait_queue_head_t open_wait_queue;
struct workqueue_struct *wq;
struct work_struct get_encap_work;
unsigned long status;
bool claimed;
unsigned int mdm_wait_timeout;
/*input control lines (DSR, CTS, CD, RI)*/
unsigned int cbits_tolocal;
/*output control lines (DTR, RTS)*/
unsigned int cbits_tomdm;
/*counters*/
unsigned int snd_encap_cmd_cnt;
unsigned int get_encap_resp_cnt;
unsigned int resp_avail_cnt;
unsigned int get_encap_failure_cnt;
unsigned int set_ctrl_line_state_cnt;
unsigned int tx_ctrl_err_cnt;
unsigned int zlp_cnt;
};
extern struct workqueue_struct *usbnet_wq;
extern int rmnet_usb_ctrl_start_rx(struct rmnet_ctrl_dev *);
extern int rmnet_usb_ctrl_suspend(struct rmnet_ctrl_dev *dev);
extern int rmnet_usb_ctrl_init(int num_devs, int insts_per_dev);
extern void rmnet_usb_ctrl_exit(int num_devs, int insts_per_dev);
extern int rmnet_usb_ctrl_probe(struct usb_interface *intf,
struct usb_host_endpoint *int_in,
unsigned long rmnet_devnum,
unsigned long *data);
extern void rmnet_usb_ctrl_disconnect(struct rmnet_ctrl_dev *);
#endif /* __RMNET_USB_H*/