/* SPDX-License-Identifier: GPL-2.0 */
|
/* Copyright (c) 2012 GCT Semiconductor, Inc. All rights reserved. */
|
|
#ifndef _GDM_MUX_H_
|
#define _GDM_MUX_H_
|
|
#include <linux/types.h>
|
#include <linux/usb.h>
|
#include <linux/list.h>
|
|
#include "gdm_tty.h"
|
|
#define PM_NORMAL 0
|
#define PM_SUSPEND 1
|
|
#define USB_RT_ACM (USB_TYPE_CLASS | USB_RECIP_INTERFACE)
|
|
#define START_FLAG 0xA512485A
|
#define MUX_HEADER_SIZE 14
|
#define MUX_TX_MAX_SIZE (1024 * 10)
|
#define MUX_RX_MAX_SIZE (1024 * 30)
|
#define AT_PKT_TYPE 0xF011
|
#define DM_PKT_TYPE 0xF010
|
|
#define RETRY_TIMER 30 /* msec */
|
|
struct mux_pkt_header {
|
__le32 start_flag;
|
__le32 seq_num;
|
__le32 payload_size;
|
__le16 packet_type;
|
unsigned char data[];
|
};
|
|
struct mux_tx {
|
struct urb *urb;
|
u8 *buf;
|
int len;
|
void (*callback)(void *cb_data);
|
void *cb_data;
|
};
|
|
struct mux_rx {
|
struct list_head free_list;
|
struct list_head rx_submit_list;
|
struct list_head to_host_list;
|
struct urb *urb;
|
u8 *buf;
|
void *mux_dev;
|
u32 offset;
|
u32 len;
|
int (*callback)(void *data,
|
int len,
|
int tty_index,
|
struct tty_dev *tty_dev,
|
int complete);
|
};
|
|
struct rx_cxt {
|
struct list_head to_host_list;
|
struct list_head rx_submit_list;
|
struct list_head rx_free_list;
|
spinlock_t to_host_lock;
|
spinlock_t submit_list_lock;
|
spinlock_t free_list_lock;
|
};
|
|
struct mux_dev {
|
struct usb_device *usbdev;
|
struct usb_interface *control_intf;
|
struct usb_interface *data_intf;
|
struct rx_cxt rx;
|
struct delayed_work work_rx;
|
struct usb_interface *intf;
|
int usb_state;
|
int (*rx_cb)(void *data,
|
int len,
|
int tty_index,
|
struct tty_dev *tty_dev,
|
int complete);
|
spinlock_t write_lock;
|
struct tty_dev *tty_dev;
|
};
|
|
#endif /* _GDM_MUX_H_ */
|