2013年8月22日木曜日

inline assembler コードをdisable した clang と inline assembler コードを enable した gcc4.2 のベンチマークテスト

freebsd-arm の ml で、security/libgcrypt をinline assembler コードをdisable した clang と inline assembler コードをenable した gcc4.2 ではどちらが速いのか、という話が出ていたのですが、どうも誰も実験してみないようなので、試しに実験してみました♪

security/libgcrypt は、make install した後の work の中に、なんとびっくり、テスト用のアプリがいろいろ入っているのです。しかも、そのものずばり、benchmark というアプリがあるので、これを使って実行結果を見てみることにしました。テストアプリの基本的な使い方は、好きなアプリを選んでファイルを実行するだけという、お手軽仕様。便利な世の中になったものですね〜。

ちなみに、うっかり clean しちゃうと work がなくなっちゃいますので、要注意です。

# cd /usr/ports/security/libgcrypt/work/libgcrypt-1.5.3/tests 
# ./benchmark > /path/to/home/benchmark.txt

ちなみに、テストに使用した RPI の uname -a は次の通りです。

FreeBSD raspberry-pi 10.0-CURRENT FreeBSD 10.0-CURRENT #0: Tue Aug 13 03:22:23 JST 2013 user@PC:/usr/home/user/crochet-freebsd/work/obj/arm.armv6/usr/src.arm/sys/RPI-B-ELY arm

clang の最適化機能は下手なアセンブラよりも上という噂も聞かないではないので、真面目な話どっちがどのくらい速いのかというのは非常に興味深いですよね。
さてさて、結果はいかに !?


USE_GCC=4.2 longling.h inline assmbler enable

MD5          234375ms 625000ms 3984375ms 546875ms 156250ms
SHA1         546875ms 781250ms 4218750ms 859375ms 468750ms
RIPEMD160    468750ms 859375ms 4140625ms 859375ms 468750ms
TIGER192     1093750ms 1484375ms 5156250ms 1328125ms 1171875ms
SHA256       781250ms 1484375ms 5000000ms 1171875ms 781250ms
SHA384       1953125ms 3046875ms 6250000ms 2265625ms 1875000ms
SHA512       1953125ms 3046875ms 6250000ms 2265625ms 1953125ms
SHA224       781250ms 1562500ms 5000000ms 1093750ms 937500ms
MD4          78125ms 468750ms 3750000ms 546875ms 234375ms
CRC32        234375ms 234375ms 4375000ms 468750ms 312500ms
CRC32RFC1510 234375ms 156250ms 4375000ms 468750ms 390625ms
CRC24RFC2440 1171875ms 1171875ms 5625000ms 1484375ms 1250000ms
WHIRLPOOL    6484375ms 6953125ms 14843750ms 6875000ms 6562500ms
TIGER        1093750ms 1562500ms 5156250ms 1328125ms 1015625ms
TIGER2       1015625ms 1484375ms 5156250ms 1406250ms 1171875ms

                ECB/Stream         CBC             CFB             OFB             CTR      
             --------------- --------------- --------------- --------------- ---------------
IDEA         3437500ms 3359375ms 3671875ms 3750000ms 3515625ms 3593750ms 3593750ms 3593750ms 5468750ms 5468750ms
3DES         7343750ms 7343750ms 7734375ms 7812500ms 7578125ms 7656250ms 7734375ms 7656250ms 9609375ms 9609375ms
CAST5        1796875ms 1875000ms 2031250ms 2109375ms 1953125ms 1953125ms 2031250ms 2031250ms 3906250ms 3828125ms
BLOWFISH     2187500ms 2109375ms 2421875ms 2421875ms 2343750ms 2265625ms 2421875ms 2343750ms 4218750ms 4296875ms
AES          1953125ms 1796875ms 1875000ms 1796875ms 1718750ms 1718750ms 2265625ms 2109375ms 1718750ms 1796875ms
AES192       2187500ms 2109375ms 2187500ms 2031250ms 2031250ms 2031250ms 2421875ms 2421875ms 2031250ms 2031250ms
AES256       2421875ms 2421875ms 2421875ms 2343750ms 2265625ms 2343750ms 2734375ms 2656250ms 2265625ms 2265625ms
TWOFISH      1562500ms 1640625ms 1718750ms 1875000ms 1718750ms 1640625ms 1796875ms 1718750ms 3515625ms 3515625ms
ARCFOUR      390625ms 468750ms
DES          2968750ms 3046875ms 3359375ms 3437500ms 3281250ms 3203125ms 3281250ms 3359375ms 5156250ms 5234375ms
TWOFISH128   1562500ms 1640625ms 1796875ms 1796875ms 1718750ms 1640625ms 1640625ms 1718750ms 3515625ms 3515625ms
SERPENT128   1875000ms 1796875ms 2109375ms 2109375ms 2031250ms 2031250ms 1953125ms 2109375ms 3828125ms 3828125ms
SERPENT192   1875000ms 1796875ms 2109375ms 2031250ms 2031250ms 2031250ms 2109375ms 2031250ms 3828125ms 3828125ms
SERPENT256   1875000ms 1796875ms 2109375ms 2031250ms 1953125ms 2031250ms 2031250ms 2109375ms 3828125ms 3828125ms
RFC2268_40   2578125ms 2031250ms 2812500ms 2421875ms 2656250ms 2734375ms 2656250ms 2734375ms 4609375ms 4609375ms
SEED         1875000ms 1875000ms 1953125ms 2187500ms 1953125ms 1953125ms 1953125ms 2109375ms 3828125ms 3828125ms
CAMELLIA128  3359375ms 3359375ms 3593750ms 3671875ms 3515625ms 3437500ms 3515625ms 3593750ms 5312500ms 5390625ms
CAMELLIA192  3828125ms 3828125ms 4062500ms 4140625ms 3984375ms 3984375ms 4062500ms 3984375ms 5859375ms 5703125ms
CAMELLIA256  3828125ms 3828125ms 4062500ms 4140625ms 3984375ms 3984375ms 4062500ms 4062500ms 5703125ms 5781250ms

