| /* |
| * PowerMgrDbgPrint.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. |
| */ |
| |
| /** \file PowerMgrDbgPrint.c |
| * \brief Includes primtoputs for debugging the power manager module. |
| * \ |
| * \date 29-Aug-2006 |
| */ |
| |
| #ifndef __POWER_MGR_DBG_PRINT__ |
| #define __POWER_MGR_DBG_PRINT__ |
| |
| #define __FILE_ID__ FILE_ID_72 |
| #include "tidef.h" |
| #include "report.h" |
| #include "osApi.h" |
| #include "PowerMgr.h" |
| |
| #ifdef TI_DBG |
| |
| #define MAX_DESC_LENGTH 32 |
| |
| #ifdef REPORT_LOG |
| void powerMgrPrintPriorities( TI_HANDLE hPowerMgr, powerMngModePriority_t* pPriorities ); |
| |
| static char booleanDesc[ 2 ][ MAX_DESC_LENGTH ] = {"no", "yes"}; |
| static char powerModeDesc[ POWER_MODE_MAX ][ MAX_DESC_LENGTH ] = |
| { "Auto", "Active", "Short doze", "Long doze", "PS only" }; |
| static char powerPolicyDesc[ POWERAUTHO_POLICY_NUM ][ MAX_DESC_LENGTH ] = |
| { "ELP", "PD", "AWAKE" }; |
| static char priorityDesc[ POWER_MANAGER_MAX_PRIORITY ][ MAX_DESC_LENGTH ] = |
| { "User priority", "Soft-Gemini priority" }; |
| static char psStatusDesc[ POWER_SAVE_STATUS_NUMBER ][ MAX_DESC_LENGTH ]= |
| { "Enter fail", "Enter success", "Exit fail", "Exit succes" }; |
| #endif |
| |
| /**************************************************************************************** |
| * PowerMgr_printObject * |
| **************************************************************************************** |
| DESCRIPTION: print configuration of the PowerMgr object - use for debug! |
| |
| INPUT: - hPowerMgr - Handle to the Power Manager |
| OUTPUT: |
| RETURN: void.\n |
| ****************************************************************************************/ |
| void PowerMgr_printObject( TI_HANDLE hPowerMgr ) |
| { |
| #ifdef REPORT_LOG |
| PowerMgr_t *pPowerMgr = (PowerMgr_t*)hPowerMgr; |
| |
| WLAN_OS_REPORT(("------------ Power Manager Object ------------\n\n")); |
| WLAN_OS_REPORT(("PS enabled: %s, desired power mode profile: %s, last power mode profile: %s\n", |
| booleanDesc[ pPowerMgr->psEnable ], powerModeDesc[ pPowerMgr->desiredPowerModeProfile ], |
| powerModeDesc[ pPowerMgr->lastPowerModeProfile ])); |
| WLAN_OS_REPORT(("Default power policy: %ss, PS power policy: %s\n", |
| powerPolicyDesc[ pPowerMgr->defaultPowerLevel ], |
| powerPolicyDesc[ pPowerMgr->PowerSavePowerLevel ])); |
| WLAN_OS_REPORT(("Current priority: %s\n", priorityDesc[ pPowerMgr->powerMngPriority ])); |
| powerMgrPrintPriorities( hPowerMgr, pPowerMgr->powerMngModePriority ); |
| WLAN_OS_REPORT(("\n------------ auto mode parameters ------------\n")); |
| WLAN_OS_REPORT(("Interval: %d, active threshold: %d, doze threshold: %d, doze mode: %s\n\n", |
| pPowerMgr->autoModeInterval, pPowerMgr->autoModeActiveTH, pPowerMgr->autoModeDozeTH, |
| powerModeDesc[ pPowerMgr->autoModeDozeMode ])); |
| WLAN_OS_REPORT(("Beacon listen interval:%d, DTIM listen interval:%d, last PS status: %s\n\n", |
| pPowerMgr->beaconListenInterval, pPowerMgr->dtimListenInterval, |
| psStatusDesc[ pPowerMgr->lastPsTransaction ])); |
| WLAN_OS_REPORT(("------------ Handles ------------\n")); |
| WLAN_OS_REPORT(("%-15s: 0x%x, %-15s:0x%x\n","hOS", pPowerMgr->hOS, "hTWD", pPowerMgr->hTWD)); |
| WLAN_OS_REPORT(("%-15s: 0x%x, %-15s:0x%x\n","hReport", pPowerMgr->hReport, "hTrafficMonitor", pPowerMgr->hTrafficMonitor)); |
| WLAN_OS_REPORT(("%-15s: 0x%x, %-15s:0x%x\n","hSiteMgr", pPowerMgr->hSiteMgr, "hTWD", pPowerMgr->hTWD)); |
| WLAN_OS_REPORT(("%-15s: 0x%x, %-15s:0x%x\n","hRetryPsTimer", pPowerMgr->hRetryPsTimer, "hActiveTMEvent", pPowerMgr->passToActiveTMEvent)); |
| WLAN_OS_REPORT(("%-15s: 0x%x\n", "hDozeTMEvent", pPowerMgr->passToDozeTMEvent)); |
| #endif |
| } |
| |
| #ifdef REPORT_LOG |
| void powerMgrPrintPriorities( TI_HANDLE hPowerMgr, powerMngModePriority_t* pPriorities ) |
| { |
| int i; |
| |
| for ( i = 0; i < POWER_MANAGER_MAX_PRIORITY; i++ ) |
| { |
| WLAN_OS_REPORT(("Priority: %-15s, enabled: %s, power mode: %s\n", |
| priorityDesc[ i ], booleanDesc[ pPriorities[ i ].priorityEnable ], |
| powerModeDesc[ pPriorities[ i ].powerMode ])); |
| } |
| } |
| #endif |
| #endif /* TI_DBG */ |
| |
| #endif /* __POWER_MGR_DBG_PRINT__ */ |