/* $OpenBSD: if_san_xilinx.h,v 1.4 2004/07/16 15:11:45 alex Exp $ */ /*- * Copyright (c) 2001-2004 Sangoma Technologies (SAN) * All rights reserved. www.sangoma.com * * This code is written by Nenad Corbic <ncorbic@sangoma.com> for SAN. * The code is derived from permitted modifications to software created * by Alex Feldman (al.feldman@sangoma.com). * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following disclaimer * in the documentation and/or other materials provided with the * distribution. * 3. Neither the name of Sangoma Technologies nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY SANGOMA TECHNOLOGIES AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef __IF_SAN_XILINX_H #define __IF_SAN_XILINX_H #define XILINX_CHIP_CFG_REG 0x40 #define XILINX_MCPU_INTERFACE 0x44 #define XILINX_MCPU_INTERFACE_ADDR 0x46 #define XILINX_GLOBAL_INTER_MASK 0x4C #define XILINX_HDLC_TX_INTR_PENDING_REG 0x50 #define XILINX_HDLC_RX_INTR_PENDING_REG 0x54 enum { WP_FIFO_ERROR_BIT, WP_CRC_ERROR_BIT, WP_ABORT_ERROR_BIT, }; #define WP_MAX_FIFO_FRAMES 7 #define XILINX_DMA_TX_INTR_PENDING_REG 0x58 #define XILINX_DMA_RX_INTR_PENDING_REG 0x5C #define XILINX_TIMESLOT_HDLC_CHAN_REG 0x60 #define AFT_T3_RXTX_ADDR_SELECT_REG 0x60 #define XILINX_CURRENT_TIMESLOT_MASK 0x00001F00 #define XILINX_CURRENT_TIMESLOT_SHIFT 8 #define XILINX_HDLC_CONTROL_REG 0x64 #define XILINX_HDLC_ADDR_REG 0x68 #define XILINX_CONTROL_RAM_ACCESS_BUF 0x6C #define XILINX_DMA_CONTROL_REG 0x70 #define XILINX_DMA_TX_STATUS_REG 0x74 #define AFT_TE3_TX_WDT_CTRL_REG 0x74 #define XILINX_DMA_RX_STATUS_REG 0x78 #define AFT_TE3_RX_WDT_CTRL_REG 0x78 #define XILINX_DMA_DATA_REG 0x7C #define AFT_TE3_CRNT_DMA_DESC_ADDR_REG 0x80 #define XILINX_TxDMA_DESCRIPTOR_LO 0x100 #define XILINX_TxDMA_DESCRIPTOR_HI 0x104 #define XILINX_RxDMA_DESCRIPTOR_LO 0x108 #define XILINX_RxDMA_DESCRIPTOR_HI 0x10C #define INTERFACE_TYPE_T1_E1_BIT 0 #define INTERFACE_TYPE_T3_E3_BIT 0 #define XILINX_RED_LED 1 #define AFT_T3_HDLC_TRANS_MODE 1 #define FRONT_END_FRAME_FLAG_ENABLE_BIT 2 #define AFT_T3_CLOCK_MODE 2 #define SIGNALLING_ENABLE_BIT 3 #define FRONT_END_RESET_BIT 4 #define CHIP_RESET_BIT 5 #define HDLC_CORE_RESET_BIT 6 #define HDLC_CORE_READY_FLAG_BIT 7 #define GLOBAL_INTR_ENABLE_BIT 8 #define ERROR_INTR_ENABLE_BIT 9 #define FRONT_END_INTR_ENABLE_BIT 10 #define CHIP_ERROR_MASK 0x00FF0000 #define AFT_TE3_TX_WDT_INTR_PND 26 #define AFT_TE3_RX_WDT_INTR_PND 27 #define FRONT_END_INTR_FLAG 28 #define SECURITY_STATUS_FLAG 29 #define ERROR_INTR_FLAG 30 #define DMA_INTR_FLAG 31 #define XILINX_GLOBAL_INTER_STATUS 0xD0000000 #define TIMESLOT_BIT_SHIFT 16 #define TIMESLOT_BIT_MASK 0x001F0000 #define HDLC_LOGIC_CH_BIT_MASK 0x0000001F #define HDLC_LCH_TIMESLOT_MASK 0x001F001F #define HDLC_RX_CHAN_ENABLE_BIT 0 #define HDLC_RX_FRAME_DATA_BIT 1 #define HDLC_RC_CHAN_ACTIVE_BIT 2 #define HDLC_RX_FRAME_ERROR_BIT 3 #define HDLC_RX_FRAME_ABORT_BIT 4 #define HDLC_RX_PROT_DISABLE_BIT 16 #define HDLC_RX_ADDR_RECOGN_DIS_BIT 17 #define HDLC_RX_ADDR_FIELD_DISC_BIT 18 #define HDLC_RX_ADDR_SIZE_BIT 19 #define HDLC_RX_BRD_ADDR_MATCH_BIT 20 #define HDLC_RX_FCS_SIZE_BIT 21 #define HDLC_CORE_RX_IDLE_LINE_BIT 22 #define HDLC_CODE_RX_ABORT_LINE_BIT 23 #define HDLC_TX_CHAN_ENABLE_BIT 24 #define HDLC_TX_PROT_DISABLE_BIT 25 #define HDLC_TX_ADDR_INSERTION_BIT 26 #define HDLC_TX_ADDR_SIZE_BIT 27 #define HDLC_TX_FCS_SIZE_BIT 28 #define HDLC_TX_FRAME_ABORT_BIT 29 #define HDLC_TX_STOP_TX_ON_ABORT_BIT 30 #define HDLC_TX_CHANNEL_ACTIVE_BIT 31 #define CONTROL_RAM_DATA_MASK 0x0000001F #define HDLC_FIFO_BASE_ADDR_SHIFT 16 #define HDLC_FIFO_BASE_ADDR_MASK 0x1F #define HDLC_FIFO_SIZE_SHIFT 8 #define HDLC_FIFO_SIZE_MASK 0x1F #define HDLC_FREE_LOGIC_CH 31 #define TRANSPARENT_MODE_BIT 31 #define DMA_SIZE_BIT_SHIFT 0 #define DMA_FIFO_HI_MARK_BIT_SHIFT 4 #define DMA_FIFO_LO_MARK_BIT_SHIFT 8 #define DMA_FIFO_T3_MARK_BIT_SHIFT 8 #define DMA_ACTIVE_CHANNEL_BIT_SHIFT 16 #define DMA_ACTIVE_CHANNEL_BIT_MASK 0xFFE0FFFF #define DMA_ENGINE_ENABLE_BIT 31 #define DMA_CHAIN_TE3_MASK 0x0000000F #define TxDMA_LO_PC_ADDR_PTR_BIT_MASK 0xFFFFFFFC #define TxDMA_LO_ALIGNMENT_BIT_MASK 0x00000003 #define TxDMA_HI_DMA_DATA_LENGTH_MASK 0x000007FF #define TxDMA_HI_DMA_PCI_ERROR_MASK 0x00007800 #define TxDMA_HI_DMA_PCI_ERROR_M_ABRT 0x00000800 #define TxDMA_HI_DMA_PCI_ERROR_T_ABRT 0x00001000 #define TxDMA_HI_DMA_PCI_ERROR_DS_TOUT 0x00002000 #define TxDMA_HI_DMA_PCI_ERROR_RETRY_TOUT 0x00004000 #define INIT_DMA_FIFO_CMD_BIT 28 #define TxDMA_HI_DMA_FRAME_START_BIT 30 #define TxDMA_HI_DMA_FRAME_END_BIT 29 #define TxDMA_HI_DMA_GO_READY_BIT 31 #define DMA_FIFO_BASE_ADDR_SHIFT 20 #define DMA_FIFO_BASE_ADDR_MASK 0x1F #define DMA_FIFO_SIZE_SHIFT 15 #define DMA_FIFO_SIZE_MASK 0x1F #define DMA_FIFO_PARAM_CLEAR_MASK 0xFE007FFF #define FIFO_32B 0x00 #define FIFO_64B 0x01 #define FIFO_128B 0x03 #define FIFO_256B 0x07 #define FIFO_512B 0x0F #define FIFO_1024B 0x1F #define RxDMA_LO_PC_ADDR_PTR_BIT_MASK 0xFFFFFFFC #define RxDMA_LO_ALIGNMENT_BIT_MASK 0x00000003 #define RxDMA_HI_DMA_DATA_LENGTH_MASK 0x000007FF #define RxDMA_HI_DMA_PCI_ERROR_MASK 0x00007800 #define RxDMA_HI_DMA_PCI_ERROR_M_ABRT 0x00000800 #define RxDMA_HI_DMA_PCI_ERROR_T_ABRT 0x00001000 #define RxDMA_HI_DMA_PCI_ERROR_DS_TOUT 0x00002000 #define RxDMA_HI_DMA_PCI_ERROR_RETRY_TOUT 0x00004000 #define RxDMA_HI_DMA_COMMAND_BIT_SHIFT 28 #define RxDMA_HI_DMA_FRAME_START_BIT 30 #define RxDMA_HI_DMA_CRC_ERROR_BIT 25 #define RxDMA_HI_DMA_FRAME_ABORT_BIT 26 #define RxDMA_HI_DMA_FRAME_END_BIT 29 #define RxDMA_HI_DMA_GO_READY_BIT 31 #define DMA_HI_TE3_INTR_DISABLE_BIT 27 #define DMA_HI_TE3_NOT_LAST_FRAME_BIT 24 #define AFT_TE3_CRNT_TX_DMA_MASK 0x0000000F #define AFT_TE3_CRNT_RX_DMA_MASK 0x000000F0 #define AFT_TE3_CRNT_RX_DMA_SHIFT 4 typedef struct xilinx_config { unsigned long xilinx_chip_cfg_reg; unsigned long xilinx_dma_control_reg; } xilinx_config_t; #define XILINX_DMA_SIZE 10 #define XILINX_DMA_FIFO_UP 8 #define XILINX_DMA_FIFO_LO 8 #define AFT_T3_DMA_FIFO_MARK 8 #define XILINX_DEFLT_ACTIVE_CH 0 #define MAX_XILINX_TX_DMA_SIZE 0xFFFF #define MIN_WP_PRI_MTU 128 #define DEFAULT_WP_PRI_MTU 1500 #define MAX_WP_PRI_MTU 8188 #define MAX_DATA_SIZE 2000 struct sdla_hdlc_api { unsigned int cmd; unsigned short len; unsigned char bar; unsigned short offset; unsigned char data[MAX_DATA_SIZE]; }; #pragma pack(1) typedef struct { unsigned char error_flag; unsigned short time_stamp; unsigned char reserved[13]; } api_rx_hdr_t; typedef struct { api_rx_hdr_t api_rx_hdr; unsigned char data[1]; } api_rx_element_t; typedef struct { unsigned char attr; unsigned char misc_Tx_bits; unsigned char reserved[14]; } api_tx_hdr_t; typedef struct { api_tx_hdr_t api_tx_hdr; unsigned char data[1]; } api_tx_element_t; #pragma pack() #undef wan_udphdr_data #define wan_udphdr_data wan_udphdr_u.aft.data #define PMC_CONTROL_REG 0x00 #define PMC_RESET_BIT 0 #define PMC_CLOCK_SELECT 1 #define LED_CONTROL_REG 0x01 #define JP8_VALUE 0x02 #define JP7_VALUE 0x01 #define SW0_VALUE 0x04 #define SW1_VALUE 0x08 #define SECURITY_CPLD_REG 0x09 #define SECURITY_CPLD_MASK 0x03 #define SECURITY_CPLD_SHIFT 0x02 #define SECURITY_1LINE_UNCH 0x00 #define SECURITY_1LINE_CH 0x01 #define SECURITY_2LINE_UNCH 0x02 #define SECURITY_2LINE_CH 0x03 #define WRITE_DEF_SECTOR_DSBL 0x01 #define FRONT_END_TYPE_MASK 0x38 #define BIT_DEV_ADDR_CLEAR 0x600 #define BIT_DEV_ADDR_CPLD 0x200 #define MEMORY_TYPE_SRAM 0x00 #define MEMORY_TYPE_FLASH 0x01 #define MASK_MEMORY_TYPE_SRAM 0x10 #define MASK_MEMORY_TYPE_FLASH 0x20 #define BIT_A18_SECTOR_SA4_SA7 0x20 #define USER_SECTOR_START_ADDR 0x40000 #define MAX_TRACE_QUEUE 100 #define TX_DMA_BUF_INIT 0 #define MAX_TRACE_BUFFER (MAX_LGTH_UDP_MGNT_PKT - \ sizeof(iphdr_t) - \ sizeof(udphdr_t) - \ sizeof(wan_mgmt_t) - \ sizeof(wan_trace_info_t) - \ sizeof(wan_cmd_t)) enum { ROUTER_UP_TIME = 0x50, ENABLE_TRACING, DISABLE_TRACING, GET_TRACE_INFO, READ_CODE_VERSION, FLUSH_OPERATIONAL_STATS, OPERATIONAL_STATS, READ_OPERATIONAL_STATS, READ_CONFIGURATION, COMMS_ERROR_STATS_STRUCT, AFT_LINK_STATUS }; #define UDPMGMT_SIGNATURE "AFTPIPEA" typedef struct { unsigned char flag; unsigned short length; unsigned char rsrv0[2]; unsigned char attr; unsigned short tmstamp; unsigned char rsrv1[4]; unsigned long offset; } aft_trc_el_t; typedef struct wp_rx_element { unsigned long dma_addr; unsigned int reg; unsigned int align; unsigned char pkt_error; }wp_rx_element_t; #if defined(_KERNEL) static __inline unsigned short xilinx_valid_mtu(unsigned short mtu) { if (mtu <= 128) { return 128; } else if (mtu <= 256) { return 256; } else if (mtu <= 512) { return 512; } else if (mtu <= 1024) { return 1024; } else if (mtu <= 2048) { return 2048; } else if (mtu <= 4096) { return 4096; } else if (mtu <= 8188) { return 8188; } else { return 0; } } static __inline unsigned short xilinx_dma_buf_bits(unsigned short dma_bufs) { if (dma_bufs < 2) { return 0; } else if (dma_bufs < 3) { return 1; } else if (dma_bufs < 5) { return 2; } else if (dma_bufs < 9) { return 3; } else if (dma_bufs < 17) { return 4; } else { return 0; } } #define AFT_TX_TIMEOUT 25 #define AFT_RX_TIMEOUT 10 #define AFT_MAX_WTD_TIMEOUT 250 static __inline void aft_reset_rx_watchdog(sdla_t *card) { sdla_bus_write_4(card->hw,AFT_TE3_RX_WDT_CTRL_REG,0); } static __inline void aft_enable_rx_watchdog(sdla_t *card, unsigned char timeout) { aft_reset_rx_watchdog(card); sdla_bus_write_4(card->hw,AFT_TE3_RX_WDT_CTRL_REG,timeout); } static __inline void aft_reset_tx_watchdog(sdla_t *card) { sdla_bus_write_4(card->hw,AFT_TE3_TX_WDT_CTRL_REG,0); } static __inline void aft_enable_tx_watchdog(sdla_t *card, unsigned char timeout) { aft_reset_tx_watchdog(card); sdla_bus_write_4(card->hw,AFT_TE3_TX_WDT_CTRL_REG,timeout); } #endif #endif