Algorithm         generate  100*sign  100*verify
------------------------------------------------
RSA 1024 bit       8593750ms   78359375ms     2187500ms
RSA 2048 bit       45546875ms   418671875ms     5625000ms
RSA 3072 bit       1337109375ms   1147109375ms     10234375ms
RSA 4096 bit       881875000ms   2457812500ms     16640625ms
DSA 1024/160             -   37343750ms     40156250ms
DSA 2048/224             -   139531250ms     132343750ms
DSA 3072/256             -   299609375ms     275390625ms
ECDSA 192 bit      3437500ms   87734375ms     157812500ms
ECDSA 224 bit      4218750ms   107187500ms     192500000ms
ECDSA 256 bit      5078125ms   126328125ms     236875000ms
ECDSA 384 bit      10078125ms   253593750ms     478984375ms
ECDSA 521 bit      24062500ms   596796875ms     1134765625ms

powm       2890625ms 7812500ms 21250000ms

random     390625ms 468750ms

clang longling.h inline assmbler disable

MD5          234375ms 468750ms 3046875ms 468750ms 390625ms
SHA1         468750ms 703125ms 3359375ms 703125ms 390625ms
RIPEMD160    468750ms 703125ms 3281250ms 625000ms 390625ms
TIGER192     703125ms 1171875ms 3828125ms 1015625ms 625000ms
SHA256       781250ms 1328125ms 4062500ms 1015625ms 781250ms
SHA384       1328125ms 2187500ms 4687500ms 1562500ms 1328125ms
SHA512       1250000ms 2187500ms 4687500ms 1562500ms 1328125ms
SHA224       703125ms 1328125ms 4062500ms 937500ms 859375ms
MD4          156250ms 468750ms 2968750ms 468750ms 234375ms
CRC32        78125ms 156250ms 2578125ms 390625ms 234375ms
CRC32RFC1510 156250ms 156250ms 2500000ms 390625ms 312500ms
CRC24RFC2440 546875ms 546875ms 2890625ms 781250ms 703125ms
WHIRLPOOL    6015625ms 6406250ms 9296875ms 6328125ms 6093750ms
TIGER        781250ms 1093750ms 3906250ms 937500ms 859375ms
TIGER2       703125ms 1171875ms 3828125ms 937500ms 859375ms

                ECB/Stream         CBC             CFB             OFB             CTR      
             --------------- --------------- --------------- --------------- ---------------
IDEA         2187500ms 2109375ms 2421875ms 2500000ms 2343750ms 2187500ms 2265625ms 2343750ms 4062500ms 3984375ms
3DES         5000000ms 5000000ms 5234375ms 5312500ms 5156250ms 5156250ms 5234375ms 5234375ms 6875000ms 6953125ms
CAST5        1562500ms 1562500ms 1875000ms 2031250ms 1640625ms 1718750ms 1718750ms 1718750ms 3515625ms 3515625ms
BLOWFISH     1640625ms 1796875ms 2109375ms 2109375ms 1953125ms 1796875ms 1953125ms 1953125ms 3671875ms 3671875ms
AES          1406250ms 1406250ms 1250000ms 1250000ms 1250000ms 1250000ms 1562500ms 1640625ms 1250000ms 1250000ms
AES192       1640625ms 1484375ms 1484375ms 1406250ms 1406250ms 1406250ms 1796875ms 1875000ms 1406250ms 1484375ms
AES256       1796875ms 1718750ms 1718750ms 1562500ms 1640625ms 1640625ms 2031250ms 2031250ms 1640625ms 1640625ms
TWOFISH      1406250ms 1328125ms 1640625ms 1640625ms 1484375ms 1484375ms 1562500ms 1484375ms 3203125ms 3125000ms
ARCFOUR      468750ms 390625ms
DES          2265625ms 2265625ms 2500000ms 2656250ms 2343750ms 2421875ms 2421875ms 2500000ms 4140625ms 4140625ms
TWOFISH128   1328125ms 1406250ms 1562500ms 1640625ms 1484375ms 1562500ms 1484375ms 1640625ms 3125000ms 3125000ms
SERPENT128   1718750ms 1640625ms 1875000ms 1875000ms 1796875ms 1796875ms 1796875ms 1875000ms 3437500ms 3437500ms
SERPENT192   1562500ms 1562500ms 1875000ms 1875000ms 1796875ms 1796875ms 1796875ms 1953125ms 3437500ms 3437500ms
SERPENT256   1718750ms 1562500ms 1953125ms 1875000ms 1718750ms 1718750ms 1796875ms 1875000ms 3437500ms 3359375ms
RFC2268_40   1718750ms 2187500ms 2031250ms 2500000ms 1796875ms 1875000ms 1953125ms 1875000ms 3593750ms 3593750ms
SEED         1406250ms 1406250ms 1640625ms 1640625ms 1562500ms 1484375ms 1562500ms 1562500ms 3125000ms 3125000ms
CAMELLIA128  2812500ms 2734375ms 3125000ms 3125000ms 2890625ms 2890625ms 2890625ms 2890625ms 4531250ms 4609375ms
CAMELLIA192  3046875ms 3046875ms 3281250ms 3359375ms 3203125ms 3125000ms 3203125ms 3203125ms 4843750ms 4843750ms
CAMELLIA256  3125000ms 3046875ms 3359375ms 3359375ms 3046875ms 3203125ms 3203125ms 3281250ms 4843750ms 4765625ms

Algorithm         generate  100*sign  100*verify
------------------------------------------------
RSA 1024 bit       10000000ms   103359375ms     3125000ms
RSA 2048 bit       230468750ms   602031250ms     8437500ms
RSA 3072 bit       1168750000ms   1783750000ms     16640625ms
RSA 4096 bit       1171875000ms   3805000000ms     27109375ms
DSA 1024/160             -   50703125ms     53046875ms
DSA 2048/224             -   211640625ms     197968750ms
DSA 3072/256             -   489843750ms     439531250ms
ECDSA 192 bit      3515625ms   90390625ms     162968750ms
ECDSA 224 bit      4453125ms   111093750ms     207421875ms
ECDSA 256 bit      5468750ms   134062500ms     254296875ms
ECDSA 384 bit      11484375ms   281718750ms     528203125ms
ECDSA 521 bit      26640625ms   667500000ms     1300156250ms

