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