162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (C) 2015 Jakub Kicinski <kubakici@wp.pl>
462306a36Sopenharmony_ci */
562306a36Sopenharmony_ci
662306a36Sopenharmony_ci#ifndef __MT7601U_USB_H
762306a36Sopenharmony_ci#define __MT7601U_USB_H
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include "mt7601u.h"
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#define MT7601U_FIRMWARE	"mt7601u.bin"
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#define MT_VEND_REQ_MAX_RETRY	10
1462306a36Sopenharmony_ci#define MT_VEND_REQ_TOUT_MS	300
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci#define MT_VEND_DEV_MODE_RESET	1
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci#define MT_VEND_BUF		sizeof(__le32)
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_cienum mt_vendor_req {
2162306a36Sopenharmony_ci	MT_VEND_DEV_MODE = 1,
2262306a36Sopenharmony_ci	MT_VEND_WRITE = 2,
2362306a36Sopenharmony_ci	MT_VEND_MULTI_READ = 7,
2462306a36Sopenharmony_ci	MT_VEND_WRITE_FCE = 0x42,
2562306a36Sopenharmony_ci};
2662306a36Sopenharmony_ci
2762306a36Sopenharmony_cienum mt_usb_ep_in {
2862306a36Sopenharmony_ci	MT_EP_IN_PKT_RX,
2962306a36Sopenharmony_ci	MT_EP_IN_CMD_RESP,
3062306a36Sopenharmony_ci	__MT_EP_IN_MAX,
3162306a36Sopenharmony_ci};
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_cienum mt_usb_ep_out {
3462306a36Sopenharmony_ci	MT_EP_OUT_INBAND_CMD,
3562306a36Sopenharmony_ci	MT_EP_OUT_AC_BK,
3662306a36Sopenharmony_ci	MT_EP_OUT_AC_BE,
3762306a36Sopenharmony_ci	MT_EP_OUT_AC_VI,
3862306a36Sopenharmony_ci	MT_EP_OUT_AC_VO,
3962306a36Sopenharmony_ci	MT_EP_OUT_HCCA,
4062306a36Sopenharmony_ci	__MT_EP_OUT_MAX,
4162306a36Sopenharmony_ci};
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_cistatic inline struct usb_device *mt7601u_to_usb_dev(struct mt7601u_dev *mt7601u)
4462306a36Sopenharmony_ci{
4562306a36Sopenharmony_ci	return interface_to_usbdev(to_usb_interface(mt7601u->dev));
4662306a36Sopenharmony_ci}
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_cistatic inline bool mt7601u_urb_has_error(struct urb *urb)
4962306a36Sopenharmony_ci{
5062306a36Sopenharmony_ci	return urb->status &&
5162306a36Sopenharmony_ci		urb->status != -ENOENT &&
5262306a36Sopenharmony_ci		urb->status != -ECONNRESET &&
5362306a36Sopenharmony_ci		urb->status != -ESHUTDOWN;
5462306a36Sopenharmony_ci}
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cibool mt7601u_usb_alloc_buf(struct mt7601u_dev *dev, size_t len,
5762306a36Sopenharmony_ci			   struct mt7601u_dma_buf *buf);
5862306a36Sopenharmony_civoid mt7601u_usb_free_buf(struct mt7601u_dev *dev, struct mt7601u_dma_buf *buf);
5962306a36Sopenharmony_ciint mt7601u_usb_submit_buf(struct mt7601u_dev *dev, int dir, int ep_idx,
6062306a36Sopenharmony_ci			   struct mt7601u_dma_buf *buf, gfp_t gfp,
6162306a36Sopenharmony_ci			   usb_complete_t complete_fn, void *context);
6262306a36Sopenharmony_civoid mt7601u_complete_urb(struct urb *urb);
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ciint mt7601u_vendor_request(struct mt7601u_dev *dev, const u8 req,
6562306a36Sopenharmony_ci			   const u8 direction, const u16 val, const u16 offset,
6662306a36Sopenharmony_ci			   void *buf, const size_t buflen);
6762306a36Sopenharmony_civoid mt7601u_vendor_reset(struct mt7601u_dev *dev);
6862306a36Sopenharmony_ciint mt7601u_vendor_single_wr(struct mt7601u_dev *dev, const u8 req,
6962306a36Sopenharmony_ci			     const u16 offset, const u32 val);
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci#endif
72