aboutsummaryrefslogtreecommitdiffstats
path: root/src/osmo-bts-oc2g/oc2gbts.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/osmo-bts-oc2g/oc2gbts.c')
-rw-r--r--src/osmo-bts-oc2g/oc2gbts.c361
1 files changed, 361 insertions, 0 deletions
diff --git a/src/osmo-bts-oc2g/oc2gbts.c b/src/osmo-bts-oc2g/oc2gbts.c
new file mode 100644
index 00000000..012d705c
--- /dev/null
+++ b/src/osmo-bts-oc2g/oc2gbts.c
@@ -0,0 +1,361 @@
+/* NuRAN Wireless OC-2G L1 API related definitions */
+
+/* Copyright (C) 2015 by Yves Godin <support@nuranwireless.com>
+ * based on:
+ * sysmobts.c
+ * (C) 2011 by Harald Welte <laforge@gnumonks.org>
+ *
+ * All Rights Reserved
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that 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 Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+#include <nrw/oc2g/oc2g.h>
+#include <nrw/oc2g/gsml1const.h>
+#include <nrw/oc2g/gsml1dbg.h>
+
+#include "oc2gbts.h"
+
+enum l1prim_type oc2gbts_get_l1prim_type(GsmL1_PrimId_t id)
+{
+ switch (id) {
+ case GsmL1_PrimId_MphInitReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphCloseReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphConnectReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphDisconnectReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphActivateReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphDeactivateReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphConfigReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphMeasureReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphInitCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphCloseCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphConnectCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphDisconnectCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphActivateCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphDeactivateCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphConfigCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_MphMeasureCnf: return L1P_T_CONF;
+ case GsmL1_PrimId_PhEmptyFrameReq: return L1P_T_REQ;
+ case GsmL1_PrimId_PhDataReq: return L1P_T_REQ;
+ case GsmL1_PrimId_MphTimeInd: return L1P_T_IND;
+ case GsmL1_PrimId_MphSyncInd: return L1P_T_IND;
+ case GsmL1_PrimId_PhConnectInd: return L1P_T_IND;
+ case GsmL1_PrimId_PhReadyToSendInd: return L1P_T_IND;
+ case GsmL1_PrimId_PhDataInd: return L1P_T_IND;
+ case GsmL1_PrimId_PhRaInd: return L1P_T_IND;
+ default: return L1P_T_INVALID;
+ }
+}
+
+const struct value_string oc2gbts_l1prim_names[GsmL1_PrimId_NUM+1] = {
+ { GsmL1_PrimId_MphInitReq, "MPH-INIT.req" },
+ { GsmL1_PrimId_MphCloseReq, "MPH-CLOSE.req" },
+ { GsmL1_PrimId_MphConnectReq, "MPH-CONNECT.req" },
+ { GsmL1_PrimId_MphDisconnectReq,"MPH-DISCONNECT.req" },
+ { GsmL1_PrimId_MphActivateReq, "MPH-ACTIVATE.req" },
+ { GsmL1_PrimId_MphDeactivateReq,"MPH-DEACTIVATE.req" },
+ { GsmL1_PrimId_MphConfigReq, "MPH-CONFIG.req" },
+ { GsmL1_PrimId_MphMeasureReq, "MPH-MEASURE.req" },
+ { GsmL1_PrimId_MphInitCnf, "MPH-INIT.conf" },
+ { GsmL1_PrimId_MphCloseCnf, "MPH-CLOSE.conf" },
+ { GsmL1_PrimId_MphConnectCnf, "MPH-CONNECT.conf" },
+ { GsmL1_PrimId_MphDisconnectCnf,"MPH-DISCONNECT.conf" },
+ { GsmL1_PrimId_MphActivateCnf, "MPH-ACTIVATE.conf" },
+ { GsmL1_PrimId_MphDeactivateCnf,"MPH-DEACTIVATE.conf" },
+ { GsmL1_PrimId_MphConfigCnf, "MPH-CONFIG.conf" },
+ { GsmL1_PrimId_MphMeasureCnf, "MPH-MEASURE.conf" },
+ { GsmL1_PrimId_MphTimeInd, "MPH-TIME.ind" },
+ { GsmL1_PrimId_MphSyncInd, "MPH-SYNC.ind" },
+ { GsmL1_PrimId_PhEmptyFrameReq, "PH-EMPTY_FRAME.req" },
+ { GsmL1_PrimId_PhDataReq, "PH-DATA.req" },
+ { GsmL1_PrimId_PhConnectInd, "PH-CONNECT.ind" },
+ { GsmL1_PrimId_PhReadyToSendInd,"PH-READY_TO_SEND.ind" },
+ { GsmL1_PrimId_PhDataInd, "PH-DATA.ind" },
+ { GsmL1_PrimId_PhRaInd, "PH-RA.ind" },
+ { 0, NULL }
+};
+
+GsmL1_PrimId_t oc2gbts_get_l1prim_conf(GsmL1_PrimId_t id)
+{
+ switch (id) {
+ case GsmL1_PrimId_MphInitReq: return GsmL1_PrimId_MphInitCnf;
+ case GsmL1_PrimId_MphCloseReq: return GsmL1_PrimId_MphCloseCnf;
+ case GsmL1_PrimId_MphConnectReq: return GsmL1_PrimId_MphConnectCnf;
+ case GsmL1_PrimId_MphDisconnectReq: return GsmL1_PrimId_MphDisconnectCnf;
+ case GsmL1_PrimId_MphActivateReq: return GsmL1_PrimId_MphActivateCnf;
+ case GsmL1_PrimId_MphDeactivateReq: return GsmL1_PrimId_MphDeactivateCnf;
+ case GsmL1_PrimId_MphConfigReq: return GsmL1_PrimId_MphConfigCnf;
+ case GsmL1_PrimId_MphMeasureReq: return GsmL1_PrimId_MphMeasureCnf;
+ default: return -1; // Weak
+ }
+}
+
+enum l1prim_type oc2gbts_get_sysprim_type(Oc2g_PrimId_t id)
+{
+ switch (id) {
+ case Oc2g_PrimId_SystemInfoReq: return L1P_T_REQ;
+ case Oc2g_PrimId_SystemInfoCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SystemFailureInd: return L1P_T_IND;
+ case Oc2g_PrimId_ActivateRfReq: return L1P_T_REQ;
+ case Oc2g_PrimId_ActivateRfCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_DeactivateRfReq: return L1P_T_REQ;
+ case Oc2g_PrimId_DeactivateRfCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SetTraceFlagsReq: return L1P_T_REQ;
+ case Oc2g_PrimId_Layer1ResetReq: return L1P_T_REQ;
+ case Oc2g_PrimId_Layer1ResetCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SetCalibTblReq: return L1P_T_REQ;
+ case Oc2g_PrimId_SetCalibTblCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_MuteRfReq: return L1P_T_REQ;
+ case Oc2g_PrimId_MuteRfCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SetRxAttenReq: return L1P_T_REQ;
+ case Oc2g_PrimId_SetRxAttenCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_IsAliveReq: return L1P_T_REQ;
+ case Oc2g_PrimId_IsAliveCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SetMaxCellSizeReq: return L1P_T_REQ;
+ case Oc2g_PrimId_SetMaxCellSizeCnf: return L1P_T_CONF;
+ case Oc2g_PrimId_SetC0IdleSlotPowerReductionReq: return L1P_T_REQ;
+ case Oc2g_PrimId_SetC0IdleSlotPowerReductionCnf: return L1P_T_CONF;
+ default: return L1P_T_INVALID;
+ }
+}
+
+const struct value_string oc2gbts_sysprim_names[Oc2g_PrimId_NUM+1] = {
+ { Oc2g_PrimId_SystemInfoReq, "SYSTEM-INFO.req" },
+ { Oc2g_PrimId_SystemInfoCnf, "SYSTEM-INFO.conf" },
+ { Oc2g_PrimId_SystemFailureInd, "SYSTEM-FAILURE.ind" },
+ { Oc2g_PrimId_ActivateRfReq, "ACTIVATE-RF.req" },
+ { Oc2g_PrimId_ActivateRfCnf, "ACTIVATE-RF.conf" },
+ { Oc2g_PrimId_DeactivateRfReq, "DEACTIVATE-RF.req" },
+ { Oc2g_PrimId_DeactivateRfCnf, "DEACTIVATE-RF.conf" },
+ { Oc2g_PrimId_SetTraceFlagsReq, "SET-TRACE-FLAGS.req" },
+ { Oc2g_PrimId_Layer1ResetReq, "LAYER1-RESET.req" },
+ { Oc2g_PrimId_Layer1ResetCnf, "LAYER1-RESET.conf" },
+ { Oc2g_PrimId_SetCalibTblReq, "SET-CALIB.req" },
+ { Oc2g_PrimId_SetCalibTblCnf, "SET-CALIB.cnf" },
+ { Oc2g_PrimId_MuteRfReq, "MUTE-RF.req" },
+ { Oc2g_PrimId_MuteRfCnf, "MUTE-RF.cnf" },
+ { Oc2g_PrimId_SetRxAttenReq, "SET-RX-ATTEN.req" },
+ { Oc2g_PrimId_SetRxAttenCnf, "SET-RX-ATTEN-CNF.cnf" },
+ { Oc2g_PrimId_IsAliveReq, "IS-ALIVE.req" },
+ { Oc2g_PrimId_IsAliveCnf, "IS-ALIVE-CNF.cnf" },
+ { Oc2g_PrimId_SetMaxCellSizeReq, "SET-MAX-CELL-SIZE.req" },
+ { Oc2g_PrimId_SetMaxCellSizeCnf, "SET-MAX-CELL-SIZE.cnf" },
+ { Oc2g_PrimId_SetC0IdleSlotPowerReductionReq, "SET-C0-IDLE-PWR-RED.req" },
+ { Oc2g_PrimId_SetC0IdleSlotPowerReductionCnf, "SET-C0-IDLE-PWR-RED.cnf" },
+ { 0, NULL }
+};
+
+Oc2g_PrimId_t oc2gbts_get_sysprim_conf(Oc2g_PrimId_t id)
+{
+ switch (id) {
+ case Oc2g_PrimId_SystemInfoReq: return Oc2g_PrimId_SystemInfoCnf;
+ case Oc2g_PrimId_ActivateRfReq: return Oc2g_PrimId_ActivateRfCnf;
+ case Oc2g_PrimId_DeactivateRfReq: return Oc2g_PrimId_DeactivateRfCnf;
+ case Oc2g_PrimId_Layer1ResetReq: return Oc2g_PrimId_Layer1ResetCnf;
+ case Oc2g_PrimId_SetCalibTblReq: return Oc2g_PrimId_SetCalibTblCnf;
+ case Oc2g_PrimId_MuteRfReq: return Oc2g_PrimId_MuteRfCnf;
+ case Oc2g_PrimId_SetRxAttenReq: return Oc2g_PrimId_SetRxAttenCnf;
+ case Oc2g_PrimId_IsAliveReq: return Oc2g_PrimId_IsAliveCnf;
+ case Oc2g_PrimId_SetMaxCellSizeReq: return Oc2g_PrimId_SetMaxCellSizeCnf;
+ case Oc2g_PrimId_SetC0IdleSlotPowerReductionReq: return Oc2g_PrimId_SetC0IdleSlotPowerReductionCnf;
+ default: return -1; // Weak
+ }
+}
+
+const struct value_string oc2gbts_l1sapi_names[GsmL1_Sapi_NUM+1] = {
+ { GsmL1_Sapi_Idle, "IDLE" },
+ { GsmL1_Sapi_Fcch, "FCCH" },
+ { GsmL1_Sapi_Sch, "SCH" },
+ { GsmL1_Sapi_Sacch, "SACCH" },
+ { GsmL1_Sapi_Sdcch, "SDCCH" },
+ { GsmL1_Sapi_Bcch, "BCCH" },
+ { GsmL1_Sapi_Pch, "PCH" },
+ { GsmL1_Sapi_Agch, "AGCH" },
+ { GsmL1_Sapi_Cbch, "CBCH" },
+ { GsmL1_Sapi_Rach, "RACH" },
+ { GsmL1_Sapi_TchF, "TCH/F" },
+ { GsmL1_Sapi_FacchF, "FACCH/F" },
+ { GsmL1_Sapi_TchH, "TCH/H" },
+ { GsmL1_Sapi_FacchH, "FACCH/H" },
+ { GsmL1_Sapi_Nch, "NCH" },
+ { GsmL1_Sapi_Pdtch, "PDTCH" },
+ { GsmL1_Sapi_Pacch, "PACCH" },
+ { GsmL1_Sapi_Pbcch, "PBCCH" },
+ { GsmL1_Sapi_Pagch, "PAGCH" },
+ { GsmL1_Sapi_Ppch, "PPCH" },
+ { GsmL1_Sapi_Pnch, "PNCH" },
+ { GsmL1_Sapi_Ptcch, "PTCCH" },
+ { GsmL1_Sapi_Prach, "PRACH" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_l1status_names[GSML1_STATUS_NUM+1] = {
+ { GsmL1_Status_Success, "Success" },
+ { GsmL1_Status_Generic, "Generic error" },
+ { GsmL1_Status_NoMemory, "Not enough memory" },
+ { GsmL1_Status_Timeout, "Timeout" },
+ { GsmL1_Status_InvalidParam, "Invalid parameter" },
+ { GsmL1_Status_Busy, "Resource busy" },
+ { GsmL1_Status_NoRessource, "No more resources" },
+ { GsmL1_Status_Uninitialized, "Trying to use uninitialized resource" },
+ { GsmL1_Status_NullInterface, "Trying to call a NULL interface" },
+ { GsmL1_Status_NullFctnPtr, "Trying to call a NULL function ptr" },
+ { GsmL1_Status_BadCrc, "Bad CRC" },
+ { GsmL1_Status_BadUsf, "Bad USF" },
+ { GsmL1_Status_InvalidCPS, "Invalid CPS field" },
+ { GsmL1_Status_UnexpectedBurst, "Unexpected burst" },
+ { GsmL1_Status_UnavailCodec, "AMR codec is unavailable" },
+ { GsmL1_Status_CriticalError, "Critical error" },
+ { GsmL1_Status_OverheatError, "Overheat error" },
+ { GsmL1_Status_DeviceError, "Device error" },
+ { GsmL1_Status_FacchError, "FACCH / TCH order error" },
+ { GsmL1_Status_AlreadyDeactivated, "Lchan already deactivated" },
+ { GsmL1_Status_TxBurstFifoOvrn, "FIFO overrun" },
+ { GsmL1_Status_TxBurstFifoUndr, "FIFO underrun" },
+ { GsmL1_Status_NotSynchronized, "Not synchronized" },
+ { GsmL1_Status_Unsupported, "Unsupported feature" },
+ { GsmL1_Status_ClockError, "System clock error" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_tracef_names[29] = {
+ { DBG_DEBUG, "DEBUG" },
+ { DBG_L1WARNING, "L1_WARNING" },
+ { DBG_ERROR, "ERROR" },
+ { DBG_L1RXMSG, "L1_RX_MSG" },
+ { DBG_L1RXMSGBYTE, "L1_RX_MSG_BYTE" },
+ { DBG_L1TXMSG, "L1_TX_MSG" },
+ { DBG_L1TXMSGBYTE, "L1_TX_MSG_BYTE" },
+ { DBG_MPHCNF, "MPH_CNF" },
+ { DBG_MPHIND, "MPH_IND" },
+ { DBG_MPHREQ, "MPH_REQ" },
+ { DBG_PHIND, "PH_IND" },
+ { DBG_PHREQ, "PH_REQ" },
+ { DBG_PHYRF, "PHY_RF" },
+ { DBG_PHYRFMSGBYTE, "PHY_MSG_BYTE" },
+ { DBG_MODE, "MODE" },
+ { DBG_TDMAINFO, "TDMA_INFO" },
+ { DBG_BADCRC, "BAD_CRC" },
+ { DBG_PHINDBYTE, "PH_IND_BYTE" },
+ { DBG_PHREQBYTE, "PH_REQ_BYTE" },
+ { DBG_DEVICEMSG, "DEVICE_MSG" },
+ { DBG_RACHINFO, "RACH_INFO" },
+ { DBG_LOGCHINFO, "LOG_CH_INFO" },
+ { DBG_MEMORY, "MEMORY" },
+ { DBG_PROFILING, "PROFILING" },
+ { DBG_TESTCOMMENT, "TEST_COMMENT" },
+ { DBG_TEST, "TEST" },
+ { DBG_STATUS, "STATUS" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_tracef_docs[29] = {
+ { DBG_DEBUG, "Debug Region" },
+ { DBG_L1WARNING, "L1 Warning Region" },
+ { DBG_ERROR, "Error Region" },
+ { DBG_L1RXMSG, "L1_RX_MSG Region" },
+ { DBG_L1RXMSGBYTE, "L1_RX_MSG_BYTE Region" },
+ { DBG_L1TXMSG, "L1_TX_MSG Region" },
+ { DBG_L1TXMSGBYTE, "L1_TX_MSG_BYTE Region" },
+ { DBG_MPHCNF, "MphConfirmation Region" },
+ { DBG_MPHIND, "MphIndication Region" },
+ { DBG_MPHREQ, "MphRequest Region" },
+ { DBG_PHIND, "PhIndication Region" },
+ { DBG_PHREQ, "PhRequest Region" },
+ { DBG_PHYRF, "PhyRF Region" },
+ { DBG_PHYRFMSGBYTE, "PhyRF Message Region" },
+ { DBG_MODE, "Mode Region" },
+ { DBG_TDMAINFO, "TDMA Info Region" },
+ { DBG_BADCRC, "Bad CRC Region" },
+ { DBG_PHINDBYTE, "PH_IND_BYTE" },
+ { DBG_PHREQBYTE, "PH_REQ_BYTE" },
+ { DBG_DEVICEMSG, "Device Message Region" },
+ { DBG_RACHINFO, "RACH Info" },
+ { DBG_LOGCHINFO, "LOG_CH_INFO" },
+ { DBG_MEMORY, "Memory Region" },
+ { DBG_PROFILING, "Profiling Region" },
+ { DBG_TESTCOMMENT, "Test Comments" },
+ { DBG_TEST, "Test Region" },
+ { DBG_STATUS, "Status Region" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_tch_pl_names[] = {
+ { GsmL1_TchPlType_NA, "N/A" },
+ { GsmL1_TchPlType_Fr, "FR" },
+ { GsmL1_TchPlType_Hr, "HR" },
+ { GsmL1_TchPlType_Efr, "EFR" },
+ { GsmL1_TchPlType_Amr, "AMR(IF2)" },
+ { GsmL1_TchPlType_Amr_SidBad, "AMR(SID BAD)" },
+ { GsmL1_TchPlType_Amr_Onset, "AMR(ONSET)" },
+ { GsmL1_TchPlType_Amr_Ratscch, "AMR(RATSCCH)" },
+ { GsmL1_TchPlType_Amr_SidUpdateInH, "AMR(SID_UPDATE INH)" },
+ { GsmL1_TchPlType_Amr_SidFirstP1, "AMR(SID_FIRST P1)" },
+ { GsmL1_TchPlType_Amr_SidFirstP2, "AMR(SID_FIRST P2)" },
+ { GsmL1_TchPlType_Amr_SidFirstInH, "AMR(SID_FIRST INH)" },
+ { GsmL1_TchPlType_Amr_RatscchMarker, "AMR(RATSCCH MARK)" },
+ { GsmL1_TchPlType_Amr_RatscchData, "AMR(RATSCCH DATA)" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_dir_names[] = {
+ { GsmL1_Dir_TxDownlink, "TxDL" },
+ { GsmL1_Dir_TxUplink, "TxUL" },
+ { GsmL1_Dir_RxUplink, "RxUL" },
+ { GsmL1_Dir_RxDownlink, "RxDL" },
+ { GsmL1_Dir_TxDownlink|GsmL1_Dir_RxUplink, "BOTH" },
+ { 0, NULL }
+};
+
+const struct value_string oc2gbts_chcomb_names[] = {
+ { GsmL1_LogChComb_0, "dummy" },
+ { GsmL1_LogChComb_I, "tch_f" },
+ { GsmL1_LogChComb_II, "tch_h" },
+ { GsmL1_LogChComb_IV, "ccch" },
+ { GsmL1_LogChComb_V, "ccch_sdcch4" },
+ { GsmL1_LogChComb_VII, "sdcch8" },
+ { GsmL1_LogChComb_XIII, "pdtch" },
+ { 0, NULL }
+};
+
+const uint8_t pdch_msu_size[_NUM_PDCH_CS] = {
+ [PDCH_CS_1] = 23,
+ [PDCH_CS_2] = 34,
+ [PDCH_CS_3] = 40,
+ [PDCH_CS_4] = 54,
+ [PDCH_MCS_1] = 27,
+ [PDCH_MCS_2] = 33,
+ [PDCH_MCS_3] = 42,
+ [PDCH_MCS_4] = 49,
+ [PDCH_MCS_5] = 60,
+ [PDCH_MCS_6] = 78,
+ [PDCH_MCS_7] = 118,
+ [PDCH_MCS_8] = 142,
+ [PDCH_MCS_9] = 154
+};
+
+const struct value_string oc2gbts_rsl_ho_causes[] = {
+ { IPAC_HO_RQD_CAUSE_L_RXLEV_UL_H, "L_RXLEV_UL_H" },
+ { IPAC_HO_RQD_CAUSE_L_RXLEV_DL_H, "L_RXLEV_DL_H" },
+ { IPAC_HO_RQD_CAUSE_L_RXQUAL_UL_H, "L_RXQUAL_UL_H" },
+ { IPAC_HO_RQD_CAUSE_L_RXQUAL_DL_H, "L_RXQUAL_DL_H" },
+ { IPAC_HO_RQD_CAUSE_RXLEV_UL_IH, "RXLEV_UL_IH" },
+ { IPAC_HO_RQD_CAUSE_RXLEV_DL_IH, "RXLEV_DL_IH" },
+ { IPAC_HO_RQD_CAUSE_MAX_MS_RANGE, "MAX_MS_RANGE" },
+ { IPAC_HO_RQD_CAUSE_POWER_BUDGET, "POWER_BUDGET" },
+ { IPAC_HO_RQD_CAUSE_ENQUIRY, "ENQUIRY" },
+ { IPAC_HO_RQD_CAUSE_ENQUIRY_FAILED, "ENQUIRY_FAILED" },
+ { 0, NULL }
+};