/* * MibDbg.c * * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 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. * * Neither the name Texas Instruments 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 THE COPYRIGHT HOLDERS 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 COPYRIGHT * OWNER 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. */ /***************************************************************************/ /* */ /* MODULE: MibDbg.c */ /* PURPOSE: MIB debug implementation */ /* */ /***************************************************************************/ #include "MibDbg.h" #include "TWDriver.h" #include "report.h" #include "osApi.h" /* *********************************************************************** * Internal functions definitions *********************************************************************** */ static void mibDbgGetArpIpTable(TI_HANDLE hTWD) { TI_STATUS status = TI_OK; TMib mib; TI_INT32 i; /* init */ mib.aMib = MIB_arpIpAddressesTable; mib.aData.ArpIpAddressesTable.FilteringEnable = 0; for ( i = 0 ; i < IP_V4_ADDR_LEN ; i++ ) { mib.aData.ArpIpAddressesTable.addr[i] = 0; } status = TWD_ReadMib(hTWD,NULL,NULL,(void*)&mib); if (status != TI_OK) { WLAN_OS_REPORT(("Get ARP Table failed\n")); return; } /* print ARP Table */ WLAN_OS_REPORT(("ARP IP Table:\n")); WLAN_OS_REPORT(("FilteringEnable: %s (%d)\n", (mib.aData.ArpIpAddressesTable.FilteringEnable)?"Enable":"Disable", mib.aData.ArpIpAddressesTable.FilteringEnable)); WLAN_OS_REPORT(("ArpIpAddress: %d.%d.%d.%d\n", mib.aData.ArpIpAddressesTable.addr[0], mib.aData.ArpIpAddressesTable.addr[1], mib.aData.ArpIpAddressesTable.addr[2], mib.aData.ArpIpAddressesTable.addr[3])); } static void mibDbgGetGroupAddressTable(TI_HANDLE hTWD) { TI_STATUS status = TI_OK; TMib mib; TI_INT32 i,j; /* init */ mib.aMib = MIB_dot11GroupAddressesTable; mib.aData.GroupAddressTable.bFilteringEnable = 0; mib.aData.GroupAddressTable.nNumberOfAddresses = 0; for ( i = 0 ; i < MIB_MAX_MULTICAST_GROUP_ADDRS ; i++ ) { for ( j = 0 ; j < MAC_ADDR_LEN ; j++ ) { mib.aData.GroupAddressTable.aGroupTable[i][j] = 0; } } status = TWD_ReadMib(hTWD,NULL,NULL,(void*)&mib); if (status != TI_OK) { WLAN_OS_REPORT(("Get Group Address Table failed\n")); return; } /* print Group Address Table */ WLAN_OS_REPORT(("Group addresses Table:\n")); WLAN_OS_REPORT(("FilteringEnable: %s (%d)\n", (mib.aData.GroupAddressTable.bFilteringEnable)?"Enable":"Disable", mib.aData.GroupAddressTable.bFilteringEnable)); WLAN_OS_REPORT(("nNumberOfAddresses: %d\n", mib.aData.GroupAddressTable.nNumberOfAddresses)); WLAN_OS_REPORT(("Group addresses: \n")); for ( i = 0 ; i < MIB_MAX_MULTICAST_GROUP_ADDRS ; i++ ) WLAN_OS_REPORT(("%x:%x:%x:%x:%x:%x\n", mib.aData.GroupAddressTable.aGroupTable[i][0], mib.aData.GroupAddressTable.aGroupTable[i][1], mib.aData.GroupAddressTable.aGroupTable[i][2], mib.aData.GroupAddressTable.aGroupTable[i][3], mib.aData.GroupAddressTable.aGroupTable[i][4], mib.aData.GroupAddressTable.aGroupTable[i][5])); } static void mibDbgGetCounterTable(TI_HANDLE hTWD) { TI_STATUS status = TI_OK; TMib mib; /* init */ mib.aMib = MIB_countersTable; mib.aData.CounterTable.FCSErrorCount = 0; mib.aData.CounterTable.PLCPErrorCount = 0; mib.aData.CounterTable.SeqNumMissCount = 0; status = TWD_ReadMib(hTWD,NULL,NULL,(void*)&mib); if (status != TI_OK) { WLAN_OS_REPORT(("Get Counter Table failed\n")); return; } /* print Counter Table */ WLAN_OS_REPORT(("FCS error count= %d \nPLCP error count = %d \nSeq error count= %d\n", mib.aData.CounterTable.FCSErrorCount, mib.aData.CounterTable.PLCPErrorCount, mib.aData.CounterTable.SeqNumMissCount)); } static void mibDbgModifyCtsToSelf(TI_HANDLE hTWD, void* pParam) { TI_STATUS status = TI_OK; TMib mib; if (pParam == NULL) { WLAN_OS_REPORT(("Modify CTS To Self failed: No Parameter received\n")); return; } /* init */ mib.aMib = MIB_ctsToSelf; mib.aData.CTSToSelfEnable = 0; mib.aData.CTSToSelfEnable = *(TI_UINT32*)pParam; status = TWD_WriteMib(hTWD, &mib); if (status != TI_OK) { WLAN_OS_REPORT(("Modify CTS To Self failed\n")); return; } WLAN_OS_REPORT(("Modify CTS To Self OK\n")); WLAN_OS_REPORT(("CtsToSelf = %s (%d)\n", mib.aData.CTSToSelfEnable?"Enable":"Disable", mib.aData.CTSToSelfEnable)); WLAN_OS_REPORT(("CTS to self: [0 - Disable, 1 - Enable]\n")); } static void mibDbgGetCtsToSelf(TI_HANDLE hTWD) { TI_STATUS status = TI_OK; TMib mib; /* init */ mib.aMib = MIB_ctsToSelf; mib.aData.CTSToSelfEnable = 0; status = TWD_ReadMib(hTWD,NULL,NULL,(void*)&mib); if (status != TI_OK) { WLAN_OS_REPORT(("Get CTS To Self failed\n")); return; } WLAN_OS_REPORT(("CtsToSelf = %s (%d)\n", mib.aData.CTSToSelfEnable?"Enable":"Disable", mib.aData.CTSToSelfEnable)); WLAN_OS_REPORT(("CTS to self: [0 - Disable, 1 - Enable]\n")); } static void mibDbgSetMaxRxLifetime(TI_HANDLE hTWD, void* pParam) { TI_STATUS status = TI_OK; TMib mib; if (pParam == NULL) { WLAN_OS_REPORT(("Set Maximum Rx Life Time failed: No Parameter received\n")); return; } /* init */ mib.aMib = MIB_dot11MaxReceiveLifetime; mib.aData.MaxReceiveLifeTime = *(TI_UINT32*)pParam; status = TWD_WriteMib(hTWD, &mib); if (status != TI_OK) { WLAN_OS_REPORT(("Set Maximum Rx Life Time failed\n")); return; } } /* *********************************************************************** * External functions definitions *********************************************************************** */ void mibDbgPrintFunctions(void) { WLAN_OS_REPORT(("\n MIB Dbg Functions \n")); WLAN_OS_REPORT(("--------------------------------------\n")); WLAN_OS_REPORT(("2101 - Print ARP Table\n")); WLAN_OS_REPORT(("2102 - Print Group Address Table\n")); WLAN_OS_REPORT(("2103 - Print Counter Table\n")); WLAN_OS_REPORT(("2104 - Print Modify CTS to Self\n")); WLAN_OS_REPORT(("2105 - Print Max RX Life Time\n")); } void MibDebugFunction(TI_HANDLE hTWD ,TI_UINT32 funcType, void* pParam) { if (hTWD == NULL) { return; } switch (funcType) { case DBG_MIB_PRINT_HELP: mibDbgPrintFunctions(); break; case DBG_MIB_GET_ARP_TABLE: mibDbgGetArpIpTable(hTWD); break; case DBG_MIB_GET_GROUP_ADDRESS_TABLE: mibDbgGetGroupAddressTable(hTWD); break; case DBG_MIB_GET_COUNTER_TABLE: mibDbgGetCounterTable(hTWD); break; case DBG_MIB_MODIFY_CTS_TO_SELF: mibDbgModifyCtsToSelf(hTWD, pParam); break; case DBG_MIB_GET_CTS_TO_SELF: mibDbgGetCtsToSelf(hTWD); break; case DBG_MIB_SET_MAX_RX_LIFE_TIME: mibDbgSetMaxRxLifetime(hTWD, pParam); break; default: WLAN_OS_REPORT(("MIB Debug: Invalid function type in MIB Debug function: %d\n", funcType)); break; } }