懐かしのMS-DOSプログラミング [sc](★0)
-
- 1
- 2010/04/21(水) 12:42:23
-
mov dx,offset msg
mov ah,9
int 21h
mov ax,4c00h
int 21h
msg db '懐かしのDOS時代のプログラミングについて語ろうぜ',0dh,0ah,'$'
-
- 230
- 2011/04/13(水) 12:22:28.78
-
exit(n)を使ってれば、voidだろうが問題なし。
-
- 231
- 2011/04/13(水) 12:31:23.18
-
gccだとexit(n)使っていようが警告出るけどな
C言語の仕様ではintが正しいらしいがMS-DOSならどっちでもいいのでは?
「void main MS-DOS」で検索したら2番目にこんなページが出てきた
http://homepage3.nifty.com/aokura/phoebe/minitips.html
> 3. void main() と int main()
>
> 古い参考書では void main() が多く、新しいものでは int main() が多いようです。
> 個人で学習する範囲においては、return する値に特に意味を持たせる
> (他のプログラムやバッチ処理で利用する)つもりがなく、
> コンパイラがエラーにならないのであれば、別にどっちでもよいように思います。
> ただし、void main() にしたときは値を返さず、int main() にしたときは必ず値(0でよい)を
> 返しましょう。それが理解できていれば支障はないでしょう
> (ちなみに、私は int main() を使っています)。
-
- 232
- 2011/04/13(水) 12:37:47.02
-
exit(n)なりmainのreturn値なりがどういう意味を持つのか
分かってない奴が、混じってるように見える。
-
- 233
- 2011/04/13(水) 12:42:10.33
-
>>232
そのへんはコンパイラが吐き出すコード見れば問題ないことがわかる
voidを指定あってもコンパイラはちゃんと0を返すコードを吐き出してる
-
- 235
- 2011/04/13(水) 12:42:37.14
-
OSの違いとコンパイラの違いの区別がつかないのもいるな
-
- 236
- 2011/04/13(水) 12:43:14.56
-
>>229
AXじゃなくてALだよ
-
- 237
- 2011/04/13(水) 12:52:21.59
-
つまりこういうことですねわかります
#include <stdio.h>
int main(int, char **){
return printf("Hello Work!\n");
}
-
- 238
- 2011/04/13(水) 12:52:59.69
-
「void main MS-DOS」の検索でこんなページも出てきた
http://www.asahi-net.or.jp/~yf8k-kbys/int2.html
> 私の知る限りではMS-DOSとUNIXがプログラムの戻り値を
> バッチやシェルスクリプトで利用することができます。
> ちなみにMS-DOSやUNIXでvoid main()とすると、
> まともなCコンパイラなら自動的にMS-DOSやUNIXに終了コードとして
> 0を返すコードを生成してくれます。
> つまりint main(){ return 0; }と同じことです。
> でも、ANSIに極力準拠するよう作られているGCCなどはvoid main()にすると
> コンパイル時に警告エラーが表示されるはずです。
>
> もともとC言語はUNIX環境での利用を非常に意識して作られた言語なので
> 戻り値がintである必然性もうなずけます。
> 何せUNIXのシェルスクリプトが強力なので複数のプログラム
> (ツール的なものが多いです。ファイルをソートしてマージして加工して...など)を
> 一括処理させることが多いのです。この様なシェルスクリプトにおいて、
> あるプログラム処理中にエラーが発生したときは、シェルの処理を中断したいことがあります。
> このトリガがmain()関数の戻り値と言うわけです。
>
> そういえば、「main()関数の戻り値はintじゃなきゃ駄目だ!」と断言する方の多くは
> UNIX(Linux)ユーザですね。
> そして「別にvoidでもいいでしょ」と言う方の多くはWindowsのC++ユーザです。(^^;
-
- 239
- 2011/04/13(水) 13:48:01.32
-
>>234
小学生みたいで微笑ましいが、まさか突っ込んだつもり?
-
- 240
- 2011/04/13(水) 18:02:38.45
-
DOS3.1時代FDD環境でお世話になったLattice C パーソナル。
int mainのreturnでなにを返してもリターンコードは0になってたな。
-
- 241
- ◆0uxK91AxII
- 2011/04/13(水) 19:14:46.75
-
>>226
OSにメモリ割り当てを任せた上で割込駆動するようなのは行えない。
>>236
ahに4cでalに戻り値だね。
-
- 242
- 2011/04/13(水) 19:51:50.04
-
ERRORLEVEL
-
- 243
- 2011/04/14(木) 00:08:37.65
-
comファイルならバイナリエディタでも作れるね
-
- 244
- 2011/04/14(木) 00:28:21.31
-
>>225
make が使えなくなるのですが?
-
- 245
- 2011/04/14(木) 22:12:33.86
-
DOSプログラムを終了させる方法を4つまで覚えてるけど、
まだ他にあったかな。もう思い出せない。
int 21h ah=4ch al=(ExitCode)
int 21h ah=00h
jmp 0
ret
-
- 246
- 2011/04/14(木) 22:41:21.68
-
int 20h
csはpspを指していること。
-
- 247
- 2011/04/15(金) 00:08:40.80
-
psp:0にあるのはcdh, 20h。つまりint 20h。
ret命令やjmp 0はint 20hを実行して終わる。
-
- 248
- 2011/04/16(土) 21:45:40.90
-
psp:0へのfar jmpなら、exeファイルであっても
csはpspを指さなければならないという制約をクリアできる。
-
- 249
- ◆0uxK91AxII
- 2011/04/17(日) 00:44:56.79
-
jmp farよりも、xor ax,ax; int 21Hの方が短い気がするする。
-
- 250
- 2011/04/17(日) 17:36:05.08
-
comファイルなら。
exeでもコードセグメントが64kB 1つしかないスモールかコンパクトなら可能
-
- 251
- 2011/04/17(日) 22:25:49.77
-
スモールやコンパクトモデルでもCSはコードセグメントを指してる。
初期値がPSPなのはDS。
-
- 252
- 2011/04/18(月) 18:09:08.49
-
とりあえずこういうことか。CP/M臭い・・
.MODEL SMALL,STDCALL,NEARSTACK
.DATA
PEXIT dd 00000000h
BDOS dd 00000050h
msg db 'hello world !', 0dh, 0ah, '$'
.STACK
.CODE
.STARTUP
mov ax, es
mov word ptr PEXIT[2], ax
mov word ptr BDOS[2], ax
mov dx, offset msg
mov ah, 09h
call BDOS
jmp PEXIT
END
-
- 253
- 2011/04/18(月) 19:55:13.72
-
BDOSエントリは0005hでなかったか?
-
- 254
- 2011/04/18(月) 20:01:59.72
-
CPM-80ではそうだな。
こっちのはDOS独自のCPM互換機能で0x0050で正解。
CP/M-86には無い。
int 21, retfがあるだけ。
-
- 255
- 2011/04/18(月) 22:49:59.27
-
>>251
あー、そうか。
Cの場合pspを指してるのはdsか。
-
- 256
- 2011/04/18(月) 23:05:17.65
-
お前ら何語を話してるんだ?w
-
- 257
- 2011/04/19(火) 05:58:51.81
-
爺共が久々に活性化w
-
- 258
- 2011/04/19(火) 10:11:02.79
-
システムコール呼び出しでcall 50hなんて使ったことないな。
-
- 259
- 2011/04/19(火) 23:59:57.68
-
親プロセス環境へのポインタ(非公開)がpsp:16h辺りにあったような気がする
-
- 260
- 2011/04/21(木) 00:01:51.48
-
親プロセスのPSPのセグメントかな。
PSP:16-17hだったと思う。
-
- 261
- 2011/04/28(木) 11:36:34.33
-
>>218
cd8枚組だっけか
買ったよ
次はDVDで出るかもなんて冊子に書かれてた
-
- 262
- 2011/06/20(月) 22:08:52.71
-
LSI C-86は俺の青春。
何万円もしたCコンパイラが無料で手に入るなんて夢のようだった。
-
- 263
- 2011/06/21(火) 12:43:24.37
-
でもパラメータのレジスタ受け渡しとかやってるのに
吐き出したコードの速度は遅いんだよな。
同じソースで吐き出したコードを比べると
Turbo-C > MS-C >> LSI-C
な感じ。
-
- 264
- 2011/06/22(水) 08:26:38.88
-
LSI-Cの出力したアセンブリリストを加工するsedスクリプトを書いたなぁ。
それだけで数%は速くなった記憶が。
-
- 265
- 2011/06/22(水) 21:09:03.72
-
この時代は何でも出来そうな気がしていた
-
- 266
- 2011/06/26(日) 22:16:55.97
-
>>262
未だに使い続けてる俺
-
- 267
- 2011/07/09(土) 09:57:32.88
-
問題
Turbo-C 2.0のメモリモデルの特徴を表にしてまとめなさい
-
- 268
- 2011/07/09(土) 22:53:18.85
-
MS-Cとほぼ同じだけど、ラージだとスタックはDGROUPの外なのが目立ったな。
ヒュージだとDGROUPそのものが存在しない。
-
- 269
- 2011/07/12(火) 22:14:03.78
-
その時代のMS-Cには、タイニーモデルはまだ存在してなかったね。
-
- 270
- 2011/07/30(土) 13:03:37.64
-
【OS】MS-DOS、誕生から30年に [11/07/28]
http://toki.2ch.net/test/read.cgi/bizplus/1311974777/
-
- 271
- 2011/07/30(土) 23:43:10.44
-
もう30年も経つんだな。
QDOSとかSCPとか懐かしい言葉だ。
DOS誕生の経緯は「MS-DOSエンサイクロペディア」に詳しく書かれてたけど、今でも持ってる。
-
- 272
- 2011/09/01(木) 19:37:33.24
-
ぐぐっても見かけないからここにこっそり書き残しておこう
tasm32のparity?の生成コードはmasm等の逆
-
- 273
- 2011/09/01(木) 22:21:02.45
-
ボーランドはアンチMSだったからな。
Turbo-Cのマウス制御関数の説明に、
「Microsoft形式のマウスには対応しておりません」
とキッパリ書いてある、なんてこともあった。
-
- 274
- 2011/09/01(木) 22:35:37.48
-
そりゃマウスドライバの話だべ
-
- 275
- 2011/09/02(金) 00:27:18.69
-
mouse.comとmouse.sysか
mouse.comのほうが見た目良かったんだが、再配布禁止だったからなあ…
-
- 276
- 2011/09/02(金) 00:48:57.49
-
ソフト側ではどちらでも動くように作れてたような気がするし
ADDDEVなどで切り替えたりしてたような気もするし
今となってはどうでもいい小手先か
-
- 277
- 2011/09/02(金) 01:15:19.43
-
>>276
基本同じなんだが、困ったことに微妙に違う所があったりした
俺はそのへんめんどいので自前ドライバを使ってたが
-
- 278
- 2011/09/03(土) 18:06:47.28
-
>>195
IBM-DOS2000買うとか?(CDで売ってた)
多分まだ売ってるはず
-
- 279
- 2011/10/08(土) 19:32:22.10
-
power.exeってMS-DOSの処理が空いている時にhalt命令で消費電力を
下げるらしいですが、ユーザープログラムでこの「空いてる状態」を
作り出すにはどうしたらよいでしょうか?
(C言語ならgetch()すればいい?)
-
- 280
- 2011/10/09(日) 00:53:11.24
-
>>279
haltからの復帰には例外が必要。
自動的に復帰させるためには、haltさせる前に、復帰させるための例外を用意してやる必要がある。
タイマなんかを使うんでは無いかな。
このページを共有する