web-dev-qa-db-ja.com

Wake-On-LAN 13.04の問題

Ubuntuサーバー13.04のインストールでWOLを数週間動作させようとしましたが、うまくいかないようです。

「Sudo pm-suspend」またはデスクトップGUIを使用してサーバーを一時停止すると、NICカードがオフになります。つまり、ネットワークポートに点滅するライトはありません。それが問題であるかどうかはわかりませんが、私の/var/log/syslogで、私のイーサネットは「ACPIによってシステムウェイクアップが有効になっている」PCIの1つではないこともわかりました。

    Oct  2 16:46:10 JAMFS1 kernel: [26462.745615] PM: suspend of devices complete after 519.955 msecs
    Oct  2 16:46:10 JAMFS1 kernel: [26462.745743] PM: late suspend of devices complete after 0.126 msecs
    Oct  2 16:46:10 JAMFS1 kernel: [26462.745953] ehci-pci 0000:00:1d.0: System wakeup enabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26462.761576] ehci-pci 0000:00:1a.0: System wakeup enabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26462.793491] xhci_hcd 0000:00:14.0: System wakeup enabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26462.809491] PM: noirq suspend of devices complete after 63.784 msecs
    Oct  2 16:46:10 JAMFS1 kernel: [26462.809695] ACPI: Preparing to enter system sleep state S3
.......
    Oct  2 16:46:10 JAMFS1 kernel: [26463.464575] ACPI: Waking up from system sleep state S3
    Oct  2 16:46:10 JAMFS1 kernel: [26463.510511] xhci_hcd 0000:00:14.0: System wakeup disabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26463.542498] ehci-pci 0000:00:1a.0: System wakeup disabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26463.574474] ehci-pci 0000:00:1d.0: System wakeup disabled by ACPI
    Oct  2 16:46:10 JAMFS1 kernel: [26463.590562] PM: noirq resume of devices complete after 125.527 msecs
    Oct  2 16:46:10 JAMFS1 kernel: [26463.590650] PM: early resume of devices complete after 0.071 msecs

しかし、「cat/proc/acpi/wakeup」によると、私のイーサネットカードISは有効になっているはずです。

Device  S-state   Status   Sysfs node
USB1      S3    *disabled
RP01      S4    *enabled   pci:0000:00:1c.0
RP03      S4    *enabled   pci:0000:00:1c.2
GLAN      S4    *disabled
EHC1      S4    *enabled   pci:0000:00:1d.0
EHC2      S4    *enabled   pci:0000:00:1a.0
XHC       S4    *enabled   pci:0000:00:14.0
HDEF      S4    *enabled   pci:0000:00:1b.0
PEG0      S4    *disabled
PEGP      S4    *disabled

私の「lspci -tv」から、「pci:0000:00:1c.2」がAtherosイーサネットカードであることがわかります。

       +-14.0  Intel Corporation Lynx Point USB xHCI Host Controller
       +-16.0  Intel Corporation Lynx Point MEI Controller #1
       +-1a.0  Intel Corporation Lynx Point USB Enhanced Host Controller #2
       +-1b.0  Intel Corporation Lynx Point High Definition Audio Controller
       +-1c.0-[01]--
       +-1c.2-[02]----00.0  Qualcomm Atheros QCA8171 Gigabit Ethernet
       +-1d.0  Intel Corporation Lynx Point USB Enhanced Host Controller #1
       +-1f.0  Intel Corporation Lynx Point LPC Controller

また、/sys/class/net/p2p1/device/power/wakeupを 'enabled'に設定します。 Sudo ethtool -s p2p1 wol gを実行し、それを/etc/rc.localに挿入しました

ASRock BiosでLAN/PCIで同等のウェイクを有効にしました。

ethtool p2p1(p2p1は私のQualcomm Atheros QCA8171ギガビットイーサネット名)はこれを示しています。

Supports Wake-on: pg
Wake-on: g

だから私は何をしますか??私は見つけたすべてのガイドと提案に従いました。ドライバーの問題だと思いますか? Atherosドライバーを更新する方法はありますか? NICカードにライトが点滅していない場合、LANで起動できる人はいますか?システムが起動したら、wiresharkを使用して、ローカルdd-wrtからコマンド/usr/sbin/wol -i 192.168.1.254 -v bc:5f:f4:be:38:e4 -p 9を介して送信されたWOLパケットを検出することができました。また、WOLジェネレーターを備えたWindowsマシンからパケットを受信することもできました。私はただのアイデアではないので、誰にも提案があります....読んでくれてありがとう。

最後に、私のlspci -vvは、それがだれにも役立つのであればそうです:

