11bd4fe43Sopenharmony_ci/*
21bd4fe43Sopenharmony_ci * Copyright (c) 2021 HiSilicon (Shanghai) Technologies CO., LIMITED.
31bd4fe43Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
41bd4fe43Sopenharmony_ci * you may not use this file except in compliance with the License.
51bd4fe43Sopenharmony_ci * You may obtain a copy of the License at
61bd4fe43Sopenharmony_ci *
71bd4fe43Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
81bd4fe43Sopenharmony_ci *
91bd4fe43Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
101bd4fe43Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
111bd4fe43Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
121bd4fe43Sopenharmony_ci * See the License for the specific language governing permissions and
131bd4fe43Sopenharmony_ci * limitations under the License.
141bd4fe43Sopenharmony_ci */
151bd4fe43Sopenharmony_ci
161bd4fe43Sopenharmony_ci#ifndef HIETH_H
171bd4fe43Sopenharmony_ci#define HIETH_H
181bd4fe43Sopenharmony_ci
191bd4fe43Sopenharmony_ci#include <osal_spinlock.h>
201bd4fe43Sopenharmony_ci#include <los_event.h>
211bd4fe43Sopenharmony_ci#include "eth_device.h"
221bd4fe43Sopenharmony_ci
231bd4fe43Sopenharmony_ci#ifdef __cplusplus
241bd4fe43Sopenharmony_ci#if __cplusplus
251bd4fe43Sopenharmony_ciextern "C" {
261bd4fe43Sopenharmony_ci#endif /* __cplusplus */
271bd4fe43Sopenharmony_ci#endif /* __cplusplus */
281bd4fe43Sopenharmony_ci
291bd4fe43Sopenharmony_ci#define HIETH_TSO_SUPPORTED
301bd4fe43Sopenharmony_ci#define CONFIG_HIETH_HWQ_XMIT_DEPTH 12
311bd4fe43Sopenharmony_ci#define HIETH_HWQ_TXQ_SIZE          (2 * CONFIG_HIETH_HWQ_XMIT_DEPTH)
321bd4fe43Sopenharmony_ci
331bd4fe43Sopenharmony_ci/* Interface Mode definitions */
341bd4fe43Sopenharmony_citypedef enum {
351bd4fe43Sopenharmony_ci    PHY_INTERFACE_MODE_MII,
361bd4fe43Sopenharmony_ci    PHY_INTERFACE_MODE_RMII,
371bd4fe43Sopenharmony_ci    PHY_INTERFACE_MODE_MAX,
381bd4fe43Sopenharmony_ci} PhyInterfaceMode;
391bd4fe43Sopenharmony_ci
401bd4fe43Sopenharmony_ci/* port */
411bd4fe43Sopenharmony_ci#define UP_PORT     0
421bd4fe43Sopenharmony_ci#define DOWN_PORT   1
431bd4fe43Sopenharmony_ci
441bd4fe43Sopenharmony_cistruct TxPktInfo {
451bd4fe43Sopenharmony_ci    union {
461bd4fe43Sopenharmony_ci        struct {
471bd4fe43Sopenharmony_ci            uint32_t dataLen : 11;
481bd4fe43Sopenharmony_ci            uint32_t nfragsNum : 5;
491bd4fe43Sopenharmony_ci            uint32_t protHdrLen : 4;
501bd4fe43Sopenharmony_ci            uint32_t ipHdrLen : 4;
511bd4fe43Sopenharmony_ci            uint32_t reserved : 2;
521bd4fe43Sopenharmony_ci            uint32_t sgFlag : 1;
531bd4fe43Sopenharmony_ci            uint32_t coeFlag : 1;
541bd4fe43Sopenharmony_ci            uint32_t portType : 1;
551bd4fe43Sopenharmony_ci            uint32_t ipVer : 1;
561bd4fe43Sopenharmony_ci            uint32_t vlanFlag : 1;
571bd4fe43Sopenharmony_ci            uint32_t tsoFlag : 1;
581bd4fe43Sopenharmony_ci        } info;
591bd4fe43Sopenharmony_ci        uint32_t val;
601bd4fe43Sopenharmony_ci    } tx;
611bd4fe43Sopenharmony_ci    uint32_t txAddr; /* normal pkt: data buffer, sg pkt: sg desc buffer */
621bd4fe43Sopenharmony_ci    uint32_t sgDescOffset; /* TSO pkt, desc addr */
631bd4fe43Sopenharmony_ci};
641bd4fe43Sopenharmony_ci
651bd4fe43Sopenharmony_cistruct HiethNetdevLocal {
661bd4fe43Sopenharmony_ci#ifdef HIETH_TSO_SUPPORTED
671bd4fe43Sopenharmony_ci    uint32_t sgHead;
681bd4fe43Sopenharmony_ci    uint32_t sgTail;
691bd4fe43Sopenharmony_ci#endif
701bd4fe43Sopenharmony_ci    char *iobase;   /* virtual io addr */
711bd4fe43Sopenharmony_ci    unsigned long iobasePhys; /* physical io addr */
721bd4fe43Sopenharmony_ci    uint8_t port; /* 0 => up port, 1 => down port */
731bd4fe43Sopenharmony_ci
741bd4fe43Sopenharmony_ci#ifdef HIETH_TSO_SUPPORTED
751bd4fe43Sopenharmony_ci    struct TxPktInfo *txq;
761bd4fe43Sopenharmony_ci    uint32_t txqHead;
771bd4fe43Sopenharmony_ci    uint32_t txqTail;
781bd4fe43Sopenharmony_ci    int32_t qSize;
791bd4fe43Sopenharmony_ci#endif
801bd4fe43Sopenharmony_ci    int32_t txHwCnt;
811bd4fe43Sopenharmony_ci
821bd4fe43Sopenharmony_ci    struct {
831bd4fe43Sopenharmony_ci        int32_t hwXmitq;
841bd4fe43Sopenharmony_ci    } depth;
851bd4fe43Sopenharmony_ci
861bd4fe43Sopenharmony_ci#define SKB_SIZE (HIETH_MAX_FRAME_SIZE)
871bd4fe43Sopenharmony_ci    uint32_t phyId;
881bd4fe43Sopenharmony_ci    uint32_t mdioFrqdiv;
891bd4fe43Sopenharmony_ci    int32_t linkStat;
901bd4fe43Sopenharmony_ci    int32_t txBusy;
911bd4fe43Sopenharmony_ci
921bd4fe43Sopenharmony_ci    int32_t phyMode;
931bd4fe43Sopenharmony_ci    int32_t phyAddr;
941bd4fe43Sopenharmony_ci    OsalSpinlock tx_lock;
951bd4fe43Sopenharmony_ci    OsalSpinlock rx_lock;
961bd4fe43Sopenharmony_ci};
971bd4fe43Sopenharmony_ci
981bd4fe43Sopenharmony_ci/* hieth context */
991bd4fe43Sopenharmony_cistruct HiethPlatformData {
1001bd4fe43Sopenharmony_ci    struct HiethNetdevLocal stNetdevLocal;
1011bd4fe43Sopenharmony_ci    EVENT_CB_S stEvent;
1021bd4fe43Sopenharmony_ci};
1031bd4fe43Sopenharmony_ci
1041bd4fe43Sopenharmony_cistruct HiethPlatformData *GetHiethPlatformData(void);
1051bd4fe43Sopenharmony_cistruct HiethNetdevLocal *GetHiethNetDevLocal(struct EthDevice *ethDevice);
1061bd4fe43Sopenharmony_ci
1071bd4fe43Sopenharmony_ci#ifdef __cplusplus
1081bd4fe43Sopenharmony_ci#if __cplusplus
1091bd4fe43Sopenharmony_ci}
1101bd4fe43Sopenharmony_ci#endif /* __cplusplus */
1111bd4fe43Sopenharmony_ci#endif /* __cplusplus */
1121bd4fe43Sopenharmony_ci
1131bd4fe43Sopenharmony_ci#endif /* HIETH_H */
114