***本記事にはプロモーションが含まれています。***
AIOが実装されて、-hdb \.PhysicalDrive0でホストのハードディスクにアクセスできなくなっていたので、パッチを作った。これで、AIOで動かなくなったものは、全部動くようになったと思う。
***本記事にはプロモーションが含まれています。***
AIOが実装されて、-hdb \.PhysicalDrive0でホストのハードディスクにアクセスできなくなっていたので、パッチを作った。これで、AIOで動かなくなったものは、全部動くようになったと思う。
***本記事にはプロモーションが含まれています。***
なのだそうです。MSのKBに書いてあった。
そうでないと、WSAConnectがWSAEINVALを返すそうな…。道理でつながらないわけだ。ノンブロッキング動作には、socket()関数ではなくて、WSASocket()関数でソケットを作らないといけないということですね。
実際にconnectで調べてみると、最初はWSAEWOULDBLOCKが返って、次はWSAEINVALになる。やっぱりconnectを2回呼び出してはいけないみたい。あまり関係ないのかなあ。
これは、Winsock FAQに書いてあってもいい情報だと思うけど。
overlapped structure やcompletion functionをNULLにしておけば、ブロッキングと同じ動作にすることができるのだそうです。でも、CreateFileのところには、Overlapped動作のときはNULLにしてはいけないと書いてあったと思う。なんか複雑。
http://support.microsoft.com/kb/179942/EN-US/
http://support.microsoft.com/default.aspx?scid=kb;EN-US;q181611
***本記事にはプロモーションが含まれています。***
アプリケーションのお話でした。ごにょごにょしておきました。
やっと、読み終えることができました。
ウィンドウシステムのところから少しついていけなくて、思った以上に時間がかかってしまいました。途中何度も中断があったのですが、とりあえず最後まで読み通せてよかった。読み通してみて、少しはプログラムを作る力がついたならいいのですけど。どうでしょう。
取り上げられていないOSの話題としては、ページングを使ったメモリ管理、プロセス管理、ファイルシステム、ネットワークなど、いろいろありますよね。64ビットに関するものには興味があるので、いずれそれに関するプログラムができたらいいのですけど。
中級者向けの、もう少し違った書き方をした本が読みたいなと思います。
***本記事にはプロモーションが含まれています。***
LDTと日本語表示の話でした。
なんかやさしく感じた。LDTとかは、少し知っていることだったからかな。日本語表示も、実際に自分で実装しようとしたら苦労するだろうなと思った。
あと少しになりました。
***本記事にはプロモーションが含まれています。***
コンソールとウィンドウの話でした。ちょっと時間が空いてしまい、だんだん忘れかけているという…。
OSみたいな大きなプログラムを作ろうと思ったら、ある程度記憶力が無いとだめなような気がしてきた。記憶しておくといっても普通の人には限度がありますよね。忘れないことより、思い出しやすいということを心がけるしかないのかもしれませんね。よく理解したコーディングを積み重なることしかないのかな。
***本記事にはプロモーションが含まれています。***
グラフィックとウィンドウの話だった。
正直言ってよくわからなかった。ウィンドウを作るうえで、基礎的なことは何でしょう。必要なことは何でしょう。注意することはどういうことなのでしょう。
ウィンドウシステムは、ハードウェアを扱うものとは違ってソフトウェアの自由度が大きいのでしょうけど、基本になることって何でしょうか。
***本記事にはプロモーションが含まれています。***
いろいろ調べていたら、パッチを使わなくてもQCOW/QCOW2が動くことがわかった。気づかないうちにバグが修正されていたみたい。結構一生懸命バグをつぶしてみたんだけどがっくり。でも、勉強になったからいいか。小さな不具合がいろいろあるので、そのパッチを作りました。
バイナリも用意しましたので、興味があれば使ってみてください。
http://www.h6.dion.ne.jp/~kazuw/qemu-win/qemu-20060906-qcow.zip
http://www.h7.dion.ne.jp/~qemu-win/download/qemu-20060906-qcow.patch
***本記事にはプロモーションが含まれています。***
WindowsホストでもQCOW2フォーマットが使えるようになって、VMスナップショットという機能を使うことができます。
loadvm/savevmとQCOW2フォーマットのハードディスクイメージを組み合わせることで、多段階のスナップショットを保存したり、復元したりできるようになります。
これにともなって、QCOW2以外を使用したときのloadvm/savevmの使用は出来なくなりました。
DOS> qemu-img convert -f raw redhat.img -O qcow2 test.qcow2
というように、QCOW2フォーマットのディスクを用意します。
DOS> qemu -L ../pc-bios -hda test.qcow2
で、ゲストOSを起動し、Ctrl-Alt-2でモニターに切り替え、仮想マシンの状態を保存します。
(qemu) savevm test
(qemu) info snapshots
ID TAG VM SIZE DATE VM CLOCK
1 test 4M 2006-09-01 12:00:00 00:00:01.000
Ctrl-Alt-1でゲストOSに戻り、ファイルを作ります。
Guest OS$ echo test >test.txt
Guest OS$ ls
test.txt
Ctrl-Alt-2で、もう一度状態を保存します。
(qemu) savevm test2
(qemu) info snapshots
ID TAG VM SIZE DATE VM CLOCK
1 test 4M 2006-09-01 12:00:00 00:00:01.000
2 test2 5M 2006-09-01 12:01:00 00:00:02.000
すると、IDもしくはTagでファイルを作る前の状態に戻したり、後の状態に戻したりできます。
(qemu) loadvm test
もしくは、
(qemu) loadvm 1
スナップショットを削除するのは、delvmです。
TAGを付け忘れても、それぞれのスナップショットは番号で指定することができます。
また、QEMUの起動時に-loadvmオプションを使うことで、瞬時にゲストOSを起動することも可能です。
DOS> qemu.exe -L ../pc-bios -hda test.qcow2 -loadvm test
使ってみると、結構使えそうです。以前のsavevm/loadvmは、メモリーの状態しか保存しなかったためゲストOSのディスクキャッシュとハードディスクの内容の整合性が問題になったのですが、ハードディスクの内容と一緒に保存され、問題が解消されています。
注意したほうがいいことは、状態を保存せずにloadvmをしてしまうと、それまでやっていた作業が消えてしまうこと。スナップショットの途中で作業を再開すると木の枝みたいに内容が枝分かれになってしまうことなどです。
***本記事にはプロモーションが含まれています。***
-snapshotオプションを使わずに、一時ファイルに名前を付けて使用する方法があります。
まず、RedHatのハードディスクイメージがあるとして、それに対する一時ファイルredhat-tmp.qcowを作ります。フォーマットは、QCOWもしくはQCOW2を選びます。
DOS> qemu-img create -b redhat.img -f qcow redhat-tmp.qcow
その後、作った一時ファイルをハードディスクとして指定してQEMUを起動します。
DOS> qemu -L ../pc-bios -hda redhat-temp.qcow
すると、RedHatが立ち上がります。
変更点は、redhat-temp.qcowに書き込まれますので、ベースファイルredhat.imgは保護されています。
変更を反映したい場合は、QEMUモニターでcommitします。
(qemu) commit hda
名前を付ける利点は、QEMUを終了しても、一時ファイルを指定することで変更点が残ることです。作業を継続することができます。また、元のハードディスクに変更を反映することが出来ます。
***本記事にはプロモーションが含まれています。***
使い方は、
DOS> qemu -L ../pc-bios -hda redhat.img -snapshot
とやると、一時ファイルがC:Documents and Settings(user name)Local SetttingsTempに出来ます。ハードディスクの形式は、RAWフォーマットでもいいです。
作業をやったあと、QEMUモニターで、
(qemu) commit hda
をするまで、ハードディスクイメージには変更したところが書き込まれません。
逆に言うと、commitしないでQEMUを終了してしまうと、変更点がすべて消えてしまいます。
もし、2つのハードディスクを使っている場合は、それぞれ別の一時ファイルが作られます。commit時に、変更点を反映するハードディスクを指定することが出来ます。