02:00.0 Ethernet controller: Qualcomm Atheros QCA8171 Gigabit Ethernet (rev 10)
        Subsystem: ASRock Incorporation Device 10a1
        Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx-
        Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- <TAbort- <MAbort- >SERR- <PERR- INTx+
        Latency: 0, Cache Line Size: 64 bytes
        Interrupt: pin A routed to IRQ 18
        Region 0: Memory at f0400000 (64-bit, non-prefetchable) [size=256K]
        Region 2: I/O ports at e000 [size=128]
        Capabilities: [40] Power Management version 3
                Flags: PMEClk- DSI- D1- D2- AuxCurrent=375mA PME(D0+,D1+,D2+,D3hot+,D3cold+)
                Status: D0 NoSoftRst+ PME-Enable- DSel=0 DScale=0 PME-
        Capabilities: [58] Express (v1) Endpoint, MSI 00
                DevCap: MaxPayload 4096 bytes, PhantFunc 0, Latency L0s unlimited, L1 unlimited
                        ExtTag- AttnBtn+ AttnInd+ PwrInd+ RBE+ FLReset-
                DevCtl: Report errors: Correctable+ Non-Fatal+ Fatal+ Unsupported+
                        RlxdOrd- ExtTag- PhantFunc- AuxPwr- NoSnoop-
                        MaxPayload 128 bytes, MaxReadReq 512 bytes
                DevSta: CorrErr- UncorrErr+ FatalErr- UnsuppReq+ AuxPwr+ TransPend-
                LnkCap: Port #0, Speed 2.5GT/s, Width x1, ASPM L0s L1, Latency L0 unlimited, L1 unlimited
                        ClockPM+ Surprise- LLActRep- BwNot-
                LnkCtl: ASPM Disabled; RCB 64 bytes Disabled- Retrain- CommClk+
                        ExtSynch- ClockPM- AutWidDis- BWInt- AutBWInt-
                LnkSta: Speed 2.5GT/s, Width x1, TrErr- Train- SlotClk+ DLActive- BWMgmt- ABWMgmt-
        Capabilities: [c0] MSI: Enable- Count=1/16 Maskable+ 64bit+
                Address: 0000000000000000  Data: 0000
                Masking: 00000000  Pending: 00000000
        Capabilities: [d8] MSI-X: Enable+ Count=16 Masked-
                Vector table: BAR=0 offset=00002000
                PBA: BAR=0 offset=00003000
        Capabilities: [100 v1] Advanced Error Reporting
                UESta:  DLP- SDES- TLP- FCP- CmpltTO- CmpltAbrt- UnxCmplt- RxOF- MalfTLP- ECRC- UnsupReq+ ACSViol-
                UEMsk:  DLP- SDES- TLP- FCP- CmpltTO- CmpltAbrt- UnxCmplt- RxOF- MalfTLP- ECRC- UnsupReq- ACSViol-
                UESvrt: DLP- SDES+ TLP- FCP- CmpltTO- CmpltAbrt- UnxCmplt- RxOF+ MalfTLP+ ECRC- UnsupReq- ACSViol-
                CESta:  RxErr- BadTLP- BadDLLP- Rollover- Timeout- NonFatalErr-
                CEMsk:  RxErr- BadTLP- BadDLLP- Rollover- Timeout- NonFatalErr+
                AERCap: First Error Pointer: 14, GenCap+ CGenEn- ChkCap+ ChkEn-
        Capabilities: [180 v1] Device Serial Number ff-be-38-f4-bc-ef-f4-df
        Kernel driver in use: alx
2
user198220

それで、さらにいじってから、Ubuntuを休止状態にして

Sudo pm-hibernate

NICライトは点灯したままで、WOLを実行できます。ただし、私はLVM暗号化を使用しているため、これは良くありません。そのため、オンサイトでパスキーを入力する必要があり、リモート入力ではできません。ハイバネーションとサスペンドのルーチンを比較すると、

/usr/lib/pm-utils/sleep.d/50unload_alx

次の行があります。

「modunload alx」

私が見つけたのは、アテロームNICのドライバーをアンロードしているものです。それをコメントアウトすると、トリックを実行し、中断したときにライトが点灯したままになり、WOLができるようになりました。

しかし、modunload alxの理由は、マシンが適切に停止するのを妨げるバグが原因であることがわかったため、おそらく追加されました。

それで、私が現在いる新しい状況は、一時停止からWOLを実行できるが、最初の後にマシンを一時停止できないことです。興味深いことに、冬眠はうまく機能し、冬眠からのWOLは毎回機能します。

WOLを一時停止して何度も繰り返すことができません。最初のサスペンドは

Sudo pm-suspend

しかし、その後、それはもうありません。

しかし、私はデスクトップ(そして次にWOL)で問題なくサスペンドできることに気付きました。

したがって、新しい質問は次のとおりです(おそらく、新しいスレッドを作成する必要があります)。

違いは何ですか

Sudo pm-suspend

デスクトップを介して一時停止するか?

また、私がする場合

Sudo pm-suspend-hybrid

一時停止し、WOLもできます。デスクトップのタイマーをXX分後にサスペンドするように設定すると、それも正常にサスペンドし、WOLを実行できます。

では、これらすべてのルーチンとSudo pm-suspendの違いは何ですか?

1
user198220