亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mplpwr.c

?? NATIONAL公司DP83816芯片Linux下驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:

//******************************************************************************
//
//  MPLPWR.C
//
//  Copyright (c) 2004 National Semiconductor Corporation.
//  All Rights Reserved
//
//  MPL Power Management Module.
//
//  This file contains the API implementations for
//     o Configuring the power state on the device
//     o WoL related configuration and status reporting
//
//******************************************************************************
#include <mplinternal.h>

// Local helful debug macros
#undef ENTER
#undef EXIT
#undef ASSERT
#undef PRINT
#undef PRINTI
#undef PRINTS
#undef TBREAK

#define ENTER(fn) MPL_CENTER(DZONE_MPL_PWR, fn)
#define EXIT(fn) MPL_CEXIT(DZONE_MPL_PWR, fn)
#define ASSERT(le) MPL_CASSERT(DZONE_MPL_PWR, le)
#define PRINT(fmt) MPL_CTRACE(DZONE_MPL_PWR, fmt)
#define PRINTI(v) MPL_CTRACE(DZONE_MPL_PWR, (" "#v": %x \n",(NS_UINT)(v)))
#define PRINTS(v) MPL_CTRACE(DZONE_MPL_PWR, (" "#v": %s \n", v))
#define TBREAK(fmt) MPL_CTRACEBREAK(DZONE_MPL_PWR, fmt)

// Locals
static NS_VOID cfgWakeEvts (MPL_CONTEXT  *pMplCtx);
static NS_VOID cfgWakePatterns(MPL_CONTEXT  *pMplCtx);
#ifdef LINUX_POWER_DEBUG
static NS_VOID printWakeReason(MPL_CONTEXT  *pMplCtx);
#endif

//*****************************************************************************
//   MplPowerSetState
//      Set a new power state on the device
//
//   Parameters
//      pMplHandle
//         MPL device handle returned following a call to MplInitialize
//      newState
//         New power state that needs to be set on the device
//      pmeEnable
//         When set to NS_TRUE, MPL enables PME on the device
//         Some OSs do this automatically, some do not
//
//   Return Value
//      NS_STATUS_SUCCESS
//         The new state was successfully set
//      NS_STATUS_FAILURE
//         The device could not be set to the new state
//
//*****************************************************************************
MPL_STATUS
   MplPowerSetState(
      IN NS_VOID         *pMplHandle,
      IN MPL_POWER_STATE  newState,
      IN NS_BOOLEAN       pmeEnable
      )
{
   MPL_CONTEXT *pMplCtx = (MPL_CONTEXT *)pMplHandle;
   MPL_STATUS status = NS_STATUS_SUCCESS;

   ENTER(MplPowerSetState);

   if ((pMplCtx->pwrState == MPL_POWER_STATE_HIGH) && 
          (newState == MPL_POWER_STATE_LOW))
   {
      // Entering Low Power state from a High Power state
      //  This function expects Int to be disabled and Rx Reset Complete
      //  before calling it
      
      // Take a register snap-shot
      setSoftRegs(pMplHandle, MPL_REGS_CURRENT);

      // Configure Wake events
      cfgWakeEvts(pMplCtx);
      
      // Configure Wake Patterns if any
      cfgWakePatterns(pMplCtx);
      
      // Put the receiver in "Silent Receive" mode
      MPL_WRITE32(pMplCtx, CR, RX_DIS);
      MPL_WRITE32(pMplCtx, RXDP, 0x0);
      MPL_WRITE32(pMplCtx, CR, RX_EN);
      
      // Enable PME if NSM wants us to - This depends on the OS, some do
      // it themselves, for the rest we do it
      if (pmeEnable == NS_TRUE)
      {
         // Using the PME backdoor
         if (MPL_READ32(pMplCtx, WCSR) & WAKEON_MASK)
         {
            // WOL event is enabled - So set PMEEN
            MPL_WRITE32(pMplCtx, CCSR, pMplCtx->ccsrReg | PMEEN | PMESTS);
         }
	 else
         {
            // Write whatever was there by default 
	    //  Note PMEEN bit is loaded from EEPROM
            MPL_WRITE32(pMplCtx, CCSR, pMplCtx->ccsrReg);
         }
      }

      // Set the new state - LOW
      pMplCtx->pwrState = MPL_POWER_STATE_LOW;
   }
   else if ((pMplCtx->pwrState == MPL_POWER_STATE_LOW) && 
               (newState == MPL_POWER_STATE_HIGH))
        {
           // Entering High Power state from a Low Power state
#ifdef LINUX_POWER_DEBUG
           printWakeReason(pMplCtx);
#endif 

           // If PME was enabled then clear status
           if (pmeEnable == NS_TRUE)
           {
              // Clear any wake events configured on the device
              MPL_WRITE32(pMplCtx, CCSR, PMESTS);
           }

           // Not doing MAC/PHY Resets

           // Set registers with last known snap-shot
           setHardRegs(pMplCtx);

           // Set the MAC address - to last know value
           MplSetMacAddress(pMplCtx, pMplCtx->permMacAddr);
      
#ifdef MPL_TASK_RECEIVE_FILTER
           // Reload Receive hash filter (Multicast and Unicast)
           MplTaskFilterReload(pMplCtx);
#endif // MPL_TASK_RECEIVE_FILTER

           // Notify the device about the head node on the Rxd ring
           // Not enabling RX yet, the replenish API will take care of it
           MPL_WRITE32(pMplCtx, RXDP,  pMplCtx->rxQueue.ringPA);

           // Notify the device about the head node on the Txd ring
           MPL_WRITE32(pMplCtx, TXDP,  pMplCtx->txQueue[0].ringPA);
           MPL_WRITE32(pMplCtx, TXDP1, pMplCtx->txQueue[1].ringPA);
           MPL_WRITE32(pMplCtx, TXDP2, pMplCtx->txQueue[2].ringPA);
           MPL_WRITE32(pMplCtx, TXDP3, pMplCtx->txQueue[3].ringPA);

           // Set the new state - HIGH
           pMplCtx->pwrState = MPL_POWER_STATE_HIGH;
        }

   EXIT(MplPowerSetState);
   return status;
}

