一、如何测试驱动器类型
随着pc硬件的高速发展,各种应用软件对外设的要求亦不断提高,这使得有些软件的设计者在开发软件时需要对主机的配套设备进行检查,以便能更好地利用这些设备。如对处理器cpu及协处理器的检测、对驱动器的检测等等。对于上述的测试,除cpu及协处理器的测试方法已有不少文章论述过外,还很少有对驱动器测试的论述。本文将详细介绍如何测试驱动器,并给出相应的子程序源码,读者可根据需要将其变成一独立程序,也可将其加入到自己的应用程序中去。
在提供的测试驱动器子程序中,使用了dos int 21h 的设备管理功能调用 44xxh(ioctl)的两个子功能:ax=4409h 和ax=440dh。通过对what-drv子程序的调用,可得到指定驱动器的类型。该测试子程序的调用方式为:
输入:al=驱动器标号(a,b,c,...)
程序:call what-drv
输出:cf= 0 成功
al= 驱动器类型(提供之源码中有各种类型说明)
ds:dx= device-params读取参数缓冲区,共有32bytes长度
cf= 1失败
ax=错误代码
1.测试指定驱动器状态
本子功能是测试所指定驱动器是否为单机或网络之共享状态输入:ax= 4409h
bl= 0,1,2,...(0=defult,1=a,2=b,3=c,...)
中断:int 21h
输出:cf= 0成功
dx=返回状态(这里仅讨论dx寄存器的bit12,在返回的参数中,dx还有其它许多状态值,本节将不在此讨论)
若bit12=0,则为单机状态
bit12=1,则为服务器共享状态
cf= 1失败
ax=错误代码
2.读取指定驱动器参数
本子功能将读出指定驱动器的各种参数,包括驱动器类型、文件分配表fat大小,根目录root大小,及其它bpb各种磁盘参数。本子程序仅读取驱动器类型参数。
输入:ax= 440dh,
bl= 0,1,2,...(0=defult,1=a,2=b,3=c,...)
cx= 0860h 这里 ch=08h表示磁盘驱动器
cl=60h表示读取驱动器参数
ds∶dx=device-params指向读取参数缓冲区,共有32 bytes长度
中断:int 21h
输出:cf= 0成功
ds∶dx=缓冲区包含读出驱动器参数
cf= 1失败
ax=错误代码
3.磁盘参数区
表1为一130mm 1.2mb的软盘驱动器参数信息(共32字节长度)。
@@08a08600.gif;表1@@
4.测试驱动器源码(程序1)
程序1:
;------------
; check drive type
;input: al=can be any drive letter(a,b,c..)
;output: cf=0 successfully
; al=drive type will be returned as an
; errorlevel.
; ds∶dx=pointer to parameter block
; cf=1 failed
; all registers restored.
;-----------------
; errorlevel result
; --------------
; -1drive isn′t local
; 0320k/360k 130mm.drive
; 11.2m 130mm.drive
; 2720k 90mm.drive
; 3single-density 203mm.drive
; 4double-density 203mm.drive
; 5hard disk
; 6type drive
; 71.44m drive
; 8something else
;------------;
what-drv proc near
push cx ;save registers
push bx
mov bl,al
and bl,lfh ;bl=0,1,2..
mov ax,4409h
;check workstation /server
push bx
int 21h
pop bx
jb what-error ;error to exit
test dh,10h ;test server?
jz what-continue
mov al,-1
jmp short what-exit
what-continue:
mov ax,440dh
mov cx,0860h
;get device paramters
push cs
pop ds
mov dx,offset device-params
int 21h
jb what-error ;error to exit
mov al,[device-params+1]
;get device type
what-exit:
clc ;successfully flag
what-error:
pop bx ;recover registers
pop cx
retn
what-drv endp