コグノスケ


link 未来から過去へ表示(*)  link 過去から未来へ表示

link もっと前
2009年9月8日 >>> 2009年8月26日
link もっと後

2009年9月8日

メモリ増設

デスクトップマシンのメモリを1GBから3GBに増やそうと思い、DDR2 800の1GB x 2を買いました。デスクトップマシンは800でなく400だった気がするけど、値段はDDR2 800が一番安いので、これでいいのです。

で、今日Amazonからメモリが届いたので早速増設しようと思ったら、どう頑張っても挿せない。しかもスロットとメモリのピン数が違う??なんぞこれ。

嫌な予感がして、既に挿してあったメモリを確認すると、DDR2 400ではなくDDR 400でした。そんな馬鹿な…というか馬鹿は俺じゃね?

もう本当にありがとうございました。

どうしたものか

メモリどうしよう。Transcend JetRam 1GB x 2です。悪い品ではないと思います。誰か使いません?

編集者:すずき(2009/09/09 00:52)

コメント一覧

  • senaさん(2009/09/19 11:23)
    久しぶりに日記見たー。
    自分のPCのメモリスロット状況把握してないけど、
    挿せそうなら買い取らせてもらおうかな。
  • すずきさん(2009/09/19 20:00)
    >sena さん
    箱とか説明書とかないですけど、どうぞもらってやってください。
open/close この記事にコメントする



2009年9月5日

無駄な努力

昨日長々と書きましたが、実はRealtekのサイトにて公開されているr8168ドライバのバージョン8.014.00を使えばパッチもへったくれも必要ありませんでした。

他の変更(バグフィクスかな?)も入っているようなので、8.012.00にこだわる理由がなければさくっとアップデートした方が良いと思います。

まあ、一つの勉強にはなったけど、あんまり意味が無かったな…。

編集者:すずき(2009/09/05 00:26)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2009年9月4日

r8168 PCI-e GbEとカーネル2.6.30

家のファイルサーバのLinuxカーネルバージョンを2.6.30.5にアップデートしたところ、r8168 PCI-eギガビットイーサネットドライバがコンパイルできなくなりました。

原因は NAPIの関数名が一部変わったためです。netif_rx_xx系が廃止され、napi_xxへ移行しました。これによりnetif_rx_xx系を使用している部分がリンクエラーとなります。

もうひとつ原因があって irqreturn_tのtypedefがintからenum irqreturnへ変わり、IRQ_HANDLEDがマクロではなく列挙型になったためです。これにより2.4.xとのコンパチを保つための定番処理(※)の判定を誤って、irqreturn_tをvoidと定義してしまいます。

このため割り込みハンドラが値を返さない関数として定義されてしまい、ハンドラ内でreturn IRQ_HANDLED; などとしている部分がコンパイルエラーになります。

以上の変更点を踏まえたパッチは以下の通り。Realtekが提供しているr8168-8.012.00に当てます。


diff -r 2aec411ad986 src/r8168.h
--- a/src/r8168.h       Sat Aug 29 04:02:18 2009 +0900
+++ b/src/r8168.h       Fri Sep 04 23:14:44 2009 +0900
@@ -37,11 +37,13 @@
 #define CHECKSUM_PARTIAL CHECKSUM_HW
 #endif

+#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30)
 #ifndef IRQ_HANDLED
 #define irqreturn_t void
 #define IRQ_HANDLED
 #define IRQ_NONE
 #endif
+#endif /* #if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,30) */

 #ifndef HAVE_FREE_NETDEV
 #define free_netdev(x) kfree(x)
@@ -251,7 +253,11 @@
        #define RTL_GET_NETDEV(priv_ptr)                        struct net_device *dev = priv_ptr->dev;
        #define RTL_RX_QUOTA(ndev, budget)                      budget
        #define RTL_NAPI_QUOTA_UPDATE(ndev, work_done, budget)
