/* * FUJITSU Extended Socket Network Device driver * Copyright (c) 2015 FUJITSU LIMITED * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program; if not, see . * * The full GNU General Public License is included in this distribution in * the file called "COPYING". * */ #ifndef FJES_HW_H_ #define FJES_HW_H_ #include #include #include #include "fjes_regs.h" struct fjes_hw; #define EP_BUFFER_SUPPORT_VLAN_MAX 4 #define EP_BUFFER_INFO_SIZE 4096 #define FJES_DEVICE_RESET_TIMEOUT ((17 + 1) * 3) /* sec */ #define EP_BUFFER_SIZE \ (((sizeof(union ep_buffer_info) + (128 * (64 * 1024))) \ / EP_BUFFER_INFO_SIZE) * EP_BUFFER_INFO_SIZE) #define EP_RING_NUM(buffer_size, frame_size) \ (u32)((buffer_size) / (frame_size)) #define FJES_MTU_TO_BUFFER_SIZE(mtu) \ (ETH_HLEN + VLAN_HLEN + (mtu) + ETH_FCS_LEN) #define FJES_MTU_TO_FRAME_SIZE(mtu) \ (sizeof(struct esmem_frame) + FJES_MTU_TO_BUFFER_SIZE(mtu)) #define FJES_MTU_DEFINE(size) \ ((size) - sizeof(struct esmem_frame) - \ (ETH_HLEN + VLAN_HLEN + ETH_FCS_LEN)) #define FJES_DEV_COMMAND_INFO_RES_LEN(epnum) (8 + 2 * (epnum)) #define FJES_DEV_COMMAND_SHARE_BUFFER_REQ_LEN(txb, rxb) \ (24 + (8 * ((txb) / EP_BUFFER_INFO_SIZE + (rxb) / EP_BUFFER_INFO_SIZE))) #define FJES_DEV_REQ_BUF_SIZE(maxep) \ FJES_DEV_COMMAND_SHARE_BUFFER_REQ_LEN(EP_BUFFER_SIZE, EP_BUFFER_SIZE) #define FJES_DEV_RES_BUF_SIZE(maxep) \ FJES_DEV_COMMAND_INFO_RES_LEN(maxep) /* Frame & MTU */ struct esmem_frame { __le32 frame_size; u8 frame_data[]; }; /* shared status region */ struct fjes_device_shared_info { int epnum; u8 ep_status[]; }; /* structures for command control request data*/ union fjes_device_command_req { struct { __le32 length; } info; struct { __le32 length; __le32 epid; __le64 buffer[]; } share_buffer; struct { __le32 length; __le32 epid; } unshare_buffer; struct { __le32 length; __le32 mode; __le64 buffer_len; __le64 buffer[]; } start_trace; struct { __le32 length; } stop_trace; }; /* structures for command control response data */ union fjes_device_command_res { struct { __le32 length; __le32 code; struct { u8 es_status; u8 zone; } info[]; } info; struct { __le32 length; __le32 code; } share_buffer; struct { __le32 length; __le32 code; } unshare_buffer; struct { __le32 length; __le32 code; } start_trace; struct { __le32 length; __le32 code; } stop_trace; }; /* parameter for command control */ struct fjes_device_command_param { u32 req_len; phys_addr_t req_start; u32 res_len; phys_addr_t res_start; phys_addr_t share_start; }; /* EP buffer information */ union ep_buffer_info { u8 raw[EP_BUFFER_INFO_SIZE]; struct _ep_buffer_info_common_t { u32 version; } common; struct _ep_buffer_info_v1_t { u32 version; u32 info_size; u32 buffer_size; u16 count_max; u16 _rsv_1; u32 frame_max; u8 mac_addr[ETH_ALEN]; u16 _rsv_2; u32 _rsv_3; u16 tx_status; u16 rx_status; u32 head; u32 tail; u16 vlan_id[EP_BUFFER_SUPPORT_VLAN_MAX]; } v1i; }; /* buffer pair for Extended Partition */ struct ep_share_mem_info { struct epbuf_handler { void *buffer; size_t size; union ep_buffer_info *info; u8 *ring; } tx, rx; struct rtnl_link_stats64 net_stats; u16 tx_status_work; u8 es_status; u8 zone; }; struct es_device_trace { u32 record_num; u32 current_record; u32 status_flag; u32 _rsv; struct { u16 epid; u16 dir_offset; u32 data; u64 tsc; } record[]; }; struct fjes_hw_info { struct fjes_device_shared_info *share; union fjes_device_command_req *req_buf; u64 req_buf_size; union fjes_device_command_res *res_buf; u64 res_buf_size; int *my_epid; int *max_epid; struct es_device_trace *trace; u64 trace_size; struct mutex lock; /* buffer lock*/ unsigned long buffer_share_bit; unsigned long buffer_unshare_reserve_bit; }; struct fjes_hw { void *back; unsigned long txrx_stop_req_bit; unsigned long epstop_req_bit; int my_epid; int max_epid; struct ep_share_mem_info *ep_shm_info; struct fjes_hw_resource { u64 start; u64 size; int irq; } hw_res; u8 *base; struct fjes_hw_info hw_info; }; int fjes_hw_init(struct fjes_hw *); int fjes_hw_reset(struct fjes_hw *); void fjes_hw_init_command_registers(struct fjes_hw *, struct fjes_device_command_param *); void fjes_hw_setup_epbuf(struct epbuf_handler *, u8 *, u32); void fjes_hw_set_irqmask(struct fjes_hw *, enum REG_ICTL_MASK, bool); #endif /* FJES_HW_H_ */