/* $OpenBSD: if_san_front_end.h,v 1.5 2007/09/12 13:56:40 chl Exp $ */ /*- * Copyright (c) 2001-2004 Sangoma Technologies (SAN) * All rights reserved. www.sangoma.com * * This code is written by Alex Feldman <al.feldman@sangoma.com> for SAN. * The code is derived from permitted modifications to software created * by Nenad Corbic (ncorbic@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_FRONT_END_H_ #define __IF_SAN_FRONT_END_H_ /* The hardware media */ #define WAN_MEDIA_NONE 0x00 /* Regular card */ #define WAN_MEDIA_T1 0x01 /* T1 connection */ #define WAN_MEDIA_E1 0x02 /* E1 connection */ #define WAN_MEDIA_56K 0x03 /* 56K connection */ /* settings for the 'adapter_type' */ #define S508_ADPTR 0x0001 /* S508 */ #define S5141_ADPTR_1_CPU_SERIAL 0x0011 /* S5141, single CPU, serial */ #define S5142_ADPTR_2_CPU_SERIAL 0x0012 /* S5142, dual CPU, serial */ #define S5143_ADPTR_1_CPU_FT1 0x0013 /* S5143, single CPU, FT1 */ #define S5144_ADPTR_1_CPU_T1E1 0x0014 /* S5144, single CPU, T1/E1 */ #define S5145_ADPTR_1_CPU_56K 0x0015 /* S5145, single CPU, 56K */ #define S5147_ADPTR_2_CPU_T1E1 0x0017 /* S5147, dual CPU, T1/E1 */ #define S5148_ADPTR_1_CPU_T1E1 0x0018 /* S5148, single CPU, T1/E1 */ #define S518_ADPTR_1_CPU_ADSL 0x0018 /* S518, adsl card */ #define A101_ADPTR_T1E1_MASK 0x0040 /* T1/E1 type mask */ #define A101_ADPTR_1TE1 0x0041 /* 1 Channel T1/E1 */ #define A101_ADPTR_2TE1 0x0042 /* 2 Channels T1/E1 */ #define A100_ADPTR_T3E3_MASK 0x0080 /* T3/E3 type mask */ #define A100_ADPTR_1_CHN_T3E3 0x0081 /* 1 Channel T3/E3 (Proto.) */ #define A105_ADPTR_1_CHN_T3E3 0x0082 /* 1 Channel T3/E3 */ #define OPERATE_T1E1_AS_SERIAL 0x8000 /* For bitstreaming only * Allow the application to * E1 front end */ #define SDLA_ADPTR_DECODE(adapter_type) \ (adapter_type == S5141_ADPTR_1_CPU_SERIAL) ? "S514-1-PCI" : \ (adapter_type == S5142_ADPTR_2_CPU_SERIAL) ? "S514-2-PCI" : \ (adapter_type == S5143_ADPTR_1_CPU_FT1) ? "S514-3-PCI" : \ (adapter_type == S5144_ADPTR_1_CPU_T1E1) ? "S514-4-PCI" : \ (adapter_type == S5145_ADPTR_1_CPU_56K) ? "S514-5-PCI" : \ (adapter_type == S5147_ADPTR_2_CPU_T1E1) ? "S514-7-PCI" : \ (adapter_type == S518_ADPTR_1_CPU_ADSL) ? "S518-PCI " : \ (adapter_type == A101_ADPTR_1TE1) ? "AFT-A101 " : \ (adapter_type == A101_ADPTR_2TE1) ? "AFT-A102 " : \ (adapter_type == A105_ADPTR_1_CHN_T3E3) ? "A105-1-PCI" : \ (adapter_type == A105_ADPTR_1_CHN_T3E3) ? "A105-2 " : \ "UNKNOWN " /* front-end UDP command */ #define WAN_FE_GET_STAT (WAN_FE_UDP_CMD_START + 0) #define WAN_FE_SET_LB_MODE (WAN_FE_UDP_CMD_START + 1) #define WAN_FE_FLUSH_PMON (WAN_FE_UDP_CMD_START + 2) #define WAN_FE_GET_CFG (WAN_FE_UDP_CMD_START + 3) /* front-end configuration and access interface commands */ /* 0x90 read from front-end register */ #define READ_FRONT_END_REGISTER (WAN_FE_CMD_START+0) /* 0x91 write to front-end register */ #define WRITE_FRONT_END_REGISTER (WAN_FE_CMD_START+1) /* 0x92 read the front-end statistics */ #define READ_FRONT_END_STATISTICS (WAN_FE_CMD_START+2) /* 0x93 flush the front-end statistics */ #define FLUSH_FRONT_END_STATISTICS (WAN_FE_CMD_START+3) #ifdef _KERNEL /* adapter configuration interface commands */ /* 0xA0 set adapter configuration */ #define SET_ADAPTER_CONFIGURATION (WAN_INTERFACE_CMD_START+0) /* 0xA1 read adapter configuration */ #define READ_ADAPTER_CONFIGURATION (WAN_INTERFACE_CMD_START+1) /* front-end command */ #define WAN_FE_GET_STAT (WAN_FE_UDP_CMD_START + 0) #define WAN_FE_SET_LB_MODE (WAN_FE_UDP_CMD_START + 1) #define WAN_FE_FLUSH_PMON (WAN_FE_UDP_CMD_START + 2) #define WAN_FE_GET_CFG (WAN_FE_UDP_CMD_START + 3) /* * return codes from interface commands */ /* the length of the FE_RX_DISC_TX_IDLE_STRUCT is invalid */ #define LGTH_FE_CFG_DATA_INVALID 0x91 /* the length of the passed configuration data is invalid */ #define LGTH_ADAPTER_CFG_DATA_INVALID 0x91 /* the passed SET_FE_RX_DISC_TX_IDLE_CFG data is invalid */ #define INVALID_FE_CFG_DATA 0x92 /* an invalid adapter operating frequency was selected */ #define ADPTR_OPERATING_FREQ_INVALID 0x92 /* set the protocol-level configuration before setting the FE configuration */ #define PROT_CFG_BEFORE_FE_CFG 0x93 /* set the front-end Rx discard/Tx idle configuration */ #define SET_FE_RX_DISC_TX_IDLE_CFG 0x98 /* read the front-end Rx discard/Tx idle configuration */ #define READ_FE_RX_DISC_TX_IDLE_CFG 0x99 /* set the T1/E1 signaling configuration */ #define SET_TE1_SIGNALING_CFG 0x9A /* read the T1/E1 signaling configuration */ #define READ_TE1_SIGNALING_CFG 0x9B /* the command is invalid for the adapter type */ #define COMMAND_INVALID_FOR_ADAPTER 0x9F /* * Constants for the SET_FE_RX_DISC_TX_IDLE_CFG * and READ_FE_RX_DISC_TX_IDLE_CFG commands */ /* T1 - no active time slots used for reception */ #define NO_ACTIVE_RX_TIME_SLOTS_T1 24 /* T1 - no active time slots used for transmission */ #define NO_ACTIVE_TX_TIME_SLOTS_T1 24 /* E1 - no active time slots used for reception */ #define NO_ACTIVE_RX_TIME_SLOTS_E1 32 /* * E1 - no active time slots used for transmission * (channel 0 reserved for framing) */ #define NO_ACTIVE_TX_TIME_SLOTS_E1 31 /* Read/Write to front-end register */ #define READ_REG(reg) card->read_front_end_reg(card, reg) #define WRITE_REG(reg, value) card->write_front_end_reg(card, reg, \ (unsigned char)(value)) /* * the structure used for the SET_FE_RX_DISC_TX_IDLE_CFG and * READ_FE_RX_DISC_TX_IDLE_CFG command */ #pragma pack(1) typedef struct { /* the length of the Rx discard buffer */ unsigned short lgth_Rx_disc_bfr; /* the length of the Tx idle buffer */ unsigned short lgth_Tx_idle_bfr; /* the transmit idle data buffer */ unsigned char Tx_idle_data_bfr[NO_ACTIVE_TX_TIME_SLOTS_E1]; } FE_RX_DISC_TX_IDLE_STRUCT; #pragma pack() /* * Constants for front-end access */ /* * the structure used for the READ_FRONT_END_REGISTER and * WRITE_FRONT_END_REGISTER command */ #pragma pack(1) typedef struct { /* the register number to be read from or written to */ unsigned short register_number; /* the register value read/written */ unsigned char register_value; } FRONT_END_REG_STRUCT; #pragma pack() /* ----------------------------------------------------------------------------- * Constants for the READ_FRONT_END_STATISTICS command * ---------------------------------------------------------------------------*/ /* the front-end statistics structure */ #pragma pack(1) typedef struct { /* the number of front-end interrupts generated */ unsigned long FE_interrupt_count; /* the number of front-end interrupt application timeouts */ unsigned long FE_app_timeout_count; } FE_STATISTICS_STRUCT; #pragma pack() /* * Constants for the SET_ADAPTER_CONFIGURATION * and READ_ADAPTER_CONFIGURATION commands */ /* the adapter configuration structure */ #pragma pack(1) typedef struct { unsigned short adapter_type; /* type of adapter */ unsigned short adapter_config; /* misc adapter config */ unsigned long operating_frequency; /* adapter operating freq */ } ADAPTER_CONFIGURATION_STRUCT; #pragma pack() typedef unsigned char (WRITE_FRONT_END_REG_T) (void *, unsigned short, unsigned char); typedef unsigned char (READ_FRONT_END_REG_T) (void *, unsigned short); enum { AFT_LED_ON, AFT_LED_OFF, AFT_LED_TOGGLE }; /* * Sangoma Front-End interface structure */ typedef struct { /* In-Service or Not (T1/E1/56K) */ unsigned long (*get_fe_service_status)(void*); /* Print Front-End alarm (T1/E1/56K) */ void (*print_fe_alarm)(void*,unsigned long); /* Print Front-End alarm (T1/E1/56K) */ char* (*print_fe_act_channels)(void*); /* Set Front-End alarm (T1/E1) */ void (*set_fe_alarm)(void*,unsigned long); } sdla_fe_iface_t; #endif /* _KERNEL */ #endif