//*****************************************************************************
//   MplWolCfg
//     Configure the WOL operation on the device
//
//   Parameters
//      pMplHandle
//         MPL device handle returned following a call to MplInitialize
//      wakeEnable
//         Flag to enable (set to NS_TRUE) or disable (set to NS_FALSE) Wol
//      wakeType
//         When WOL is enabled, represents a bit-map of wake-up events that
//         needs to be enabled. It is a logical OR of,
//          MPL_WOL_MAGIC - Enable wake on Magic Pattern.
//          MPL_WOL_PATTERN - Enable wake on pattern match (Patterns needs
//                            to be separately defined).
//          MPL_WOL_BROADCAST - Enable wake on any broadcast packet.
//          MPL_WOL_MULTICAST - Enable wake on multicast packet.
//          MPL_WOL_DIRECTED - Enable wake on directed (unicast) packet to 
//                             the device's address.
//          MPL_WOL_LINK - Enable wake on link status change.
//          MPL_WOL_ARP - Enable wake on any ARP packet.
//
//   Return Value
//      NS_STATUS_SUCCESS
//         The WOL events were successfully enabled or disabled (depending
//         on wakeEnable).
//      NS_STATUS_INVALID_PARM
//         The wake event type is not supported on the device.
//
//*****************************************************************************
MPL_STATUS
   MplWolCfg(
      IN NS_VOID     *pMplHandle,
      IN NS_BOOLEAN   wakeEnable,
      IN NS_UINT      wakeType
      )
{
   MPL_CONTEXT *pMplCtx = (MPL_CONTEXT *)pMplHandle;
   MPL_STATUS status = NS_STATUS_SUCCESS;

   ENTER(MplWolCfg);

   pMplCtx->pwrWakeType = 0x0;
   if (wakeEnable == NS_TRUE)
   {
      // Enable WOL - Make sure wake evt is one that we support
      if (wakeType & ~(MPL_WOL_MAGIC     |
                       MPL_WOL_PATTERNS  |
                       MPL_WOL_BROADCAST | 
                       MPL_WOL_MULTICAST | 
                       MPL_WOL_DIRECTED  | 
                       MPL_WOL_LINK      | 
                       MPL_WOL_ARP))
      {
         status = NS_STATUS_INVALID_PARM;
      }
      else
      {
         pMplCtx->pwrWakeType = wakeType;
      }
   }

   EXIT(MplWolCfg);
   return status;
}