powm       3671875ms 11015625ms 32031250ms

random     390625ms 234375ms

ちょっと、数値がいっぱい過ぎて、細かい検証はしてません。(爆

結局、longlong.h の使われ方にも左右されるのでしょうが、やっぱり、全体的に inline assembler enable な gcc の方が速いことが多い・・ように見えますね。これで、clang の方が速い!とかだったら、面白かったのにな〜。今はどうしても、asm コードが原因でビルドが通らないことが多いので、やっぱり、なんとか asm コードが通るようになってほしいものですね・・。

2013年8月21日水曜日

FreeBSD on RaspberryPi で Xorg を WITH_NEW_XORG を有効にしてビルドする

前の記事では、WITH_NEW_XORG を有効にしないで、ビルドする方法の解説でしたが、 ようやくWITH_NEW_XORG を有効にして、Xorg をビルドすることができました。

もっとも、ビルドできただけなので、どこまできちんと動作するのかは正直まだ未知数ではありますが・・。

せっかくなので、とりあえず、fvwm2 も追加で入れて写真をとってみました。たまに落ちたりもしますが、動くことは動くみたいです。

詳しいビルド方法については、現在 github に必要なパッチを適用した ports を入れたリポジトリと一緒に、ドキュメントを公開しています。

freebsd-ports-xorg-raspberrypi

同じドキュメントの日本語版は以下になります。


FreeBSD on RaspberryPi での Xorg のビルド方法

1: 事前準備

このビルドで使用する FreeBSD RaspberryPi のイメージは、"MALLOC_PRODUCTION=yes" オプションを有効にしてビルドしてください。このオプションが設定されていないと、jemalloc 問題 (Failed assertion) で glib20 がビルドに失敗する原因になります。イメージをビルドするのに crochet-freebsd を使用している場合は、"__MAKE_CONF"オプションを指定することで、ビルドに使用する "make.conf" の指定ができます。

"WITH_NEW_XORG=yes" を指定したビルドも可能ですので、その場合は、このオプションを "make.conf" に設定してください。

2: ports tree の取得

イメージ作成時に、crochet-freebsd では "UsrPorts" オプションを指定することで、ports tree をあらかじめインストールすることができます。もしくは、RPI 上で以下のコマンドを使用して、手動で ports tree を取得することもできます。

    # portsnap fetch
    # portsnap extract
    # cd /usr/ports
    # make fetchindex

3: 修正版の適用

ビルドを無事に完了させるために、事前に ports tree に修正を適用する必要があります。

(1) x11/xorg-server

Aleksandr Rybalko 氏が作成された FreeBSD ARM でxorg-server がビルドできない問題の修正版

    # fetch --no-verify-peer https://github.com/rayddteam/x11-servers-xorg-server/archive/master.zip
    # unzip master.zip
    # rm master.zip
    # cd x11-servers-xorg-server-master
    # cp -rf * /usr/ports/x11-servers/xorg-server/
    # cd ../

(2) x11-drivers/xf86-video-scfb

Aleksandr Rybalko 氏による xf86-video-scfb の移植版

    # fetch --no-verify-peer https://github.com/rayddteam/xf86-video-scfb/archive/master.zip
    # unzip master.zip
    # rm master.zip
    # cp -rf xf86-video-scfb-master /usr/ports/x11-drivers/xf86-video-scfb/

(3) x11-font/fontconfig, x11/pixman

デフォルトビルドで、x11-fonts/fontconfig の fc-cache が ARM で Segmentation fault (core dumped) する問題 (ports/181372)、 及び、ARM で x11/pixman がビルドできない問題 (ports/181372)、の修正版

    # fetch --no-verify-peer https://github.com/taguchi-ch/freebsd-ports-xorg-raspberrypi/archive/master.zip
    # unzip master.zip
    # rm master.zip
    # cd freebsd-ports-xorg-raspberrypi-master/x11-fonts/fontconfig/
    # cp -rf * /usr/ports/x11-fonts/fontconfig/
    # cd ../../x11/pixman/
    # cp -rf * /usr/ports/x11/pixman/

(4) graphics/libGL, graphics/dri

ARM で "WITH_NEW_XORG=yes" オプションを有効にしてビルドした場合に、graphics/libGL や graphics/dri で 発生するエラーを修正する Olivier Cochard-Labbe 氏によるパッチ(ports/176703・ports/176705) の適用版。 いずれも graphics/libGL の修正のみで問題が解決します。

    # cd ../../graphics/libGL/
    # cp -rf * /usr/ports/graphics/libGL/

(5) security/libgcrypt

security/libgcrypt のARM ビルド問題 (ports/181365・Rui Paulo 氏) は PR が採用されたため、現時点では解決済みです。

4: Xorg のビルド

    # cd /usr/ports/x11/xorg/
    # make config-recursive
注意: オプション設定では、ビデオドライバは一切必要はありません。RPI で使用するビデオドライバは後ほどインストールする xf86-video-scfb です。
    # make install clean

5: xf86-video-scfb のビルド

    # cd /usr/ports/x11-drivers/xf86-video-scfb/
    # ./configure
    # make install clean

6: xorg.conf の作成

'Xorg -configure' は現時点ではまだ RPI では機能しません。そのため、自分で "/etc/X11/xorg.conf" を作成する必要があります。 しかし、Aleksandr Rybalko 氏が作成された "xorg.conf" の設定が公開されているので、その設定を "xorg.conf" にコピーするだけで済みます。

設定内容:

Section "Files"
EndSection

Section "Module"
    Load        "dbe"
    Disable    "dri"
    Disable    "dri2"
    Disable    "glx"
    SubSection  "extmod"
        Option  "omit xfree86-dga"
    EndSubSection
EndSection

Section "ServerFlags"
    Option    "AIGLX"        "false"
    Option    "NoAccel"    "True"
    Option    "NoDRI"        "True"
    Option    "DRI"        "False"
    Option    "DRI2"        "False"
EndSection

Section "InputDevice"
    Identifier  "Keyboard1"
    Driver      "kbd"
EndSection

Section "InputDevice"
    Identifier  "Mouse1"
    Driver      "mouse"
    Option      "Protocol"      "auto"
    Option      "Device"        "/dev/sysmouse"
EndSection

Section "Monitor"
    Identifier  "Monitor"
    Mode "1024x600"
        DotClock        25.175
        HTimings        1024 1048 1148 1200
        VTimings        600 610 620 700
    EndMode
EndSection

Section "Device"
    Identifier  "Generic FB"
    Driver      "scfb"
    Option    "NoAccel"    "True"
EndSection

Section "Screen"
    Identifier  "Screen"
    Device      "Generic FB"
    Monitor     "Monitor"
    DefaultDepth 16
    SubSection "Display"
        Depth           16
        Modes           "1024x600"
    EndSubsection
EndSection

Section "ServerLayout"
    Identifier  "layout"
    Screen      0 "Screen" 0 0
    InputDevice "Mouse1" "CorePointer"
    InputDevice "Keyboard1" "CoreKeyboard"
EndSection

7: rc.conf への設定追加

    # echo 'dbus_enable="YES"' >> /etc/rc.conf
    # echo 'hald_enable="YES"' >> /etc/rc.conf

8: dbus・hald の起動

    # /usr/local/etc/rc.d/dbus start
    # /usr/local/etc/rc.d/hald start

9: xorg の起動

    % startx

2013年8月19日月曜日

FreeBSD で pkg 以外の ports 全てを削除する

FreeBSD on RaspberryPi で、何かをいろいろやり直したくなったときのための、 pkg 以外の ports 全てを削除するコマンド。

別に全消しでいいじゃん、と思われるでしょうが、 RaspberryPi では pkg のビルドに思いのほか時間がかかって面倒なので、これを使えば、ちょっとした時間短縮ができます。

# pkg info | awk '{print $1}' | grep -v ^pkg | xargs pkg delete -f -y

ちなみに、単に全部削除する場合は、

# pkg delete -af

これだけでおしまいです。
レッツバルス♪

2013年8月18日日曜日

FreeBSD で修正したコンポーネントのみをビルドインストールする

FreeBSD で、特定のコンポーネントにパッチを当てたり、ソースコードを修正した場合に、 buildworld しないで、該当のコンポーネントだけ、コンパイルインストールする方法のメモ

# cd /path/to/the/component
# make obj
# make depend
# make
# make install
# rehash

意外とうっかりやるのを忘れたりして、修正がなぜシステムに反映されないのか、10 分くらい惑ったりしちゃいます・・。

2013年8月15日木曜日

FreeBSD on RaspberryPi で Xorg をビルドする

何かと結構時間かかりましたが、ようやくFreeBSD on RaspberryPi で Xorg が動作しました。やっぱりなんだかんだいっても、グラフィカルな表示をみるとうれしくなりますよね。もっとも、派手なウインドウマネジャが入ってるわけじゃないので、ひたすら地味ですが・・。

xorg のビルドに当たってのハマりどころは、前回の記事の webcamd のビルド でのハマりどころに、更にいくつか追加されるような感じになります。

まずは、手順から。

1: Xorg のビルドインストール

# cd /usr/ports/x11/xorg
# make config-recursive

オプション設定の注意ですが、RPI で使用するビデオドライバは別途入れることになりますので、xorg-drivers のビデオドライバは全部チェックを外すことをおすすめします。多分チェックすると新たなハマりどころが増えるだけかと思います。
あと、libiconv の patches オプションはオンにしておいた方がいいでしょう。
それ以外は基本的になるべく必要ではない設定は組み込まない、もしくはデフォルトで、を心がければそれほどハマらないですむのではないかと思います。

オプション設定が完了したら、次のコマンドを実行することで、xorg 及び依存関係にある ports 全てが自動的にビルドインストールされます。
尚、現時点でデフォルトでビルドされる xorg-server のバージョンは 1.7.7 ですが、WITH_NEW_XORG=yes を make.conf に指定することで xorg-server のバージョンが 1.10.6 になり、それに伴い関連するドライバーなどもバージョンアップした状態でビルドをすることができます。しかし、現時点ではこのオプションを指定した状態ではコンパイルが通らないため、使用は避けた方がよいでしょう。

# make install clean

もし、問題が発生したら、2: の回避方法を試してみて、問題の発生した ports が無事にインストール完了したら、

# cd /usr/ports/x11/xorg
# make install clean

で xorg のビルドを再開してください。

2: 問題が起きた場合の解決方法

多分、しばらくすると、エラーで落ちます。というか、落ちましたよね ?

x11/pixman や devel/glib20 のエラーについては、webcamd のビルドに書いてありますので、そちらを参照してください。ここでは残りのエラーの回避方法を書きます。

(1) x11-fonts/fontconfig

これは結構いやらしくて、デフォルトで make すると、make 自体は問題なく終了するのですが、インストール時に fc-cache が実行されると Segmentation fault (core dumped) を起こすというものです。そして、実際にエラーで止まるのは fontconfig ではなく、font 系の他の ports です。わたしの場合は font-misc-misc でした。そのため発生したら、一旦 fontconfig を deinstall して、入れ直す必要があります。

回避方法: 一旦インストール済みの fontconfig を deinstall し、make 時に、USE_GCC=4.2 を指定して再インストールします

# cd /usr/ports/x11-fonts/fontconfig
# make deinstall
# rm -rf work
# make USE_GCC=4.2 install clean

(2) x11-servers/xorg-server

これが恐らく、一番の山で、デフォルトの状態では決してビルドが通りません。なぜかというと、対応するビデオドライバがないからです・・。

エラーメッセージ:

Making all in fb
gmake[3]: Entering directory `/usr/ports/x11-servers/xorg-server/work/xorg-server-1.7.7/fb'
  CC    fb24_32.o
In file included from fb24_32.c:30:
./fb.h:102:2: error: "GLYPHPADBYTES must be 4"
#error "GLYPHPADBYTES must be 4"
 ^
1 error generated.
gmake[3]: *** [libfb_la-fb24_32.lo] Error 1
gmake[3]: Leaving directory `/usr/ports/x11-servers/xorg-server/work/xorg-server-1.7.7/fb'
gmake[2]: *** [all-recursive] Error 1
gmake[2]: Leaving directory `/usr/ports/x11-servers/xorg-server/work/xorg-server-1.7.7'
*** Error code 1

Stop.
make[1]: stopped in /usr/ports/x11-servers/xorg-server
*** Error code 1

Stop.
make: stopped in /usr/ports/x11-servers/xorg-server

回避方法: しかし、実は、この問題は Ray 氏によって既に解決されていてxorg-server の patch 及び、RPI 向けの移植版ビデオドライバが公開されています。そのため、それを使用すれば問題なく xorg-server をビルドして動作させることができます。

まず、準備として、x11-servers-xorg-server-master.zipx11-drivers-xf86-video-scfb-master.zip を任意の場所にダウンロードします。以下のコマンドはファイルをダウンロードしてビルドインストールするまでになります。

# fetch --no-verify-peer https://github.com/rayddteam/x11-servers-xorg-server/archive/master.zip
# unzip master.zip
# cd x11-servers-xorg-server-master
# cp -rf * /usr/ports/x11-servers/xorg-server/
# rm master.zip

# fetch --no-verify-peer https://github.com/rayddteam/xf86-video-scfb/archive/master.zip
# unzip master.zip
# cd x11-drivers-xf86-video-scfb-master
# cp -rf x11-drivers-xf86-video-scfb-master /usr/ports/x11-drivers/xf86-video-scfb/
# rm master.zip

# cd /usr/ports/x11-servers/xorg-server/
# make install clean

# cd /usr/ports/x11-drivers/xf86-video-scfb/
# make install clean

3: xorg.conf について

xorg が無事最後までインストールできたら、いよいよ xorg の起動の準備になります。
通常であれば、Xorg -configure で設定ファイルを作成するのですが、なんと、RPI ではこれがうまく動作しません・・。困ったものです。
しかし、xorg-server の patch を書かれた Ray 氏が、記事に設定例も書いてくれていますので、これをそのまま使わせていただくことにします。

以下の設定を全て、/etc/X11/xorg.conf にコピペして保存します。


Section "Files"
EndSection

Section "Module"
    Load        "dbe"
    Disable    "dri"
    Disable    "dri2"
    Disable    "glx"
    SubSection  "extmod"
        Option  "omit xfree86-dga"
    EndSubSection
EndSection

Section "ServerFlags"
    Option    "AIGLX"        "false"
    Option    "NoAccel"    "True"
    Option    "NoDRI"        "True"
    Option    "DRI"        "False"
    Option    "DRI2"        "False"
EndSection

Section "InputDevice"
    Identifier  "Keyboard1"
    Driver      "kbd"
EndSection

Section "InputDevice"
    Identifier  "Mouse1"
    Driver      "mouse"
    Option      "Protocol"      "auto"
    Option      "Device"        "/dev/sysmouse"
EndSection

Section "Monitor"
    Identifier  "Monitor"
    Mode "1024x600"
        DotClock        25.175
        HTimings        1024 1048 1148 1200
        VTimings        600 610 620 700
    EndMode
EndSection

Section "Device"
    Identifier  "Generic FB"
    Driver      "scfb"
    Option    "NoAccel"    "True"
EndSection

Section "Screen"
    Identifier  "Screen"
    Device      "Generic FB"
    Monitor     "Monitor"
    DefaultDepth 16
    SubSection "Display"
        Depth           16
        Modes           "1024x600"
    EndSubsection
EndSection

Section "ServerLayout"
    Identifier  "layout"
    Screen      0 "Screen" 0 0
    InputDevice "Mouse1" "CorePointer"
    InputDevice "Keyboard1" "CoreKeyboard"
EndSection

わくわく、startx する前に、/etc/rc.conf に 設定を追加するのを忘れないようにしましょう。

# echo 'dbus_enable="YES"' >> /etc/rc.conf
# echo 'hald_enable="YES"' >> /etc/rc.conf

dbus と hald を手動で起動します。

# /usr/local/etc/rc.d/dbus start
# /usr/local/etc/rc.d/hald start

ようやく、準備が整いました。うまく動くといいですね~!

% startx

2013年8月14日水曜日

FreeBSD CURRENT on RapsberryPi で webcamd をビルドする

RapsberryPi 用 camera board のテストをするために、とりあえず webcamd を ports から入れてみたときの作業メモです。

個人的な感触ですが、RapsberryPi で ports をビルドしたい場合、RapsberryPi では ports tree の取得にかなり時間がかかるので、イメージを作る段階で併せて入れておく方が何かと便利です。

イメージ作成時に入れなかった場合は、svn で ports tree を取得するよりも、portsnap を使用する方が、ファイルが壊れるなどのトラブルが発生しにくい気がします。

portsnap を使用して、ports tree を取得する初回の手順は、以下の通りです。

# portsnap fetch
# portsnap extract
# cd /usr/ports
# make fetchindex

2回目以降は、こちらになります。

# cd /usr/ports
# portsnap fetch
# portsnap update
# make fetchindex

ここから、webcamd のビルドに移ります。

# cd /usr/ports/multimedia/webcamd/
# make config-recursive
# make install clean

これで何もエラーも起きずに最後までたどり着ければいいのですが、わたしは以下の3つの ports でエラー等が発生しましたので、わたしの行った回避方法を書きます。

(1) security/libgcrypt

エラーメッセージ:

===>  Building for libgcrypt-1.5.2
make  all-recursive
Making all in compat
Making all in mpi
/bin/sh /usr/local/bin/libtool --tag=CC    --mode=compile cc -DHAVE_CONFIG_H -I. -I..   -I../src -I../src  -I/usr/local/include -O -pipe -std=gnu89 -fvisibility=hidden -Wall -MT mpih-div.lo -MD -MP -MF .deps/mpih-div.Tpo -c -o mpih-div.lo mpih-div.c
libtool: compile:  cc -DHAVE_CONFIG_H -I. -I.. -I../src -I../src -I/usr/local/include -O -pipe -std=gnu89 -fvisibility=hidden -Wall -MT mpih-div.lo -MD -MP -MF .deps/mpih-div.Tpo -c mpih-div.c  -fPIC -DPIC -o .libs/mpih-div.o
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:13: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~
./longlong.h:230:25: note: expanded from macro 'umul_ppmm'
                   : "=&r" ((USItype)(xh)),                             
                                      ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:17: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~
./longlong.h:231:24: note: expanded from macro 'umul_ppmm'
                     "=r" ((USItype)(xl))                               
                                     ^
mpih-div.c:98:3: error: invalid % escape in inline assembly string
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:2: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:228:14: note: expanded from macro 'umul_ppmm'
  __asm__ ("%@ Inlined umul_ppmm\n"                                     
           ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:13: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~
./longlong.h:230:25: note: expanded from macro 'umul_ppmm'
                   : "=&r" ((USItype)(xh)),                             
                                      ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:18: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ~~~~~~~~~~~~~~~~^~~~~~~~~~~~~
./longlong.h:231:24: note: expanded from macro 'umul_ppmm'
                     "=r" ((USItype)(xl))                               
                                     ^
mpih-div.c:98:3: error: invalid % escape in inline assembly string
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:2: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:228:14: note: expanded from macro 'umul_ppmm'
  __asm__ ("%@ Inlined umul_ppmm\n"                                     
           ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:153:14: note: expanded from macro 'UDIV_QRNND_PREINV'
        sub_ddmmss (_xh, _r, (nh), (nl), _xh, _xl);                 
        ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:200:23: note: expanded from macro 'sub_ddmmss'
           : "=r" ((USItype)(sh)),                                      
                             ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:153:19: note: expanded from macro 'UDIV_QRNND_PREINV'
        sub_ddmmss (_xh, _r, (nh), (nl), _xh, _xl);                 
        ~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:201:24: note: expanded from macro 'sub_ddmmss'
             "=&r" ((USItype)(sl))                                      
                              ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:155:18: note: expanded from macro 'UDIV_QRNND_PREINV'
            sub_ddmmss (_xh, _r, _xh, _r, 0, (d));                  
            ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:200:23: note: expanded from macro 'sub_ddmmss'
           : "=r" ((USItype)(sh)),                                      
                             ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:155:23: note: expanded from macro 'UDIV_QRNND_PREINV'
            sub_ddmmss (_xh, _r, _xh, _r, 0, (d));                  
            ~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~
./longlong.h:201:24: note: expanded from macro 'sub_ddmmss'
             "=&r" ((USItype)(sl))                                      
                              ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:158:15: note: expanded from macro 'UDIV_QRNND_PREINV'
                sub_ddmmss (_xh, _r, _xh, _r, 0, (d));              
                ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:200:23: note: expanded from macro 'sub_ddmmss'
           : "=r" ((USItype)(sh)),                                      
                             ^
mpih-div.c:98:3: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
                UDIV_QRNND_PREINV(dummy, r, r,
                ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:158:20: note: expanded from macro 'UDIV_QRNND_PREINV'
                sub_ddmmss (_xh, _r, _xh, _r, 0, (d));              
                ~~~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~
./longlong.h:201:24: note: expanded from macro 'sub_ddmmss'
             "=&r" ((USItype)(sl))                                      
                              ^
mpih-div.c:104:6: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:13: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~
./longlong.h:230:25: note: expanded from macro 'umul_ppmm'
                   : "=&r" ((USItype)(xh)),                             
                                      ^
mpih-div.c:104:6: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:17: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ~~~~~~~~~~~~~~~^~~~~~~~~~~~~~~~
./longlong.h:231:24: note: expanded from macro 'umul_ppmm'
                     "=r" ((USItype)(xl))                               
                                     ^
mpih-div.c:104:6: error: invalid % escape in inline assembly string
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:150:2: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_q, _ql, (nh), (di));                            
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:228:14: note: expanded from macro 'umul_ppmm'
  __asm__ ("%@ Inlined umul_ppmm\n"                                     
           ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
mpih-div.c:104:6: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:13: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ~~~~~~~~~~~^~~~~~~~~~~~~~~~~~
./longlong.h:230:25: note: expanded from macro 'umul_ppmm'
                   : "=&r" ((USItype)(xh)),                             
                                      ^
mpih-div.c:104:6: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:18: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ~~~~~~~~~~~~~~~~^~~~~~~~~~~~~
./longlong.h:231:24: note: expanded from macro 'umul_ppmm'
                     "=r" ((USItype)(xl))                               
                                     ^
mpih-div.c:104:6: error: invalid % escape in inline assembly string
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:152:2: note: expanded from macro 'UDIV_QRNND_PREINV'
        umul_ppmm (_xh, _xl, _q, (d));                              
        ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:228:14: note: expanded from macro 'umul_ppmm'
  __asm__ ("%@ Inlined umul_ppmm\n"                                     
           ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
mpih-div.c:104:6: error: invalid use of a cast in a inline asm context requiring an l-value: remove the cast or build with -fheinous-gnu-extensions
            UDIV_QRNND_PREINV(dummy, r, r,
            ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./mpi-internal.h:153:14: note: expanded from macro 'UDIV_QRNND_PREINV'
        sub_ddmmss (_xh, _r, (nh), (nl), _xh, _xl);                 
        ~~~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./longlong.h:200:23: note: expanded from macro 'sub_ddmmss'
           : "=r" ((USItype)(sh)),                                      
                             ^
fatal error: too many errors emitted, stopping now [-ferror-limit=]
20 errors generated.
*** [mpih-div.lo] Error code 1

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2/mpi
1 error

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2/mpi
*** [all-recursive] Error code 1

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2
1 error

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2
*** [all] Error code 2

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2
1 error

make: stopped in /usr/ports/security/libgcrypt/work/libgcrypt-1.5.2
===> Compilation failed unexpectedly.
Try to set MAKE_JOBS_UNSAFE=yes and rebuild before reporting the failure to
the maintainer.
*** Error code 1

Stop.
make: stopped in /usr/ports/security/libgcrypt
*** Error code 1

回避方法: オプション USE_GCC=4.2 を使用して、再度 make します

# cd /usr/ports/security/libgcrypt
# rm -rf work
# make USE_GCC=4.2 install clean

(2) x11/pixman

エラーメッセージ:

CPPAS pixman-arm-neon-asm.lo
/usr/include/float.h: Assembler messages:
/usr/include/float.h:43: Error: bad instruction `extern int __flt_rounds(void)'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_r'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'orig_w'
./pixman-arm-neon-asm.h:708: Warning: ignoring redefinition of register alias 'dummy'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'dst_w'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'src'
./pixman-arm-neon-asm.h:947: Warning: ignoring redefinition of register alias 'mask'
pixman-arm-neon-asm.S:3623: Warning: ignoring redefinition of register alias 'tmp1'
pixman-arm-neon-asm.S:3623: Warning: ignoring redefinition of register alias 'tmp2'
pixman-arm-neon-asm.S:3627: Warning: ignoring redefinition of register alias 'tmp1'
pixman-arm-neon-asm.S:3627: Warning: ignoring redefinition of register alias 'tmp2'
pixman-arm-neon-asm.S:3631: Warning: ignoring redefinition of register alias 'tmp1'
pixman-arm-neon-asm.S:3631: Warning: ignoring redefinition of register alias 'tmp2'
pixman-arm-neon-asm.S:3635: Warning: ignoring redefinition of register alias 'tmp1'
pixman-arm-neon-asm.S:3635: Warning: ignoring redefinition of register alias 'tmp2'
cc: error: assembler command failed with exit code 1 (use -v to see invocation)
*** Error code 1

Stop.
make: stopped in /usr/ports/x11/pixman/work/pixman-0.30.0/pixman
*** Error code 1

Stop.
make: stopped in /usr/ports/x11/pixman/work/pixman-0.30.0
*** Error code 1

Stop.
make: stopped in /usr/ports/x11/pixman/work/pixman-0.30.0
*** Error code 1

Stop.
make: stopped in /usr/ports/x11/pixman
*** Error code 1

Stop.
make: stopped in /usr/ports/x11/pixman

回避方法: 回避方法は send-pr しましたので、ports/181140 の patch を Makefile に適用してください。

# cd /usr/ports/x11/pixman
# rm -rf work
# patch < patch-Makefile.txt
# make install clean

(3) devel/glib20

エラーメッセージ:

/bin/sh /usr/ports/devel/glib20/work/glib-2.36.3/install-sh -d /usr/local/lib/gio/modules
 /bin/mkdir -p '/usr/local/share/glib-2.0/schemas'を
 install  -o root -g wheel -m 444 gschema.dtd '/usr/local/share/glib-2.0/schemas'
 /bin/mkdir -p '/usr/local/include/glib-2.0/gio/'
: jemalloc_arena.c:380: Failed assertion: "p[i] == 0"
Abort trap (core dumped)

回避方法: make.conf に MALLOC_PRODUCTION=yes が設定されていれば回避出来るエラーなのですが、問題は、このオプションが RaspberryPi のイメージ作成時に反映されていなければいけない、ということです。ですので、このエラーが発生した場合は、イメージ作成時の設定などを見直して、MALLOC_PRODUCTION=yes が有効になっているイメージを再作成し、かつ、RaspberryPi の make.conf にもオプション設定した上で glib20 を再コンパイルする必要があります。
(まあ、イメージを作りなおしたということは、そもそもの最初からやり直し、ではありますが・・。)
あと、この問題でビルドが止まるのは、このエラーが直接原因ではなく、他の ports で、必要なヘッダファイル(gio/gio.h 等)が入っていないという形で現れるので、注意が必要です。

コンパイルが完了したら、webcamd を動作させるために追加の設定が必要になります。

# echo 'cuse4bsd_load="YES"' >> /boot/loader.conf
# echo 'webcamd_enable="YES"' >> /etc/rc.conf

しかし、実は、xorg のコンパイルがまだ終わっていないので、動作確認ができていません。ほんとに動くんでしょうかね、これ・・。

FreeBSD CURRENT on RaspberryPI でports をビルドする際に発生する問題の回避策

/usr/ports/x11-fonts/fontconfig

デフォルトでmakeすると、makeは問題なく終了するが、インストール時に fc-cache が Segmentation fault (core dumped) を起こす。
回避策 make 時に、USE_GCC=4.2 を指定する

2013年8月6日火曜日

Mac OS X Mountain Lion で smb ファイルサーバのマウントをする

Mac OS X Mountain Lion で smb ファイルサーバのマウントをするやり方のメモです。

ここでは、仮に以下の内容で接続するものとします。

ホスト名 : hoge
IP アドレス : 10.0.0.2
ディレクトリ名 : hoe
ユーザ名 : user

一番簡単なやり方では、finder を使用します。
finder の メニュー、「移動」の一番下にある「サーバに接続...」を選択し、サーバアドレスの欄に、
smb://サーバのホスト名、もしくは ip アドレス
を指定します。

ですので、この場合は、
smb://hoge
もしくは
smb://10.0.0.2
となります

マウントしたいディレクトリを直接指定したい場合は、
smb://サーバのホスト名、もしくは ip アドレス / ディレクトリ名
でディレクトリをマウントすることができます。

この場合は、以下の通りになります。
smb://hoge/hoe
もしくは、
smb://10.0.0.2/hoe

あとは finder が、必要なユーザ名やパスワードの入力を求めてきますので、 それに従って入力することで、GUI で smb ファイルサーバに接続することができます。

接続の切断は、finder メニューの「ファイル」か、表示されているアイコンを右クリックして「"hoe" を取り出す」を選択します。

でも、finder じゃなくて、直接コンソールでマウントしたいこともありますね。
ファイルの権限変更したい時とか。

その場合は、mount_smbfs というコマンドを使用します。

まず、あらかじめ、マウントポイントを用意する必要がありますので、 適当なディレクトリを用意します。
ここでは、ホームディレクトリに mnt というディレクトリを用意します。

% cd
% mkdir mnt

そうしたら、おもむろに、

% mount_smbfs //user@hoge/hoe ./mnt
もしくは、
% mount_smbfs //user@10.0.0.2/hoe ./mnt
( 必要であればここでパスワードの入力が求められます )

特に何も表示されなければ、問題なくマウントされたはずなので、df コマンドで確認します。

% df
Filesystem       512-blocks      Used  Available Capacity  iused      ifree %iused  Mounted on
/dev/disk0s2     1951845952 191396920 1759937032    10% 23988613  219992129   10%   /
devfs                   368       368          0   100%      638          0  100%   /dev
map -hosts                0         0          0   100%        0          0  100%   /net
map auto_home             0         0          0   100%        0          0  100%   /home
//user@hoge/hoe  578166916  85595336  492571580    15%        0 18446744073709551615    0%   /Users/user/mnt

のような感じで表示されたら mount に成功です。

% cd mnt
% ls

で内容がきちんと表示されれば、あとは、通常のファイルシステムと同様に利用することができます。

もし、マウントコマンド実行時に、

mount_smbfs: mount error: /Users/user/mnt: Input/output error

のようなエラーメッセージが出力されたら、対象のサーバを既にマウントしていないかどうか確認してみてください。

% df

で確認できます

さて、必要な作業が完了したら、アンマウントしましょう。
アンマウントは

% umount ./mnt

で実行できます。

umount(/Users/user/mnt): Resource busy -- try 'diskutil unmount'

のようなエラーメッセージが出力されたら、自分が今いるパスがマウントしたパスの中なら、ホームディレクトリに戻るなどしてから再度実行してください。

ちなみに、finder も結局のところマウントを実行しているわけなので、一体どこにマウントしているのかというと、

% df
Filesystem       512-blocks      Used  Available Capacity  iused      ifree %iused  Mounted on
/dev/disk0s2     1951845952 191397960 1759935992    10% 23988743  219991999   10%   /
devfs                   368       368          0   100%      638          0  100%   /dev
map -hosts                0         0          0   100%        0          0  100%   /net
map auto_home             0         0          0   100%        0          0  100%   /home
//user@hoge/hoe  578167248  85595338  492571910    15%        0 18446744073709551615    0%   /Volumes/hoe

なので、実は、"/Volumes/ マウント先のディレクトリ名" に直接 cd すれば、いちいち手動でマウントしなくても、ちゃんとターミナルから操作できるという、しょうもない落ちなのでした・・。

2013年8月2日金曜日

Bad file descriptor の修復に失敗した話

先日、FreeBSD をインストールした古いノート PC で chronium をビルドしていたら、気がついたら、別に電源コードが抜けたとかバッテリーが切れたとかもないのに、ビルド途中に電源まで完全に落ちてしまっていました。
仕方ないので、一回 make clean して、続きをやろうとしたところ、恐らく落ちた時点でコンパイル中だったと思われるディレクトリが clean に失敗している様子。

改めて、該当ディレクトリに移動して、rm -rf work で work ディレクトリを手動削除しようとしたら、

ファイル名 : Bad file descriptor
...
ディレクトリが空じゃないので削除できません

のようなエラーメッセージが・・。

調べてみたら、この Bad file descriptor というのは、あまり例のないエラーのようで、関連する情報がほとんどなかったのですが、ファイルが壊れてしまった時に出るエラーメッセージのようです。

そこで、壊れてしまっているファイルを全部消そうと、該当ディレクトリで rm * しても、その一つ上で rm -rf ディレクトリ名 にしても、全く消すことができません。

マルチユーザモードで fsck -y しても、なぜか修復されず、シングルユーザモードで fsck -y / では、一旦修復しました!といわれるのに、ls -l するとやっぱり、ファイル名 : Bad file descriptor と表示されてしまいます。

これはもうクリーンインストールするしかないとは思ったのですが、調べた情報の中で、clri(8) を使ったら壊れた部分を消して修復可能なのではないか、という話があり、実行例もないようなので、ダメ元で、clri(8) を試して見ることにしました。

ちなみに、clri(8) は、man の情報によれば、fsck で適切に処理されないファイルを削除する、ものだそうです。

壊れたファイルが /path/to/hoge/hoe/hoehoe.txt の場合は、こんな感じになります。

% ls /path/to/hoge/hoe
hoehoe.txt : Bad file descriptor

本来であれば壊れたファイルの i ノード番号を取得して該当ファイルだけを削除したいところですが、Bad file descriptor なファイルの場合、既に i ノード番号すら取得できない状況のため、壊れたファイルの入っているディレクトリを削除してみることにします。

clri(8) は、マルチユーザモードでは実行できなかったため、シングルユーザモードで、

# df
Filesystem  1K-blocks     Used   Avail Capacity  Mounted on
/dev/ada0p2  23352220 12784608 8699436    60%    /
devfs               1        1       0   100%    /dev
# cd /path/to/hoge 
# ls -i
2899285 hoe <-壊れてないディレクトリ(中身のファイルは壊れてる)
# clri /dev/ada0p2 2899285
# fsck -y /

実行自体は、とりあえず、正常に終了しました。

それで、結果的にどうなったかというと・・

# ls
hoe : Bad file descriptor

なんということでしょう。
さっきまで、一応壊れていなかった hoe までもが壊れてしまったのです。
試しに、この一つ上の hoge でも試してみたら、hoge も壊れました・・。

そのため、結局このあと必要なファイルのみバックアップして、クリーンインストールしました。

単にわたしがうまくいかなかっただけで、うまくいくことも、もしかしたらあるのかもしれませんが、 crli(8) では Bad file descriptor は修復できない、と思ってたほうがいいのかもしれません。
やるなら、被害が拡大することを前提に、どうしようもないときだけ試してみるほうがよさそうです。