web-dev-qa-db-ja.com

Linux上のQualcommAtherosQCA8171のWOLが機能しない

Wake-on-lanを自分のマシンで動作させることができません。私はLinuxを初めて使用するので、おそらく何かが足りません。私の設定の下。どんな入力でも大歓迎です。ありがとうございました。

私のハードウェア構成:

AsRock FM2A88X-ITX+
AMD A10-7800
Running Linux Mint 17.3 64bits

BIOS configured for wake-on-lan:
    Boot From Onboard LAN: Enabled
    PCIE Device Power On: Enabled

私のシステム構成:

$ uname -a
Linux home-server 3.19.0-32-generic #37~14.04.1-Ubuntu SMP Thu Oct 22 09:41:40 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux


$ lspci -nnk | grep -i net -A2
01:00.0 Network controller [0280]: Qualcomm Atheros AR9462 Wireless Network 
Adapter [168c:0034] (rev 01)
        Subsystem: AzureWave Device [1a3b:2110]
        Kernel driver in use: ath9k
        03:00.0 Ethernet controller [0200]: Qualcomm Atheros QCA8171 Gigabit Ethernet [1969:10a1] (rev 10)
        Subsystem: ASRock Incorporation Device [1849:10a1]
        Kernel driver in use: alx


$ modinfo alx
filename:       /lib/modules/3.19.0-32-generic/kernel/drivers/net/ethernet/atheros/alx/alx.ko
license:        GPL
description:    Qualcomm Atheros(R) AR816x/AR817x PCI-E Ethernet Network Driver
author:         Qualcomm Corporation, <[email protected]>
author:         Johannes Berg <[email protected]>
srcversion:     1917D292620190CB7319BDE
alias:          pci:v00001969d000010A0sv*sd*bc*sc*i*
alias:          pci:v00001969d000010A1sv*sd*bc*sc*i*
alias:          pci:v00001969d00001090sv*sd*bc*sc*i*
alias:          pci:v00001969d0000E091sv*sd*bc*sc*i*
alias:          pci:v00001969d00001091sv*sd*bc*sc*i*
depends:        mdio
intree:         Y
vermagic:       3.19.0-32-generic SMP mod_unload modversions
signer:         Magrathea: Glacier signing key
sig_key:        0C:8B:EF:E0:C1:E2:89:E4:D8:99:09:26:11:7A:DA:3B:DF:EB:41:9C
sig_hashalgo:   sha512


$ Sudo ethtool eth0
    Settings for eth0:
    Supported ports: [ TP ]
    Supported link modes:   10baseT/Half 10baseT/Full
                            100baseT/Half 100baseT/Full
                            1000baseT/Full
    Supported pause frame use: Symmetric Receive-only
    Supports auto-negotiation: Yes
    Advertised link modes:  10baseT/Half 10baseT/Full
                            100baseT/Half 100baseT/Full
                            1000baseT/Full
    Advertised pause frame use: Symmetric
    Advertised auto-negotiation: Yes
    Speed: 1000Mb/s
    Duplex: Full
    Port: Twisted Pair
    PHYAD: 0
    Transceiver: internal
    Auto-negotiation: on
    MDI-X: Unknown
    Current message level: 0x000060e4 (24804)
                           link ifup rx_err tx_err hw wol
    Link detected: yes


$ cat /proc/acpi/wakeup
Device  S-state   Status   Sysfs node
PB21      S4    *disabled
PB22      S4    *disabled
PB31      S4    *disabled  pci:0000:00:03.1
PB32      S4    *disabled
PB33      S4    *disabled
PB34      S4    *disabled
SBAZ      S4    *disabled  pci:0000:00:14.2
ECIR      S4    *disabled
PS2K      S4    *disabled
PS2M      S4    *disabled
P0PC      S4    *disabled  pci:0000:00:14.4
OHC1      S4    *enabled   pci:0000:00:12.0
EHC1      S4    *enabled   pci:0000:00:12.2
OHC2      S4    *enabled   pci:0000:00:13.0
EHC2      S4    *enabled   pci:0000:00:13.2
OHC3      S4    *disabled
EHC3      S4    *disabled
OHC4      S4    *enabled   pci:0000:00:14.5
XHC0      S4    *enabled   pci:0000:00:10.0
XHC1      S4    *enabled   pci:0000:00:10.1
PE20      S4    *disabled  pci:0000:00:15.0
PE21      S4    *disabled
PE22      S4    *disabled
PE23      S4    *disabled


$ ifconfig
eth0      Link encap:Ethernet  HWaddr ------HAVE_DELETED_THAT_MYSELF-----
          inet addr:192.168.1.98  Bcast:192.168.1.255  Mask:255.255.255.0
          inet6 addr: fe80::d250:99ff:fe85:92e/64 Scope:Link
          UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1
          RX packets:17749 errors:0 dropped:0 overruns:0 frame:0
          TX packets:10035 errors:0 dropped:0 overruns:0 carrier:0
          collisions:0 txqueuelen:1000
          RX bytes:22733189 (22.7 MB)  TX bytes:846896 (846.8 KB)
          Interrupt:16


$ cat /etc/network/interfaces
# interfaces(5) file used by ifup(8) and ifdown(8)
auto lo
iface lo inet loopback


$ Sudo ethtool -s eth0 wol g
Cannot get current wake-on-lan settings: Operation not supported
  not setting wol

@ MariusMatutiae 素晴らしい入力の後の2016年1月22日の追加情報:

私は最新の .19.8カーネル を入手し、Atheros alxドライバーのみをtarしました( これらの指示 を実行した後にそれを行うことができました):