//*****************************************************************************
//   MplWolGetCfg
//     Retrieve the current WOL configuration on the device
//
//   Parameters
//      pMplHandle
//         MPL device handle returned following a call to MplInitialize
//      pWakeType
//         Pointer to caller provider variable in which the bit-map of wake-up
//         events currently enabled is returned. It is a logical OR of,
//          MPL_WOL_MAGIC - Enable wake on Magic Pattern.
//          MPL_WOL_PATTERN - Enable wake on pattern match (Patterns needs to
//                            be separately defined).
//          MPL_WOL_BROADCAST - Enable wake on any broadcast packet.
//          MPL_WOL_MULTICAST - Enable wake on multicast packet.
//          MPL_WOL_DIRECTED - Enable wake on directed (unicast) packet to
//                             the device's address.
//          MPL_WOL_LINK - Enable wake on link status change.
//          MPL_WOL_ARP - Enable wake on any ARP packet.
//
//   Return Value
//      NS_STATUS_SUCCESS
//         The WOL configuration was returned successfully
//
//*****************************************************************************
MPL_STATUS
   MplWolGetCfg(
      IN NS_VOID   *pMplHandle,
      IN NS_UINT   *pWakeType
      )
{
   MPL_CONTEXT *pMplCtx = (MPL_CONTEXT *)pMplHandle;

   ENTER(MplWolGetCfg);

   *pWakeType = pMplCtx->pwrWakeType;

   EXIT(MplWolGetCfg);
   return NS_STATUS_SUCCESS;
}

