亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧美一区二区在线免费播放| 中文字幕综合网| 中文字幕一区二区三区av| 污片在线观看一区二区| 波多野结衣中文字幕一区| 欧美成人乱码一区二区三区| 亚洲精品免费在线| 丰满亚洲少妇av| 精品少妇一区二区三区视频免付费| 国产精品美女久久久久久久网站| 蜜桃视频一区二区| 欧美日韩激情一区| 亚洲精品日日夜夜| 成人av在线资源网| 久久这里只有精品首页| 免费观看一级欧美片| 欧美色大人视频| 亚洲黄色av一区| 99久久婷婷国产综合精品电影 | 久久精品国产一区二区| 欧美在线观看视频在线| 中文字幕视频一区| 成人午夜精品一区二区三区| 久久色成人在线| 韩国av一区二区三区四区| 欧美一区二区三级| 日韩avvvv在线播放| 欧美亚洲国产bt| 亚洲国产视频一区二区| 欧美日韩在线综合| 亚洲国产wwwccc36天堂| 欧美无砖砖区免费| 午夜在线电影亚洲一区| 欧美日韩在线观看一区二区| 一区二区三区国产精华| 91国偷自产一区二区三区观看| 综合亚洲深深色噜噜狠狠网站| av欧美精品.com| 国产精品超碰97尤物18| 色欧美乱欧美15图片| 一区二区三区在线免费播放| 欧美日韩中字一区| 久久精品国产久精国产爱| 欧美刺激午夜性久久久久久久| 日本美女一区二区三区| 日韩精品自拍偷拍| 国产综合久久久久久鬼色 | 欧美军同video69gay| 天堂精品中文字幕在线| 日韩一区二区高清| 国产精品亚洲人在线观看| 中文字幕乱码日本亚洲一区二区| 99久久伊人精品| 婷婷开心久久网| 亚洲精品一区二区三区四区高清| 精品一区二区三区不卡| 国产亚洲欧美色| 99在线精品观看| 亚洲 欧美综合在线网络| 欧美电影免费观看高清完整版| 国产精品一区专区| 亚洲男女一区二区三区| 91麻豆精品国产91久久久资源速度 | 日韩午夜av电影| 国产高清精品久久久久| 一区二区三区四区激情| 精品国产伦一区二区三区观看体验| 国产激情视频一区二区三区欧美| 亚洲人成网站在线| 欧美一区二区三区小说| 成人免费毛片高清视频| 日韩高清在线不卡| 国产精品美女一区二区在线观看| 欧美剧情电影在线观看完整版免费励志电影| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品素人一区二区| 欧美乱妇20p| 99精品欧美一区二区蜜桃免费| 无吗不卡中文字幕| 自拍偷拍亚洲激情| 久久亚洲精精品中文字幕早川悠里 | 欧美日韩亚洲综合在线| 国产盗摄一区二区| 水野朝阳av一区二区三区| 国产精品久久久久久久蜜臀 | 日韩高清不卡一区| 国产精品久久一卡二卡| 精品少妇一区二区三区视频免付费| 99re热视频精品| 国产乱子轮精品视频| 天天av天天翘天天综合网色鬼国产| 国产欧美日韩视频在线观看| 日韩午夜精品视频| 欧美最猛性xxxxx直播| 成人激情视频网站| 国产美女在线观看一区| 日本午夜精品视频在线观看| 樱桃视频在线观看一区| 国产精品黄色在线观看| 久久精品欧美日韩精品| 欧美成人伊人久久综合网| 制服丝袜在线91| 欧美日韩一区二区不卡| 色播五月激情综合网| 白白色 亚洲乱淫| 国产suv精品一区二区6| 国产精品一卡二卡在线观看| 激情另类小说区图片区视频区| 奇米四色…亚洲| 日日欢夜夜爽一区| 亚洲电影一区二区三区| 亚洲一区二区三区四区不卡| 亚洲免费在线看| 日韩美女精品在线| 亚洲素人一区二区| 综合自拍亚洲综合图不卡区| 亚洲欧洲国产日韩| 国产91丝袜在线观看| 国产综合色在线| 国产精品99久久久| 国产精品原创巨作av| 国产精品88av| 国产成人av电影在线| 成人午夜免费视频| 91亚洲国产成人精品一区二三 | 国产suv精品一区二区6| 丁香一区二区三区| 99久久国产综合精品麻豆| 日本韩国欧美一区| 欧美在线|欧美| 欧美高清性hdvideosex| 精品久久国产97色综合| 欧美精品一区视频| 国产精品久久免费看| 亚洲欧美日韩成人高清在线一区| 一区二区三区欧美久久| 天涯成人国产亚洲精品一区av| 免费国产亚洲视频| 国产白丝网站精品污在线入口| 91蜜桃网址入口| 欧美美女bb生活片| 久久这里只有精品视频网| 一区在线观看免费| 五月天一区二区| 九九热在线视频观看这里只有精品| 国产超碰在线一区| 欧美性做爰猛烈叫床潮| www激情久久| 亚洲女与黑人做爰| 久久疯狂做爰流白浆xx| 成人免费视频一区| 欧美人与性动xxxx| 国产婷婷色一区二区三区| 亚洲视频在线一区| 免费欧美日韩国产三级电影| 成人一二三区视频| 欧美精品欧美精品系列| 国产喷白浆一区二区三区| 亚洲国产视频网站| 岛国av在线一区| 制服丝袜中文字幕亚洲| 国产精品国产三级国产aⅴ原创| 亚洲福利视频一区二区| 福利91精品一区二区三区| 欧美日韩国产综合一区二区| 欧美激情在线看| 蜜桃视频免费观看一区| 在线观看国产日韩| 亚洲国产电影在线观看| 久久精品理论片| 欧美日韩国产小视频| 国产精品免费看片| 精品无人区卡一卡二卡三乱码免费卡 | 欧美天堂一区二区三区| 国产午夜精品久久久久久久| 天堂va蜜桃一区二区三区漫画版 | 欧美日韩日本视频| 国产精品久久久久永久免费观看 | 91在线视频播放地址| 26uuu亚洲| 欧美色图一区二区三区| 久久久久久电影| 青青草国产成人av片免费| 91福利视频久久久久| 国产精品久久网站| 成人夜色视频网站在线观看| 久久奇米777| 激情综合网激情| 日韩免费电影网站| 日韩高清不卡一区二区三区| 欧美精品tushy高清| 亚洲综合精品久久| 色婷婷精品大在线视频| 国产精品国产三级国产三级人妇| 国产成人亚洲精品青草天美| 精品福利一区二区三区| 国模套图日韩精品一区二区| 日韩欧美黄色影院| 韩国三级中文字幕hd久久精品| 欧美成人欧美edvon|