ふと気づくと電源ランプが付かなくなってるし。
測位は問題無いけど電源ランプ付かなくなってるってのは品質に疑問があるので、返品交換手続きに入った。
gps ntpdはしばしお預け。

I know who Iam.
ふと気づくと電源ランプが付かなくなってるし。
測位は問題無いけど電源ランプ付かなくなってるってのは品質に疑問があるので、返品交換手続きに入った。
gps ntpdはしばしお預け。
OpenRD には Debian squeezeが入れてあるが、 kernel のバージョンは、2.6.32で Ubuntu 11.04 とは結構違う。
カーネル関係のビルドには、 kernel-package を入れるといいらしいので入れる。
noizumi@silverfox:~/src$ sudo aptitude install kernel-package
だが、 /lib/modules/2.6.32-5-kirkwood/build が無い!?
で、検索すると、module-assistant を入れるといいらしい。
noizumi@silverfox:/usr/src$ sudo aptitude install module-assistant
noizumi@silverfox:~$ sudo m-a prepare
で、環境が整ったので、モジュール pl2303 のビルドだが、Ubuntu の2.6.38のカーネルのpl2303.c ではエラーが出てコンパイルが通らないので
noizumi@silverfox:/usr/src$ sudo aptitude install linux-source-2.6.32
と、ソースを取ってきてごりごりやった。
展開して、make して、/lib/modules/uname -r/kernel/drivers/usb/serial のディレクトリへできあがった pl2303.ko をぶっこむべし。
そして、sudo depmod -a やってNAVI CLIP を挿す。
Jun 4 18:03:09 silverfox kernel: [750754.894719] usb 1-1.2: new full speed USB device using orion-ehci and address 7
Jun 4 18:03:09 silverfox kernel: [750755.026187] usb 1-1.2: New USB device found, idVendor=04bb, idProduct=0941
Jun 4 18:03:09 silverfox kernel: [750755.033632] usb 1-1.2: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jun 4 18:03:09 silverfox kernel: [750755.041185] usb 1-1.2: Product: USB-Serial Controller D
Jun 4 18:03:09 silverfox kernel: [750755.046590] usb 1-1.2: Manufacturer: Prolific Technology Inc.
Jun 4 18:03:09 silverfox kernel: [750755.052621] usb 1-1.2: SerialNumber: 10001CF9
Jun 4 18:03:09 silverfox kernel: [750755.126176] usb 1-1.2: configuration #1 chosen from 1 choice
Jun 4 18:03:09 silverfox kernel: [750755.255818] usbcore: registered new interface driver usbserial
Jun 4 18:03:09 silverfox kernel: [750755.274675] USB Serial support registered for generic
Jun 4 18:03:09 silverfox kernel: [750755.284900] usbcore: registered new interface driver usbserial_generic
Jun 4 18:03:09 silverfox kernel: [750755.291734] usbserial: USB Serial Driver core
Jun 4 18:03:09 silverfox kernel: [750755.364524] USB Serial support registered for pl2303
Jun 4 18:03:09 silverfox kernel: [750755.374831] pl2303 1-1.2:1.0: pl2303 converter detected
Jun 4 18:03:09 silverfox kernel: [750755.406372] usb 1-1.2: pl2303 converter now attached to ttyUSB0
Jun 4 18:03:09 silverfox kernel: [750755.412576] usbcore: registered new interface driver pl2303
Jun 4 18:03:09 silverfox kernel: [750755.418358] pl2303: Prolific PL2303 USB to serial adaptor driver
無事認識。gpsd と gpsd-clients をぶっこむ。
noizumi@silverfox:~$ sudo aptitude install gpsd gpsd-clients
noizumi@silverfox:~$ sudo dpkg-reconfigure gpsd
で、デバイスを /dev/ttyUSB0 に、オプションに -n を指定。
noizumi@silverfox:~$ sudo service gpsd restart
で、gpsd 再起動。
X は入れてないので、動作試験に xgps は使えぬ。gpsmon で見てみる。
測位できてるっぽい。
そして、ntpd は既に稼働しているので、ここを参考に、 /etc/ntp.conf に
|
1 2 |
server 127.127.28.0 minpoll 4 maxpoll 4 fudge 127.127.28.0 time1 0.420 refid GPS |
を設定。
oizumi@silverfox:~$ ntpq -p
remote refid st t when poll reach delay offset jitter
==============================================================================
*SHM(0) .GPS. 0 l 11 16 337 0.000 13.960 7.495
後は暫く動かして、誤差を出させて、time1 の後の数字をいじるとする。
あ、正確に測るには0.420 じゃなくて0 にしておかないといけないな (^^;
IO DATAのNAVI CLIP(UMGPS/MF)を衝動買い。
Web見ても「linuxで動きました」って情報が無いのが一筋縄ではいかなそうな予感がもりもりする。

とりあえず挿してみる
Jun 4 11:07:45 purplecat kernel: [137771.758155] usb 2-1.2: new full speed USB device using ehci_hcd and address 7
うむ、やっぱり挿さったところまでしか認識しない。
とりあえず、Vendor ID と Product IDを確認。
noizumi@purplecat:~$ lsusb
Bus 002 Device 007: ID 04bb:0941 I-O Data Device, Inc.
サーフ社製 StarIIIというメジャーなGPSチップの製品だそうなので、基本的にはシリアル出力だから、USBシリアル変換ドライバがうまく噛めば動くはず。
どうせFDTIのUSBシリアル変換つかってんだろうと思って、糞OS仮想箱(Windows 7 VirtualBox guest)でデバイスを見ると…
Profilic Technology inc. USB Serial Controller D
!?
なにそれ? おいしいの?
pl2303 ドライバって知らねえよヽ(Д´)ノ
VEしてるねえ。対応しなきゃいけないソフトウエア技術者は大変だ :-) 。
まあ、USB機器だと、ドライバにハードコーディングされているVendor IDとProduct IDを追加してやればいいだけなので、認識しない位では屁でもない。
という事で、pl2303.c と pl2303.h にエントリ追加してゴリゴリやった。
ファイルを展開して、make して、/lib/modules/uname -r`/kernel/drivers/usb/serial のディレクトリへできあがった pl2303.ko をぶっこむべし。
で、sudo depmod -a やって、再び挿してみる。
Jun 4 14:24:06 purplecat kernel: [149548.161160] usb 2-1.2: new full speed USB
device using ehci_hcd and address 11
Jun 4 14:24:06 purplecat kernel: [149548.309700] USB Serial support registered
for pl2303
Jun 4 14:24:06 purplecat kernel: [149548.309760] pl2303 2-1.2:1.0: pl2303 conve
rter detected
Jun 4 14:24:06 purplecat kernel: [149548.311730] usb 2-1.2: pl2303 converter no
w attached to ttyUSB0
Jun 4 14:24:06 purplecat kernel: [149548.311755] usbcore: registered new interf
ace driver pl2303
Jun 4 14:24:06 purplecat kernel: [149548.311758] pl2303: Prolific PL2303 USB to
serial adaptor driver
無事認識っと。
noizumi@purplecat:~$ sudo aptitude install gpsd gpsd-clients
gpsd の起動オプションを変更。
[/etc/deffault/gpsd]
…
DEVICES=”/dev/ttyUSB0″
…
noizumi@purplecat:~$ sudo service gpsd restart
noizumi@purplecat:~$ xgps
ちゃんと緯度経度情報が取れてるし、測位データを計測する事が可能となった。
このGPSを、OpenRD Ultimateに接続して、GPS時間計測ntpdにでもするか。
Windows XPの入ったPCで、起動時に S.M.A.R.T のエラーが出る奴を復旧したが、 Ubuntu 11.04 のLive CDで Gparted 使った。
250GBの壊れそうなHDDは使用領域が30GB程度だったので、200GBのHDDへパーティションを縮めてコピーした。
1. Gpartedで/dev/sda1を250GB→200GBに縮小。
2. /dev/sdb のパーティションテーブル作成。/dev/sdb1をntfsで確保。bootフラグを付ける。
3. 端末で、dd if=/dev/sda of=/dev/sdb bs=446 count=1 を実行し、MBRをコピー。
4. Gpartedで /dev/sda1 をコピー、 /dev/sdb1 へ貼り付け。
で完了。無事問題なく起動した。
今回は、ハードディスク容量を減らすコピーだったが、逆に容量を増やすコピーもできる訳で、 Gparted だと非常に簡単にできて便利だなあと感心した。
Core i7はx86_64のコードセットが使えるので、折角だから、64bit化しようと、ubuntu.com から、Ubuntu 11.04 – Latest version の64bit のISOイメージファイルをダウンロード。
CD焼くのが面倒なので、以前使用していた8GB USBメモリへ「スタートアップディスクの作成」でインストールディスクを作り、USBメモリ起動。
「Ubuntu 11.04からUbuntu 11.04へアップグレード」という奇妙な感じのするオプションを選択してインストールした。
設定他、データは残ってたので、medibuntu、japaneseリポジトリ再設定、lm-sensors、Déjà Dupバックアップツール、VirtualBox、Thunderbird、conky-all、ffmpeg関係の再インストールで元の環境になった。
今のところ、劇的に変わった感じはしないのだが、どんなメリットがあるのやら…。
libva1とか、ATI のビデオカードの動画再生支援が標準で入るようになった Ubuntu 11.04だが、残念ながら、 xvba-va-driver の依存関係が破損していて入らない。
まず、ソースを取ってくる。
noizumi@purplecat:~/src$ apt-get source xvba-va-driver
パッケージリストを読み込んでいます… 完了
依存関係ツリーを作成しています
状態情報を読み取っています… 完了
‘xvba-va-driver’ の代わりに ‘xvba-video’ をソースパッケージとして選出しています
注意: ‘xvba-video’ パッケージは以下の場所の ‘Svn’ バージョン制御システムで保守されています:
svn://svn.debian.org/svn/pkg-fglrx/xvba-video/trunk
119 kB のソースアーカイブを取得する必要があります。
取得:1 http://jp.archive.ubuntu.com/ubuntu/ natty/multiverse xvba-video 0.7.7-1 (dsc) [1,951 B]
取得:2 http://jp.archive.ubuntu.com/ubuntu/ natty/multiverse xvba-video 0.7.7-1 (tar) [114 kB]
取得:3 http://jp.archive.ubuntu.com/ubuntu/ natty/multiverse xvba-video 0.7.7-1 (diff) [3,044 B]
119 kB を 0秒 で取得しました (265 kB/s)
gpgv: 2010年12月22日 17時46分06秒 JSTにRSA鍵ID 90CBD8E4で施された署名
gpgv: 署名を検査できません: 公開鍵が見つかりません
dpkg-source: warning: failed to verify signature on ./xvba-video_0.7.7-1.dsc
dpkg-source: info: extracting xvba-video in xvba-video-0.7.7
dpkg-source: info: unpacking xvba-video_0.7.7.orig.tar.gz
dpkg-source: info: unpacking xvba-video_0.7.7-1.debian.tar.gz
依存関係で、fglrx-driverという名前のパッケージは無いので、fglrxに修正する。
noizumi@purplecat:~/src$ vi xvba-video-0.7.7/debian/control
Source: xvba-video
Section: non-free/libs
Priority: optional
Homepage: http://www.splitted-desktop.com/~gbeauchesne/
Maintainer: Fglrx packaging team <pkg-fglrx-devel@lists.alioth.debian.org>
Uploaders: Patrick Matthäi <pmatthaei@debian.org>
Build-Depends: debhelper (>= 7), libva-dev, libgl1-mesa-dev
Standards-Version: 3.9.1
Vcs-Svn: svn://svn.debian.org/svn/pkg-fglrx/xvba-video/trunk
Vcs-Browser: http://svn.debian.org/wsvn/pkg-fglrx/xvba-video/trunk/
XS-Autobuild: yesPackage: xvba-va-driver
Architecture: i386 amd64
Depends: ${shlibs:Depends}, ${misc:Depends}, fglrx-driver(>= 1:10-9), libva1
Description: XvBA-based backend for VA API (AMD fglrx implementation)
X-Video Bitstream Acceleration (XvBA), designed by AMD for its ATI/AMD Radeon
GPU, is a future extension of the X video extension (Xv) for the X Window
System on Linux operating-systems. XvBA API allows video programs to offload
portions of the video decoding process to the GPU video-hardware. Currently,
the portions designed to be offloaded by XvBA onto the GPU are motion
compensation (mo comp) and inverse discrete cosine transform (iDCT), and VLD
(Variable-Length Decoding) for MPEG-2, MPEG-4 AVC (H.264) and VC-1 encoded
video.
.
This driver only works with the proprietary fglrx driver from AMD.
noizumi@purplecat:~/src$ cd xvba-video-0.7.7/
noizumi@purplecat:~/src/xvba-video-0.7.7$ dpkg-buildpackage -d
dpkg-buildpackage: export CFLAGS from dpkg-buildflags (origin: vendor): -g -O2
dpkg-buildpackage: export CPPFLAGS from dpkg-buildflags (origin: vendor):
dpkg-buildpackage: export CXXFLAGS from dpkg-buildflags (origin: vendor): -g -O2
dpkg-buildpackage: export FFLAGS from dpkg-buildflags (origin: vendor): -g -O2
dpkg-buildpackage: export LDFLAGS from dpkg-buildflags (origin: vendor): -Wl,-Bsymbolic-functions
dpkg-buildpackage: source package xvba-video
dpkg-buildpackage: source version 0.7.7-1
dpkg-buildpackage: source changed by Patrick Matthäi <pmatthaei@debian.org>
dpkg-buildpackage: host architecture i386
dpkg-source –before-build xvba-video-0.7.7
fakeroot debian/rules clean
dh_testdir
dh_testroot
dh_clean
dpkg-source -b xvba-video-0.7.7
dpkg-source: info: using source format 3.0 (quilt)'../xvba-va-driver_0.7.7-1_i386.deb’ にパッケージ `xvba-va-driver’ を構築しています。
dpkg-source: info: building xvba-video using existing ./xvba-video_0.7.7.orig.tar.gz
dpkg-source: info: building xvba-video in xvba-video_0.7.7-1.debian.tar.gz
dpkg-source: info: building xvba-video in xvba-video_0.7.7-1.dsc
debian/rules build
dh_testdir
dh_testdir
touch build-stamp
fakeroot debian/rules binary
dh_testdir
dh_testdir
touch build-stamp
dh_testdir
dh_testroot
dh_prep
dh_install "x86/xvba_drv_video.so" "usr/lib/va/drivers/"
dh_testdir
dh_testroot
dh_installchangelogs NEWS
dh_installdocs
dh_install
dh_link
dh_compress
dh_fixperms
dh_strip
dh_installdeb
dh_shlibdeps
dh_gencontrol
dh_md5sums
dh_builddeb
dpkg-deb:
signfile xvba-video_0.7.7-1.dsc
gpg: “Patrick Matthäi <pmatthaei@debian.org>”をとばします: 秘密鍵が得られません
gpg: [stdin]: clearsign failed: 秘密鍵が得られません
dpkg-genchanges >../xvba-video_0.7.7-1_i386.changes
dpkg-genchanges: including full source code in upload
dpkg-source –after-build xvba-video-0.7.7
dpkg-buildpackage: full upload (original source is included)
dpkg-buildpackage: warning: Failed to sign .dsc and .changes file
これで、インストール可能な xvba-va-driver_0.7.7-1_i386.deb ができあがるので、
noizumi@purplecat:~/src$ sudo dpkg -i xvba-va-driver_0.7.7-1_i386.deb
[sudo] password for noizumi:
未選択パッケージ xvba-va-driver を選択しています。
(データベースを読み込んでいます … 現在 140154 個のファイルとディレクトリがインストールされています。)
(xvba-va-driver_0.7.7-1_i386.deb から) xvba-va-driver を展開しています…
xvba-va-driver (0.7.7-1) を設定しています …
動作確認
noizumi@purplecat:~/src$ vainfo
libva: libva version 0.31.1
Xlib: extension “XFree86-DRI” missing on display “:0.0”.
libva: va_getDriverName() returns 0
libva: Trying to open /usr/lib/dri/fglrx_drv_video.so
Segmentation fault
という事で、依存破損を修正してインストールしても、ダメ。
元々入れてたここのモジュールだと、vainfo で segmentation fault する事は無いが、mplayer-vaapi や vlc --ffmpeg-hw で再生できないので、根本的なところで異常となってるのかもしれない。
こういう部分を追っかけようと思うとかなり気合いを入れないといけないので、修正を待とう(^^;
久しぶりにエンコ活動をやろうと、ffmpeg を弄ってみようと思ったが、Ubuntu 11.04を新規インストールしたので環境が無い。
とりあえず、パッケージの ffmpeg をインストールしてみたが、やはり、「libxvid 何それ?」とおトボケ状態。
権利関係がややこしいこの手のビデオ、オーディオコーデックは Ubuntu では「自国の法律守って自己責任でね」というスタイル。
そこで拙文「Ubuntu 10.04のffmpegでlibmp3lameを使用できるようにする」を備忘録に設定しようとするも、libavcodec-unstripped-52 ってのが無くなってる。
synaptic パッケージマネージャで libavcodec を検索すると、libavcoodec-extra-52 ってのがあった。
どうやら改名されてしまったようなので次のパッケージを入れる。
・libavcodec-extra-52
削除されるパッケージ
libavcodec52
libavutil50
インストールされるパッケージ
apport-hooks-medibuntu
libavutil-extra-50
libfaac0
libmp3lame0
libopenjpeg2
libx264-106
libxvidcore4
・libavdevice-extra-52
削除されるパッケージ
libavdevice52
libavformat52
インストールされるパッケージ
libavformat-extra-52
・libavfilter-extra-1
削除されるパッケージ
libavfilter1
libswscale0
インストールされるパッケージ
libswscale-extra–0
・libpostproc-extra-51
削除されるパッケージ
libpostproc51
依存関係で自動指定済み
・libavformat-extra-52
・libavutil-extra-50
・libswscale-extra-0
で、テストエンコード
noizumi@purplecat:~/ビデオ/tmp$ ffmpeg -y -i 1304614119.mp4 -vcodec libxvid -sameq -aspect 16:9 -acodec libmp3lame -ab 128k -threads 6 1304614119.avi
無事できた。
Ubuntu Desktop 環境で設定する NetworkManager の設定ファイルはどこにあるのか?が結構前から気になっていた。
個人用の設定だから、/etc/NetworkManager 以下には無いし、/home/noizumi の下にあるんだろうと思っていたが、 rgrep で検索しても出てこないし、全く謎だった。
何せ日本のGoogleで検索してもこういうお寒い状況で、全然欲しい情報が手に入らない。
# げっ、書いてる内容が内容なだけに、検索トップに来やがった…
# 単に昔からWebページを開設しているというだけで、Google様はほぼリアルタイムでわしのページを収集して下さるのだった 🙂
英語で検索するとすぐ出てくる。
という訳で、
~/.gconf/system/networking
にあるのが分かった。
先日設定したモバイルブロードバンドのNTTdocomo moperaの設定は
~/.gconf/system/networking/connections/2/gsm/%conf.xml
にあって、
<?xml version=”1.0″?>
<gconf>
<entry name=”apn” mtime=”1304584824″ type=”string”>
<stringvalue>mopera.ne.jp</stringvalue>
</entry>
<entry name=”number” mtime=”1304584824″ type=”string”>
<stringvalue>*99#</stringvalue>
</entry>
<entry name=”name” mtime=”1304584824″ type=”string”>
<stringvalue>gsm</stringvalue>
</entry>
</gconf>
というように格納されていた。
この gsm の部分を cdma とかいじっても変わらないので、決定的な部分は別のところにありそう。
NetworkManager/Debugging のページで紹介されている PPPベースのデバッグをやってみたけど、有用な情報が得られない。
うーむ。あきらめるか。
Ubuntu は外人が主力開発なので、mobile phone に関してはNTT docomoの携帯電話は接続しても認識してくれない。
応用開発というところがFOMA用のドライバを作っていて、cdc-acm(FOMA対応)を落っことして来て、ゴリゴリやるもソースが古くてコンパイルに通らない。
そこで、linux-source のパッケージをインストールして展開し、その中から、cdc-acm.c と cdc-acm.h を抜きだし、FOMA用のソースとマージしてゴリゴリやったら通った。
SH-02Cを通信モードにし、USBケーブルで接続して、シリアル通信ソフトで、 /dev/ttyACM0 に115200、パリティなし、8ビット、ストップビット1、フローコントロールXon/Xoffで接続してみると…
|
1 2 3 4 5 6 7 8 |
ati NTT DoCoMo OK at%v Ver1.00 OK |
と、ちゃんと接続できているようではある。
ATDで発呼すると電話掛けるので、pppdで使う上では問題無く使えそうだ。
しかし、ネットワーク設定のモバイルブロードバンド設定で設定しても、
May 5 15:10:09 purplecat modem-manager[845]: (ttyACM0) opening serial port…
May 5 15:10:09 purplecat modem-manager[845]: Modem /org/freedesktop/ModemManager/Modems/2: state changed (disabled -> enabling)
May 5 15:10:09 purplecat modem-manager[845]: Modem /org/freedesktop/ModemManager/Modems/2: state changed (enabling -> disabled)
May 5 15:10:09 purplecat modem-manager[845]: (ttyACM0) closing serial port…
May 5 15:10:09 purplecat modem-manager[845]: (ttyACM0) serial port closed
May 5 15:10:09 purplecat NetworkManager[843]: failed to enable/disable modem: (32) Failed to find a usable modem character set
と、moperaに接続できない。
電話掛けてる感じも無いし、根本的なところでダメな感じがするなあ。
しかたがないので、pppconfig で mopera の設定作って、pon ってやってみたらちゃんと繋がり、Webブラウジングできた。これでLinuxでのモバイル通信はOKじゃ。
一応、まぜまぜしたソースを貼っておこう
cdc-acm.c
cdc-acm.h
これを、応用開発さんのドライバのファイルと置き換え、カーネルヘッダをインストールしてあれば、make で cdc-acm.ko ができるので、それを /lib/modules/uname -r/kernel/drivers/usb/class へコピーすればOK。
参考までにウチの環境は次の通り。
noizumi@purplecat:/etc/ppp$ uname -a
Linux purplecat 2.6.38-8-generic-pae #42-Ubuntu SMP Mon Apr 11 05:17:09 UTC 2011 i686 i686 i386 GNU/Linux
コピーする前に元からあるcdc-acm.koのオリジナルファイルはバックアップを取っておいた方が良いです。
Ubuntu 10.10 で、Firefox4 がCPU1個のプロセス100%で食い潰し、ブラックアウトするという現象に悩まされていたので、11.04へ飛びついた。
一度10.10からアップグレードしたが現象変わらず、クリーンインストールしてみたが、~/.mozilla のフォルダを復元すると、やっぱり同じ症状が出る。どうやら、extensionかプラグインに不都合があった模様。
詳しくは調べていないが、greecemonkey、firebug、moonlightなどの拡張の内、greecemonkeyは大丈夫なので、moonlightがあやしいかな?
クリーンインストールした時に既定のままインストールしたので、/dev/sda にGrub 起動メニューがインストールされてしまった。また、Windows7のシグナチャを破壊するのか?と思ったが、問題無く両方起動した。
これで、USB 8GBのメモリで起動切替しなくて済む。
プリインストールのWindows7 Home Editionは殆ど使っていないので、別にクリーンインストールでハードディスク全域をUbuntuにしても良かった。
しかし、BIOSやファームウエアの更新は腐れゲイツOSでないとできない場合が多いので、最低限のWindows起動環境は残しておかないといけない。困ったもんだ。
アプリケーションのメニューがウインドウではなく、上のバーに出るようになって、にユーザーインターフェースが Mac の様になった。
あと、ATIのドライバが新しくなって、Catalyst Control Center で「ティア フリー」という設定により、垂直同期待機がようやくまともに動くようになった事がうれしい。
今まで、動画再生すると、垂直同期無視で描画していたので、チラつきが非常に気になっていたのだが、それが無くなったので、素晴らしい。
VirtualBox で仮想マシンを動かして、ワークスペースに Windows7 と debian squeeze のウインドウを置いて、それぞれフルスクリーンにすると、こんな感じで、ワークスペース1つが仮想マシンみたいな使い方もできる。
まあ、これはconpizで既に実現していた機能で、Ubuntu はワークスペース切替をconpizでやるようにしたので、できて当たり前と言えば当たり前。
まだ、日本語で検索ができないとか完成していない部分もあるので、普通に使いたい人は、日本語Remix CDが出るまでは手を出さない方が無難。
※やけにUbuntu の日本語サイトが重いと思ったら、もう日本語Remix CDが出てたんだな。