//*****************************************************************************
//   MplWolClearPattern
//     Clear all WOL wake patterns on the device
//
//   Parameters

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久一区二区三区| 亚洲国产高清在线观看视频| 欧美mv日韩mv国产| 亚洲同性gay激情无套| 日韩成人午夜精品| 大胆亚洲人体视频| 欧美疯狂性受xxxxx喷水图片| 久久久精品天堂| 97久久精品人人做人人爽| 精品久久久久久久人人人人传媒| 国产电影一区在线| 日本午夜精品视频在线观看 | 制服丝袜亚洲播放| 国产精品无圣光一区二区| 日日骚欧美日韩| 色8久久人人97超碰香蕉987| 久久久久久亚洲综合| 青娱乐精品在线视频| 欧美影院精品一区| 亚洲欧美日韩在线播放| 成人免费视频一区二区| 久久综合成人精品亚洲另类欧美 | 激情小说欧美图片| 一区二区三区免费在线观看| 亚洲宅男天堂在线观看无病毒| 久久综合久久综合九色| 日韩精品欧美精品| 欧美日本不卡视频| 亚洲午夜在线视频| 欧美亚洲丝袜传媒另类| 亚洲精品成人少妇| 91天堂素人约啪| 亚洲三级电影全部在线观看高清| 国产成人三级在线观看| 国产日韩影视精品| 久久国产精品第一页| 欧美成人a∨高清免费观看| 麻豆一区二区三| 7878成人国产在线观看| 日韩成人免费在线| 欧美va亚洲va香蕉在线| 精品在线观看免费| 亚洲精品一区二区三区香蕉| 久久精品国产免费看久久精品| 日韩午夜激情电影| 九色|91porny| 国产欧美综合在线观看第十页| 成人在线综合网站| 亚洲欧美另类小说| 欧美日产国产精品| 精品一区二区免费看| 国产蜜臀97一区二区三区| eeuss鲁一区二区三区| 亚洲免费三区一区二区| 欧美日韩三级视频| 久久er99精品| 中文字幕亚洲一区二区av在线| 91久久线看在观草草青青| 日韩精品91亚洲二区在线观看 | 亚洲地区一二三色| 日韩午夜激情视频| 成+人+亚洲+综合天堂| 亚洲综合偷拍欧美一区色| 欧美日韩在线播| 久久不见久久见免费视频1| 亚洲欧洲99久久| 69堂亚洲精品首页| 丁香一区二区三区| 午夜伦理一区二区| 日本一二三不卡| 911国产精品| 成人精品国产免费网站| 日韩精品视频网| 国产精品每日更新| 欧美视频日韩视频| 欧美三级视频在线播放| 欧美高清精品3d| 久久综合久久综合久久综合| 懂色av一区二区夜夜嗨| 亚洲成在线观看| 国产日韩欧美综合在线| 一本到一区二区三区| 精品影院一区二区久久久| 日韩毛片在线免费观看| 精品对白一区国产伦| 日本道免费精品一区二区三区| 国产在线精品一区二区 | 欧美一区二区三区啪啪| av电影在线观看不卡| 免费成人在线影院| 亚洲一区二区三区四区不卡| 精品国产免费一区二区三区香蕉| 91精品办公室少妇高潮对白| 国产成人免费视频网站| 日韩黄色免费网站| 亚洲一区在线观看免费| 亚洲va欧美va人人爽| 奇米在线7777在线精品| 中文字幕免费一区| 亚洲精品一区二区三区99| 欧美欧美欧美欧美| 91麻豆文化传媒在线观看| 国产成人精品网址| 国产在线一区二区综合免费视频| 亚洲国产美女搞黄色| 亚洲欧洲99久久| 欧美极品aⅴ影院| 欧美变态tickling挠脚心| 欧美日韩国产一级片| 色天天综合久久久久综合片| 成人激情综合网站| 粉嫩欧美一区二区三区高清影视 | 欧美精品三级日韩久久| 色婷婷av一区二区| 在线观看日韩国产| 欧美亚洲日本一区| 在线免费观看日本一区| 在线视频中文字幕一区二区| caoporen国产精品视频| 97久久精品人人爽人人爽蜜臀| 国产一区二区三区黄视频 | 337p日本欧洲亚洲大胆色噜噜| 欧美日韩一本到| 欧美裸体bbwbbwbbw| 欧美亚洲一区二区在线| 91精品国产综合久久福利| 欧洲一区二区三区在线| 欧美性极品少妇| 69精品人人人人| 精品蜜桃在线看| 国产欧美一区二区精品性色| 亚洲国产精品激情在线观看| 亚洲欧美国产毛片在线| 亚洲欧美激情视频在线观看一区二区三区| 亚洲视频一区二区在线观看| 一区二区三区自拍| 日本不卡一区二区三区| 久久精品国产色蜜蜜麻豆| 国产suv一区二区三区88区| 国产91清纯白嫩初高中在线观看| 成人精品视频一区二区三区尤物| 99国产精品一区| 91精品一区二区三区久久久久久 | 日韩一区二区在线看片| 欧美一区二区国产| 久久综合999| 亚洲女子a中天字幕| 亚洲成人黄色小说| 国产精品一区专区| 色视频一区二区| 精品国产免费视频| 亚洲天堂网中文字| 蜜桃久久精品一区二区| 国产成人免费视频精品含羞草妖精| 成人av网址在线| 欧美精品第1页| 久久一日本道色综合| 亚洲男人的天堂av| 韩国欧美一区二区| 精品视频一区三区九区| 久久一夜天堂av一区二区三区| 亚洲黄色在线视频| 国产综合久久久久久久久久久久| 99国产精品一区| 精品国产一区二区在线观看| 亚洲精品日日夜夜| 国产成人免费视频网站高清观看视频| 日本一区二区三区电影| 久久久777精品电影网影网| 亚洲综合免费观看高清在线观看| 另类欧美日韩国产在线| 99久久国产免费看| 久久综合成人精品亚洲另类欧美| 亚洲综合丁香婷婷六月香| 国产成人av一区二区三区在线 | 中文字幕永久在线不卡| 丝袜国产日韩另类美女| aaa国产一区| 国产午夜亚洲精品理论片色戒 | 亚洲一区二区中文在线| 国产成人av一区| wwww国产精品欧美| 日产国产欧美视频一区精品 | 玉米视频成人免费看| 国产精品影视天天线| 在线综合视频播放| 亚洲香肠在线观看| 在线免费观看日本欧美| 国产精品的网站| 成人综合在线观看| 国产三级欧美三级日产三级99 | 色999日韩国产欧美一区二区| 久久久精品免费网站| 精品在线一区二区三区| 日韩欧美成人一区二区| 日本三级韩国三级欧美三级| 欧美伊人久久久久久久久影院| 亚洲三级在线免费观看| 91丨porny丨在线| 亚洲色欲色欲www|