- #if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29)
+ #if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,31)
+       #define RTL_NETIF_RX_COMPLETE(dev, napi)                napi_complete(napi)
+       #define RTL_NETIF_RX_SCHEDULE_PREP(dev, napi)           napi_schedule_prep(napi)
+       #define __RTL_NETIF_RX_SCHEDULE(dev, napi)              __napi_schedule(napi)
+ #elif LINUX_VERSION_CODE < KERNEL_VERSION(2,6,29)
        #define RTL_NETIF_RX_COMPLETE(dev, napi)                netif_rx_complete(dev, napi)
        #define RTL_NETIF_RX_SCHEDULE_PREP(dev, napi)           netif_rx_schedule_prep(dev, napi)
        #define __RTL_NETIF_RX_SCHEDULE(dev, napi)              __netif_rx_schedule(dev, napi)

このパッチを使う方がもしいましたら、ご自由にどうぞ。一応、我が家のファイルサーバ上では元気に動いております。が、ご利用の際は自己責任でよろしくお願いいたします。

変化のとき

今回紹介した変更点が、いつカーネルに取り込まれたかについてはLinux kernelのgitリポジトリを調べてね…というのはちょっと無責任ですので、紹介しておきます。

細かいログは参考の章に譲り、変更点がマージされた時期と関連するバージョンタグだけ挙げます。時間は全てUTC換算です。

  • 2009 04/07 21:25:01: Linux 2.6.30-rc1
  • 2009 03/26 23:06:50: irqreturn_tのパッチがマージ
  • 2009 03/23 23:12:14: Linux 2.6.29
  • 2009 03/16 14:56:58: NAPIのパッチがマージ
  • 2009 03/13 02:39:28: Linux 2.6.29-rc8

従って私のパッチでは、NAPIはLinux 2.6.29未満であれば古いAPIを使い、irqreturn_tはLinux 2.6.30未満であれば古い定義を使うようにしています。

(※)irqreturn_tを使うハンドラを、古い2.4.x系とコードコンパチにするコードとして、カーネルのコメント中で紹介されていた方法です。r8168が悪いわけではありません。

参考

以下はirqreturn_tが変化したときのログ。

irqreturn_tの定義が変わったときのマージログとオリジナルのパッチのログ

----- マージ
commit a8416961d32d8bb757bcbb86b72042b66d044510
Merge: 6671de3 fc2869f
Author: Linus Torvalds <torvalds@linux-foundation.org>
Date:   Thu Mar 26 16:06:50 2009 -0700

    Merge branch 'irq-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/gi
t/tip/linux-2.6-tip

----- パッチ
commit bedd30d986a05e32dc3eab874e4b9ed8a38058bb
Author: Thomas Gleixner <tglx@linutronix.de>
Date:   Tue Sep 30 23:14:27 2008 +0200

    genirq: make irqreturn_t an enum

    Impact: cleanup

    Remove the 2.4 compabiliy cruft

もうひとつNAPIが変化したときのログ。

netif_rx系が削除されたときのマージログとオリジナルのパッチのログ

----- マージ
commit 8e91f178a2bb4a3e52e76f6263c251ffb816eb17
Merge: 8032b52 ea8dbdd
Author: Linus Torvalds <torvalds@linux-foundation.org>
Date:   Mon Mar 16 07:56:58 2009 -0700

    Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6

----- パッチ
commit 9fae6c3f648e38f023b99b5f5a5280907b2e796e
Author: Ilya Yanok <yanok@emcraft.com>
Date:   Fri Mar 13 09:51:46 2009 -0700

    dnet: replace obsolete *netif_rx_* functions with *napi_*

    *netif_rx_* functions is obsolete and removed in newer kernels so
    we need to use corresponding *napi_* functions instead.

こんなとこかな。

編集者:すずき(2009/09/05 00:16)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



2009年8月26日

熱は下がろうとも

昨日一日、薬飲んで安静にしていたおかげで、熱はだいぶ下がりました。お腹は痛いままです。

