1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#ifndef HDF_USB_CDCACM_H
17094332d3Sopenharmony_ci#define HDF_USB_CDCACM_H
18094332d3Sopenharmony_ci
19094332d3Sopenharmony_ci#include "data_fifo.h"
20094332d3Sopenharmony_ci#include "hdf_base.h"
21094332d3Sopenharmony_ci#include "hdf_device_desc.h"
22094332d3Sopenharmony_ci#include "osal_atomic.h"
23094332d3Sopenharmony_ci#include "osal_mutex.h"
24094332d3Sopenharmony_ci#include "usbfn_request.h"
25094332d3Sopenharmony_ci#include "usb_ddk.h"
26094332d3Sopenharmony_ci#include "usb_object.h"
27094332d3Sopenharmony_ci
28094332d3Sopenharmony_ci#define USB_MAX_PACKET_SIZE     0x40
29094332d3Sopenharmony_ci
30094332d3Sopenharmony_cienum UsbSerialCmd {
31094332d3Sopenharmony_ci    USB_SERIAL_OPEN = 0,
32094332d3Sopenharmony_ci    USB_SERIAL_CLOSE,
33094332d3Sopenharmony_ci    USB_SERIAL_READ,
34094332d3Sopenharmony_ci    USB_SERIAL_WRITE,
35094332d3Sopenharmony_ci    USB_SERIAL_GET_BAUDRATE,
36094332d3Sopenharmony_ci    USB_SERIAL_SET_BAUDRATE,
37094332d3Sopenharmony_ci    USB_SERIAL_SET_PROP,
38094332d3Sopenharmony_ci    USB_SERIAL_GET_PROP,
39094332d3Sopenharmony_ci    USB_SERIAL_REGIST_PROP,
40094332d3Sopenharmony_ci    USB_SERIAL_WRITE_SPEED,
41094332d3Sopenharmony_ci    USB_SERIAL_WRITE_GET_TEMP_SPEED,
42094332d3Sopenharmony_ci    USB_SERIAL_WRITE_SPEED_DONE,
43094332d3Sopenharmony_ci    USB_SERIAL_WRITE_GET_TEMP_SPEED_UINT32,
44094332d3Sopenharmony_ci    USB_SERIAL_READ_SPEED,
45094332d3Sopenharmony_ci    USB_SERIAL_READ_GET_TEMP_SPEED,
46094332d3Sopenharmony_ci    USB_SERIAL_READ_SPEED_DONE,
47094332d3Sopenharmony_ci    USB_SERIAL_READ_GET_TEMP_SPEED_UINT32,
48094332d3Sopenharmony_ci    USB_SERIAL_INIT = 100,
49094332d3Sopenharmony_ci    USB_SERIAL_RELEASE = 101,
50094332d3Sopenharmony_ci};
51094332d3Sopenharmony_ci
52094332d3Sopenharmony_cistruct UsbSerial {
53094332d3Sopenharmony_ci    struct UsbAcmDevice         *acm;
54094332d3Sopenharmony_ci    struct UsbCdcLineCoding     lineCoding;
55094332d3Sopenharmony_ci    struct OsalMutex            lock;
56094332d3Sopenharmony_ci
57094332d3Sopenharmony_ci    struct DListHead            readPool;
58094332d3Sopenharmony_ci    struct DListHead            readQueue;
59094332d3Sopenharmony_ci    int32_t                     readStarted;
60094332d3Sopenharmony_ci    int32_t                     readAllocated;
61094332d3Sopenharmony_ci    struct DataFifo             readFifo;
62094332d3Sopenharmony_ci    struct DListHead            writePool;
63094332d3Sopenharmony_ci    int32_t                     writeStarted;
64094332d3Sopenharmony_ci    int32_t                     writeAllocated;
65094332d3Sopenharmony_ci    struct DataFifo             writeFifo;
66094332d3Sopenharmony_ci    bool                        writeBusy;
67094332d3Sopenharmony_ci
68094332d3Sopenharmony_ci    bool                        suspended;
69094332d3Sopenharmony_ci    bool                        startDelayed;
70094332d3Sopenharmony_ci    int32_t                         refCount;
71094332d3Sopenharmony_ci};
72094332d3Sopenharmony_ci
73094332d3Sopenharmony_cistruct AcmNotifyMethod {
74094332d3Sopenharmony_ci    void (*Connect)(struct UsbAcmDevice *acm);
75094332d3Sopenharmony_ci    void (*Disconnect)(struct UsbAcmDevice *acm);
76094332d3Sopenharmony_ci    int32_t (*SendBreak)(struct UsbAcmDevice *acm, int32_t duration);
77094332d3Sopenharmony_ci};
78094332d3Sopenharmony_ci
79094332d3Sopenharmony_cistruct UsbAcmPipe {
80094332d3Sopenharmony_ci    uint8_t                     id;
81094332d3Sopenharmony_ci    uint16_t                    maxPacketSize;
82094332d3Sopenharmony_ci    struct UsbFnInterface       *ctrlIface;
83094332d3Sopenharmony_ci};
84094332d3Sopenharmony_ci
85094332d3Sopenharmony_cistruct UsbAcmInterface {
86094332d3Sopenharmony_ci    struct UsbFnInterface       *fn;
87094332d3Sopenharmony_ci    UsbFnInterfaceHandle        handle;
88094332d3Sopenharmony_ci};
89094332d3Sopenharmony_ci
90094332d3Sopenharmony_cistruct UsbAcmDevice {
91094332d3Sopenharmony_ci    struct IDeviceIoService     service;
92094332d3Sopenharmony_ci    struct HdfDeviceObject      *device;
93094332d3Sopenharmony_ci    struct UsbFnDevice          *fnDev;
94094332d3Sopenharmony_ci    struct UsbAcmInterface      ctrlIface;
95094332d3Sopenharmony_ci    struct UsbAcmInterface      dataIface;
96094332d3Sopenharmony_ci    struct UsbAcmPipe           notifyPipe;
97094332d3Sopenharmony_ci    struct UsbAcmPipe           dataInPipe;
98094332d3Sopenharmony_ci    struct UsbAcmPipe           dataOutPipe;
99094332d3Sopenharmony_ci
100094332d3Sopenharmony_ci    struct DListHead            ctrlPool;
101094332d3Sopenharmony_ci    int32_t                     ctrlReqNum;
102094332d3Sopenharmony_ci    struct UsbFnRequest         *notifyReq;
103094332d3Sopenharmony_ci    struct OsalMutex            lock;
104094332d3Sopenharmony_ci    bool                        pending;
105094332d3Sopenharmony_ci    bool                        initFlag;
106094332d3Sopenharmony_ci    uint32_t                    enableEvtCnt;
107094332d3Sopenharmony_ci    char                        *udcName;
108094332d3Sopenharmony_ci    struct UsbSerial            *port;
109094332d3Sopenharmony_ci    struct UsbCdcLineCoding     lineCoding;
110094332d3Sopenharmony_ci    uint16_t                    serialState;
111094332d3Sopenharmony_ci#define SERIAL_STATE_DCD        (1 << 0)
112094332d3Sopenharmony_ci#define SERIAL_STATE_DSR        (1 << 1)
113094332d3Sopenharmony_ci#define SERIAL_STATE_BREAK      (1 << 2)
114094332d3Sopenharmony_ci#define SERIAL_STATE_RING       (1 << 3)
115094332d3Sopenharmony_ci#define SERIAL_STATE_FRAMING    (1 << 4)
116094332d3Sopenharmony_ci#define SERIAL_STATE_PARITY     (1 << 5)
117094332d3Sopenharmony_ci#define SERIAL_STATE_OVERRUN    (1 << 6)
118094332d3Sopenharmony_ci
119094332d3Sopenharmony_ci    uint16_t                    handshakeBits;
120094332d3Sopenharmony_ci    /* notification callbacks */
121094332d3Sopenharmony_ci    struct AcmNotifyMethod      *notify;
122094332d3Sopenharmony_ci};
123094332d3Sopenharmony_ci
124094332d3Sopenharmony_cistruct CtrlInfo {
125094332d3Sopenharmony_ci    uint8_t                     request;
126094332d3Sopenharmony_ci    struct UsbAcmDevice         *acm;
127094332d3Sopenharmony_ci};
128094332d3Sopenharmony_ci
129094332d3Sopenharmony_ci#endif /* HDF_USB_CDCACM_H */
130