From 772897c8f506ed2ca5fd7a1cd90cab0e8231f0a6 Mon Sep 17 00:00:00 2001 From: nmlgc Date: Fri, 1 Nov 2019 09:41:15 +0100 Subject: [PATCH] [th03] Identify ZUNSP.COM as a rebrand of Promisence Soft's SPRITE16.COM driver MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Which was actually found out by @m1yur1 last year, who thankfully tweeted this in reference to ReC98: https://twitter.com/m1yur1/status/1018855232371998720 Thanks a lot! But what makes this more than a piece of trivia is the fact that the StormySpace release actually *was* bundled with documentation. Shoutout to the Neo Kobe PC-98 collection for preserving the original release! This should now greatly simplify any RE efforts related to TH03's INT 42h calls. (Not *trivialize*, because there's still all this EGC hardware to be understood…) And sure, you *were* allowed to use this driver in your own game, but replacing the copyright with your own isn't exactly the nicest thing to do… That now makes three library programmers that ZUN didn't credit. Makes me wonder what makes M. Kajihara so special. Probably the fact that Touhou has always been about the music for ZUN, first and foremost. Part of P0056, funded by rosenrose and [Anonymous]. --- README.md | 3 +- build32b.bat | 2 +- th03_zunsp.asm => libs/sprite16/sprite16.asm | 30 +- libs/sprite16/sprite16.doc | 312 +++++++++++++++++++ 4 files changed, 339 insertions(+), 8 deletions(-) rename th03_zunsp.asm => libs/sprite16/sprite16.asm (98%) create mode 100644 libs/sprite16/sprite16.doc diff --git a/README.md b/README.md index 3a68974b..7f9fac11 100644 --- a/README.md +++ b/README.md @@ -45,7 +45,8 @@ It certainly *seems* to be. During the development of the static English patches * [master.lib](http://www.koizuka.jp/~koizuka/master.lib/), a 16-bit x86 assembly library providing an abstraction layer for all components of a PC-98 DOS system * as well as the Borland C/C++ runtime library, version 4.0. -* Additionally, TH01 includes the [Pi loader library by 電脳科学研究所/BERO](http://www.vector.co.jp/soft/dos/prog/se037608.html). +* Additionally, TH01 includes the [Pi loader library by 電脳科学研究所/BERO](http://www.vector.co.jp/soft/dos/prog/se037608.html), +* and TH03's `ZUNSP.COM` (accessible via `ZUN.COM -4`) is a rebranded version of Promisence Soft's `SPRITE16.COM`, a 16-color PC-98 EGC display driver, version 0.04, which was bundled with the sample game *StormySpace*. The two main libraries make up a sizable amount of the code in all the executables. In TH05, for example, they amount to 74% of all code in `OP.EXE`, and 40% of all code in `MAIN.EXE`. That's already quite a lot of code we do not have to deal with. Identifying the rest of the code shared across the games will further reduce the workload to a more acceptable amount. diff --git a/build32b.bat b/build32b.bat index 8209cbb6..a9b6dce1 100755 --- a/build32b.bat +++ b/build32b.bat @@ -18,7 +18,7 @@ if errorlevel 9009 goto no_tasm32 %ReC98_ASM% th02_main.asm bin\th02\main.obj %ReC98_ASM% th02_maine.asm bin\th02\maine.obj -%ReC98_ASM% th03_zunsp.asm bin\th03\zunsp.obj +%ReC98_ASM% /DTHIEF libs\sprite16\sprite16.asm bin\th03\zunsp.obj %ReC98_ASM% th03_res_yume.asm bin\th03\res_yume.obj %ReC98_ASM% th03_op.asm bin\th03\op.obj %ReC98_ASM% th03_main.asm bin\th03\main.obj diff --git a/th03_zunsp.asm b/libs/sprite16/sprite16.asm similarity index 98% rename from th03_zunsp.asm rename to libs/sprite16/sprite16.asm index b2b5c98d..62f935f0 100644 --- a/th03_zunsp.asm +++ b/libs/sprite16/sprite16.asm @@ -1,3 +1,6 @@ +; This is a rebranded version of Promisence Soft's SPRITE16.COM driver, +; version 0.04, which was bundled with the sample game "StormySpace". +; See SPRITE16.DOC for API documentation. ; ; +-------------------------------------------------------------------------+ ; | This file has been generated by The Interactive Disassembler (IDA) | @@ -41,7 +44,7 @@ aSprite16 db 'SPRITE16',0 sub_10C proc near cld - push offset aZunsp_comVersi ; "ZUNSP.COM Version 1.00 Copyright(C) "... + push offset aHeader call sub_676 push es mov ax, 0 @@ -104,7 +107,7 @@ loc_161: ; --------------------------------------------------------------------------- loc_186: - push offset aUsageZunspZPat ; "Usage: ZUNSP -z (풓)\r\n "... + push offset aUsage call sub_676 mov ax, 4C01h int 21h ; DOS - 2+ - QUIT WITH EXIT CODE (EXIT) @@ -2053,10 +2056,25 @@ word_F43 dw 0 word_F45 dw 0 aGbgvgkvkslvsvV db '܂B',0Dh,0Ah,0 aPatuvVVVBbInt0 db '풓܂B(int %02Xh)',0Dh,0Ah,0 -aZunsp_comVersi db 'ZUNSP.COM Version 1.00 Copyright(C) 1997 ZUN ',0Dh,0Ah - db 0Dh,0Ah,0 -aUsageZunspZPat db 'Usage: ZUNSP -z (풓)',0Dh,0Ah - db ' -r ()',0Dh,0Ah,0 +aHeader label byte + +ifdef THIEF + + db 'ZUNSP.COM Version 1.00 Copyright(C) 1997 ZUN ',0Dh,0Ah + db 0Dh,0Ah,0 +aUsage label byte + db 'Usage: ZUNSP -z (풓)',0Dh,0Ah + +else + + db 'SPRITE16.COM Version 0.04 Copyright(C) 1996 PromisenceSoft',0Dh,0Ah + db 0Dh,0Ah,0 +aUsage label byte + db 'Usage: sprite16 -z (풓)',0Dh,0Ah + +endif + + db ' -r ()',0Dh,0Ah,0 aZ db '/Z',0 aR db '/R',0 aV db '/V',0 diff --git a/libs/sprite16/sprite16.doc b/libs/sprite16/sprite16.doc new file mode 100644 index 00000000..472a4311 --- /dev/null +++ b/libs/sprite16/sprite16.doc @@ -0,0 +1,312 @@ +------------------------------------------------------------------------------- + + EGCを使った16色スプライトドライバ + + SPRITE16.COM Version 0.04 + Copyright(C) 1996/3/14 Promisence Soft + +------------------------------------------------------------------------------- + +_/SPRITE16.COMとは? + + ・VRAMの下をスプライト領域として使用するEGCによる16色スプライトドライバです。 + ・初めに常駐させて他のプログラムからファンクションを呼んで実行します。 + ・386以上のEGC搭載の98および互換機のDOS環境で動作します。 + ・ベクタは42Hを使用しますがそれ以外を使うこともできます。 + +_/SPRITE16.COM の開発経緯 + 「PromisenceSoft」がパソコン通信上で流した「SKASH BoM!」や「The Star Strik +er」などといった、一連のシューティングゲームはユーザーが楽しんでそれで終わり・・・の筈でし +た。ところが、作り手にとっては思いもよらぬ意外な反応が、配布先のユーザーの間で +は起こっていたのです。 +「パソコン通信やってる友達を通して入手したんですけど、98でスプライトをどのように?」 +「隠しI/Oポートかなんかでパターン高速転送機能でもあるんですか?」 +などといった、単なる遊び手としての楽しみにとどまらず、作り手としての積極的な +挑戦を試みる方々が郵便、電話を通して大変多くの質問をいただきました。 + +趣味でプログラミングを楽しむ日曜プログラマーでも、簡単に扱えるスプライト・・・むろん、 +ゲームを作るのにスプライトが必要というわけでもないのですが、これが使えるか +否かで、趣味の範囲内でも、表現できる幅もぐっと広がるのではないか?ということで +「PromisenceSoft」からこの度、スプライト常駐ドライバとして開発、公開されました。 + +当初、ライブラリ配布・・・としての形態を構想していたのですが、256色環境(PC/AT,9821) +にも対応するべく、常駐ドライバという形態で公開しました。 + +さて、時代は Microsoft自ら徹底的に整備したGameAPIによるWin95ゲーム環境が +主流になることは火を見るよりも明らかです。そして、「PromisenceSoft」としても +「The Star Striker for Win95」などのシューティングの開発も進めており、完成、公開 +に向けて精進しております。にもかかわらず、このような時期に DOS ベースのゲーム開発 +ドライバを公開した理由は、それなりのわけがあります。それは、現行マシン上での +Direct Draw を通した画像処理性能の思ったよりも低い性能・・・です。 +そして、さらに深刻な問題が、ユーザーのパソコン普及状況です。とあるネット(ZOB-Station) +でのPromisence Soft のサポートノートで実施した保持マシンアンケートや、TAKERU での保有機種 +アンケートを吟味するかぎり、満足のいくゲームを、Win95上でDOSと同等のQualityで仕上げ +るのには非常に困難な状況に直面していることを確認しました。ご参考までに、ZOB- +Stationは開発関係の方々が非常に多く、積極的なパソコンユーザーが大変多い・・・にも関ら +ずです。Win95上でのゲーム環境の快適さはビデオボードの性能に大きく依存するわけです +が、重要なのはこれらゲーム専用ボードがない状況では、ゲームアプリの快適さは極端に落ちる +のにビジネスアプリはほぼ通常どおり快適に動いてしまう・・・という点です。 +パソコンゲームユーザー層のほとんどが、仕事のついでにゲームで一息入れる・・・という方々が +ほとんどなので、これらゲーム専用ビデオボードが「生活必需品」でないことを考慮すると、雑誌などで騒がれているほど急速な普及は少々考えられにくい状況です。 +とりあえず、オール1パソコンのような一体型パソコンを買えばいつの間にか高性能ビデオボード +も付いてくる・・・という状況が半年以上続くまでは「本格的な普及」と呼べないので +それまでは、「PromisenceSoft」としては DOS ベースの 16,256色ゲームも WIN95と +並列して公開していく予定です。 + +ちなみに、320*200*8Bit という画像モードでの DOS ベーススプライトドライバも公開予定なの +ですが、かなり高スペックなPCのWin95上での同画像モードのスペックと比較しても、 +遜色がないばかりか圧勝します。これは、実際の測定結果を元にした比較なのですが、 +ここでは測定数字を羅列するよりも、スプライトドライバを通して実際に動くゲームを遊んで +いただいた方が、理解しやすいと思いますので敢えて載せないことにします。 + +よく、広告やカタログなどに 秒間xxxxピクセル!!なんて性能表示が出てますね。 +では、次の数字は何のスペックを意味するでしょうか? + + 4 Bitカラー 秒間 245,760 ピクセル合成表示可能!! + +これは、何のマシンのスペックでしょう? +実は、コレ、1983に発売された旧ファミコンのスプライト機能の性能値です。 +全く数字だけでは見当がつきませんね(^^) + +もちろん、現在発売されているビデオボードは表示方法こそ違え、上とは全く比較に +ならないスペックを持っているわけですが、カタログに載っているポリゴン描画機能数値や +ピクセル数を「x十万」といわれてもピン!ときません。 + +やはり、「どのようなゲームが動いているか」にユーザーの焦点が集まります。 +是非、サンプルゲーム「StormySpace」を通して吟味してみてください。 +なお、本ゲーム(正確にはスプライトドライバ)は、御持ちのマシンのVRAM性能に著しく +依存します。ですから、286や386ベースのパソコンに486(50,66MHz)相当のチップに載せ変え +ても、その効果は全く期待できませんので予めご了承ください。 + + +_/使い方 + + sprite16 -z ・・・・ 常駐(ディフォルトベクタ 42H 使用) + sprite16 -r ・・・・ 解放 + + もし他のベクタ 50H を使用する時は以下のようにします。 + + sprite16 -v 50h -z ・・・・ 常駐(ベクタ 50H 使用) + sprite16 -v 50h -r ・・・・ 解放 + + 常駐するとメインメモリにマスクデータ用バッファ(16000バイト)とベタデー + タ用バッファ(16000バイト)の合計32000バイトのメモリを確保しコード + を含めて約36Kバイトを消費します。 + + +_/常駐チェック方法 + + ベクタ42hから読み出したセグメント値:オフセット102Hのアドレスから8バ + イト分が "SPRITE16" の文字列であれば常駐しています。文字列の次は00h固定で + す。そして00hの次にバージョン番号があります。バージョン1.23ならば10 + 進数の123になっています。 + + +_/ファンクションについて + + ファンクション番号はAHに指定し、引数は他のレジスタに格納します。 + 全てのファンクションは全ての汎用レジスタを保護します。 + 全てのファンクションに戻値はありません。 + 内部では割込み許可になっています。 + + ファンクションは、 + + %ファンクション0 VRAM加工 + %ファンクション1 マスクデータ作成 + %ファンクション2 スプライト表示 + + %ファンクション3 単色表示ON/OFF設定 + %ファンクション4 単色表示カラー設定 + %ファンクション5 マスク(AND)処理ON/OFF設定 + %ファンクション6 EGC-アクセスプレーン設定 + %ファンクション7 EGC-ROP設定 + %ファンクション8 EGC-MASK設定 + + %ファンクション9~16 予約 + + これだけあります。 + 最初に一度だけ0と1のファンクションでスプライトを準備しファンクション2で + 表示します。重要なのはこの3つのファンクションだけです。 + この他にも、VRAM一括32Bit消去・・・など重要なファンクションが必要なのですが、現時点で + は装備されておりません。 + また、ラスタースクロール、上下反転表示、縦方向拡大、特殊ラスター加工機能・・・などが、 + 9~16に配置される予定です。 + + 次にそれぞれの詳しい解説をします。 + 文章中のONは0以外の整数でOFFは0とします。 + それとベタデータとはマスクデータを反転したデータという意味で使っています。 + +------------------------------------------------------------------------------- +%ファンクション0 VRAM加工 + + プログラマ側が何らかの方法でVRAM400ラインに用意したグラフィックデータ + をファンクション1のマスクデータ作成に備えて200ライン用に加工します。加工 + 内容は、まず表400ライン分のデータを縦半分に圧縮し、それを下200ライン分 + にコピーし、さらに裏下200ライン分にコピーします。プログラムで裏ページを使 + わない場合はこの裏下200ライン分にコピーする作業は無駄に終わる事になります + が、普通は表裏ページを切り替える方法と取ると思われるので裏にもコピーしていま + す。 + 次にファンクション1でマスクデータを作成してください。 + + 自分でVRAM加工するか200ライン用に既に加工済みのグラフィックデータを直 + 接ローダー等でVRAMの表下にロードした場合などはこのファンクションを使う必 + 要はなくファンクション1を最初に実行してください。 + (グラフィックエディッターの都合上、400ラインでしか絵データを編集できない時など + に使用します。) + +------------------------------------------------------------------------------- +%ファンクション1 マスクデータ作成 + + 表下200ライン分のグラフィックデータからマスクデータをメインメモリ上のバッ + ファに取り込みます。またマスクデータを反転したベタデータもメインメモリのバッ + ファに作成します。(実際は4プレーンを全てORしたベタデータが先に作成される) + スプライト表示ファンクションを実行する前に1度実行しておいてください。 + + 400ライン用のグラフィックデータを使う場合はあらかじめファンクション0で + 200ライン用に変換したグラフィックデータを表下に作成しておいてからこのファ + ンクションを実行してください。 + +------------------------------------------------------------------------------- +%ファンクション2 スプライト表示 + + ファンクション1で取り込んだマスクデータとVRAMの下200ラインにあるスプ + ライトデータを使ってVRAMの上200ラインに指定サイズのスプライトを表示し + ます。このファンクション内ではEGCのON、OFFはまったく行いません、その + ため、あらかじめEGC拡張モードONにしておいてから実行してください。 + (EGCのON、OFFはかなりのオーバーヘッドがあるためこのような仕様にしました) + + 引数は以下の通りです。 + +  DX 表示X座標 (画面内:0~639) +  BX 表示Y座標 (画面内:0~199) +  DI 転送元オフセット(0~15998) +  AL Xサイズ (1:16ドット 2:32ドット 3:48ドット・・・) +  CX Yライン数 (1~200) + + それぞれの値の正当範囲チェックは行っていません。だからもしXサイズやライン + 数に0を指定するとVRAMが破壊されるので注意してください。 + + 座標はドット単位で指定します。画面では左上が(0,0)です。 + X,Y座標の比は400ラインで見るとX:Y=1:1ですが200ラインで見ると + X:Y=1:2になります。これは実行直前にY座標を半分にすれば200ラインで + もX:Y=1:1になります + + 上下はクリッピングしているのではみ出してもかまいません。例えばスプライトの縦 + ライン数が100でY座標が-60なら40ライン分が画面に表示されます。 + 横方向はクリッピングしていません。X座標の範囲チェックは完全にプログラマ側に + 任せております。 + + ALに指定する値はXドットサイズ/16の値を指定します。 + 例えば16ドットならば1を、32ドットならば2を指定します。 + + CXに指定するライン数は実際の表示ライン数を指定します。 + だから200ラインモード時見かけ上32ラインならその半分の16を指定します。 + + C言語であれば + + #define XSIZE16 (16/16) + #define XSIZE32 (32/16) + #define XSIZE64 (64/16) + + #define YSIZE16 (16/2) + #define YSIZE32 (32/2) + #define YSIZE64 (64/2) + + こんな風にテキスト定義しておくと分かりやすいと思います。 + + DIには転送元スプライトパターンを指定します。 + VRAM下200ラインに格納されているスプライトの左上のオフセットを指定する + のですがこの時、重要なのが転送元オフセットは必ず偶数アドレスから始まらなけれ + ばならないということです。予めスプライトパターンの横の配置を16ドット単位に + しておけば問題ありません。 + 任意のオフセットを指定可能なので、前景物から徐々に姿を表す・・・といった + 場面でも無理なく表現できます。 + + (なお、この転送元スプライト設定方法は、98VRAMの構成に影響を受けておりますが + 256色版スプライトドライバでも、このファンクションをサポートします) + +------------------------------------------------------------------------------- +%ファンクション3 単色表示ON/OFF設定 + + ディフォルトはOFFですがDXに1を指定してコールすると単色表示モードONに + なり、次のスプライト表示からスプライトが1色で表示されるようになります。 + この1色(パレット番号)はファンクション4で設定できます。 + + 単色表示ではマスクを行う必要がないため通常よりかなり高速です。 + (高速化度は機種依存) + +------------------------------------------------------------------------------- +%ファンクション4 単色表示カラー設定 + + このファンクションで指定した色番号がスプライト単色表示の色に使用されます。 + + 設定方法はDXにパレット番号0~15を入れて実行します。 + ディフォルトはパレット番号15に設定しています。 + 256色版スプライトドライバでは、パレット番号は0~255が有効になります。 + +------------------------------------------------------------------------------- +%ファンクション5 マスク(AND)処理ON/OFF設定 + + 通常スプライト表示ではマスク(AND)処理をしてからOR転送しますが + OFFにすると、マスク処理を省略します。 + + ディフォルトはONです。 + 単色描画モードONの時はマスクする必要が無いので強制的にマスクは省略されます + 引数はDXに指定します。 + +------------------------------------------------------------------------------- +%ファンクション6 EGC-アクセスプレーン設定 + + スプライト表示時にEGCの04A0hに出力するアクセスプレーンの設定です。 + ディフォルトは4プレーン同時アクセスのFFF0hです。 + 引数はDXに指定します。 + なお、256色スプライトドライバではこのファンクションは未定義になります。 + +------------------------------------------------------------------------------- +%ファンクション7 EGC-ROP設定 + + 通常スプライト表示時にEGCの04A4hに出力するROPの設定です。 + ディフォルトは28FCh(VRAM間OR転送)になっています。 + 引数はDXに指定します。 + なお、256色スプライトドライバではこのファンクションは未定義になります。 + +------------------------------------------------------------------------------- +%ファンクション8 EGC-MASK設定 + + スプライト表示時にEGCの04A8hに出力するマスク値の設定です。 + ディフォルトはFFFFhですがAAAAhに変更すると薄暗い感じで表示されます + 引数はDXに指定します。 + 256色スプライトドライバでもMASK機能としてはサポートされます。 + +------------------------------------------------------------------------------- + + +以上、現バージョンのスプライトドライバの機能紹介でした。 +この他にも、上下反転表示、縦方向拡大、特殊ラスター加工機能・・・などの機能を +盛り込み、Cで手軽に使用可能になるべくヘッダファイルの添付、サンプルソース、および +最適化済みスプライトドライバ全ソースのセットを「最光速スプライトドライバ for 16Color」として +シェアウェア公開する予定です。 + +何か問題点、疑問点などがございましたら御連絡ください。 + + +_/著作権など + +当スプライトドライバおよび付属サンプルゲーム「StormySpace」の +著作権は「PromisenceSoft」にあります。 +他人への譲渡、コピーは自由ですが、他ネットへの転載は事後でもよろしい +ので御報告お願いします。 + + + 池田 晃(A.Ikeda) + Nifty MHF03553 + PC-VAN LRD16898 + + 葛目元公(Mocky) + Nifty PXM05370 + 東京BBS MOTOKIMI + ZOB ZOB15200 + + EXJ_Z + ZOB ZOB18245 + \ No newline at end of file