熱が下がるとき(下がった後?)って滝のように汗をかきますが、今回は布団に人の形が見えるくらい汗が出ました。起きたら服がびしょびしょだし、自分でもびっくり。

まあ、それは良しとして。会社からもう一度インフルエンザの検査を受けろと言ってきました。2回もやって陰性でしたと言っても、もう一回だけやって欲しいと。もうほとんど熱もないし、そんなことしても無駄にお金がかかる(※)だけで意味がない、と伝えても、とにかくもう一回だけやって欲しいの一点張り。

検査代は後で会社が払ってくれると言うから、個人的に損はしませんけど…会社のやることは意味が分からん。まあ、逆らっても仕方ないので病院へ。

(※)インフルエンザの検査は基本的には熱があるときに受けるものです。熱がなければ、本来不要な検査を行ったことになりますので健康保険が効きません。つまり10割負担です。

保険外診療

病院で体温を測ると36.4℃でした。ド平熱もいいとこです。

お医者さんには、熱もないしインフルエンザの検査は実費になりますよ?それでもやります?って言われましたが、とにかく検査をお願いしました。理由?そんなの私にもわかりませんて。

結果は陰性でした。当たり前です!って感じで、お医者さんも若干呆れてました。ですよねー。

この不要な検査で7千円以上飛んでいきました。MOTTAINAIよ!

それと、お腹痛かった件は腸炎と診断されました。新たにお腹に優しい薬が処方されておしまい。

編集者:すずき(2009/08/29 16:51)

コメント一覧

  • コメントはありません。
open/close この記事にコメントする



link もっと前
2009年9月8日 >>> 2009年8月26日
link もっと後

管理用メニュー

link 記事を新規作成

<2009>
<<<09>>>
--12345
6789101112
13141516171819
20212223242526
27282930---

最近のコメント5件

  • link 21年9月20日
    すずきさん (11/19 01:04)
    「It was my pleasure.」
  • link 21年9月20日
    whtさん (11/17 23:41)
    「This blog solves my ...」
  • link 24年10月1日
    すずきさん (10/06 03:41)
    「xrdpで十分動作しているので、Wayl...」
  • link 24年10月1日
    hdkさん (10/03 19:05)
    「GNOMEをお使いでしたら今はWayla...」
  • link 24年10月1日
    すずきさん (10/03 10:12)
    「私は逆にVNCサーバーに繋ぐ使い方をした...」

最近の記事3件

  • link 23年4月10日
    すずき (11/15 23:48)
    「[Linux - まとめリンク] 目次: Linux関係の深いまとめリンク。目次: RISC-V目次: ROCK64/ROCK...」
  • link 24年11月6日
    すずき (11/15 23:47)
    「[Ubuntu 24.04 LTS on ThinkPad X1 Carbon Gen 12] 目次: Linux会社ではTh...」
  • link 24年11月11日
    すずき (11/15 23:26)
    「[Pythonのテストフレームワーク] 目次: Python最近Pythonを触ることが増えたのでテストについて調べようと思い...」
link もっとみる

こんてんつ

open/close wiki
open/close Linux JM
open/close Java API

過去の日記

open/close 2002年
open/close 2003年
open/close 2004年
open/close 2005年
open/close 2006年
open/close 2007年
open/close 2008年
open/close 2009年
open/close 2010年
open/close 2011年
open/close 2012年
open/close 2013年
open/close 2014年
open/close 2015年
open/close 2016年
open/close 2017年
open/close 2018年
open/close 2019年
open/close 2020年
open/close 2021年
open/close 2022年
open/close 2023年
open/close 2024年
open/close 過去日記について

その他の情報

open/close アクセス統計
open/close サーバ一覧
open/close サイトの情報

合計:  counter total
本日:  counter today

link About www.katsuster.net
RDFファイル RSS 1.0

最終更新: 11/19 01:04