$ tar xf linux-3.19.8.tar.xz linux-3.19.8/drivers/net/ethernet/atheros/alx
$ cd linux-3.19.8/drivers/net/ethernet/atheros/alx
$ make -C /lib/modules/`uname -r`/build M=`pwd` modules
$ Sudo cp /lib/modules/3.19.0-32-generic/kernel/drivers/net/ethernet/atheros/alx/alx.ko /lib/modules/3.19.0-32-generic/kernel/drivers/net/ethernet/atheros/alx/alx.ko.old
$ Sudo cp alx.ko /lib/modules/3.19.0-32-generic/kernel/drivers/net/ethernet/atheros/alx/alx.ko
$ Sudo reboot

そのカーネルのalxドライバーにはWOL設定が戻っています(私が気付いた唯一の違いは、ドライブに署名キーがないことです-上の「modinfoalx」の出力と下の出力を比較してください)が、もう一度運がありません! !!私はまだ自分のマシンでWOLを動作させることができません。 BIOSセットアップのすべてをチェックして再チェックしました。 USBキーボードを使用してスリープ解除することもできますが、WOLを使用することはできません。

$ Sudo modinfo alx
filename:       /lib/modules/3.19.0-32-generic/kernel/drivers/net/ethernet/atheros/alx/alx.ko
license:        GPL
description:    Qualcomm Atheros(R) AR816x/AR817x PCI-E Ethernet Network     Driver
author:         Qualcomm Corporation, <[email protected]>
author:         Johannes Berg <[email protected]>
srcversion:     1917D292620190CB7319BDE
alias:          pci:v00001969d000010A0sv*sd*bc*sc*i*
alias:          pci:v00001969d000010A1sv*sd*bc*sc*i*
alias:          pci:v00001969d00001090sv*sd*bc*sc*i*
alias:          pci:v00001969d0000E091sv*sd*bc*sc*i*
alias:          pci:v00001969d00001091sv*sd*bc*sc*i*
depends:        mdio
vermagic:       3.19.0-32-generic SMP mod_unload modversions

2016年1月30日の追加情報

まだ運がない。 WoWLAN機能を設定することはできましたが、Linuxがパワーダウン、休止状態、またはサスペンドモードからウェイクアップすることはできませんでした。 LAN内のルーターや他のコンピューターを介してウェイクアップしてみました。

$ Sudo iw phy0 wowlan enable magic-packet
$ Sudo iw phy0 wowlan show
  WoWLAN is enabled:
   * wake up on magic packet

それを機能させるのに役立つものは、最高級のブラジルコーヒーの250gパックを手に入れるでしょう:)

2
Italo Nesi

最後にいくつかの進歩がありますが、それでも十分ではありません。カーネル「3.19.0-32-generic」を使用しているので、kernel.orgからalxドライブのソースコードをダウンロードし、ファイルを編集してパッチを適用しました( パッチはここをクリック ) @MariusMatutiaeのアドバイスに従って、ドライバーをコンパイルして、パッチを適用した新しいドライバーに置き換えました。これで、最終的にethtoolコマンドの出力に「SupportsWake-on:pg」が表示されますが、マシンをウェイクアップできません(シャットダウン、休止状態、サスペンド)。私のルーター(aiCloud機能とルーターのネイティブのwake on lanの両方)と別のLinuxボックスからのetherwakeを試してみました。私は掘り続けます、今のところ私がしたことを以下に見てください。もう1つは、起動後にalxドライバーが読み込まれないため、rc.localにスクリプトを作成して読み込むことです。私はおそらくそれを可能な限り最悪の方法でやっていますが、私はそこに着きます。

カーネルをダウンロードします(私が現在使用しているものと同じです)

cd ~/Downloads
wget https://www.kernel.org/pub/linux/kernel/v3.x/linux-3.19.tar.gz

Alxドライバーファイルのみを解凍します

tar xf linux-3.19.tar.gz linux-3.19/drivers/net/ethernet/atheros/alx

ソースコードのあるフォルダに移動します

cd linux-3.19/drivers/net/ethernet/atheros/alx

[〜#〜]重要[〜#〜]:ここでは、 https:/)に従ってalxソースコードファイルを編集する必要があります。 /bugzilla.kernel.org/attachment.cgi?id=156751&action=diff

コンパイル

Sudo make -C /lib/modules/$(uname -r)/build M=$(pwd) modules
Sudo make -C /lib/modules/$(uname -r)/build M=$(pwd) modules_install

Alxドライバーを削除します(リモート/ SSHの場合、接続が切断され、マシンに直接ログインする必要があります)

Sudo rmmod alx

Alxドライバーを再挿入します

Sudo insmod alx.ko

Alx.koファイルを削除してコピーします

Sudo cp /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko.good
Sudo rm /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko
Sudo cp alx.ko /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko

この瞬間、「ethtool -s eth0 wol pg」を試してみるとうまくいくはずですが、それはもう一度起動するまで続きません。そのため、/ etc/rc.localファイルに以下を追加する必要がありました(作成されたファイル「alx.ko」に注意してください。これを/Drivers/alx.koに移動しました)。

#!/bin/sh -e
#
# rc.local
#
# This script is executed at the end of each multiuser runlevel.
# Make sure that the script will "exit 0" on success or any other
# value on error.
#
# In order to enable or disable this script just change the execution
# bits.
#
# By default this script does nothing.
#
exec 2> /tmp/rc.local.log
exec 1>&2
set -x
####################################################
# Enable WOL on eth0 at start-up
rmmod alx
insmod /Drivers/alx.ko
rm /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko
cp /Drivers/alx.ko /lib/modules/$(uname -r)/kernel/drivers/net/ethernet/atheros/alx/alx.ko
ethtool -s eth0 wol pg
iw phy0 wowlan enable magic-packet
# End
####################################################

exit 0
5
Italo Nesi