Author: Dale Roberts, Direct I/O and Windows NT
Here are two helpful hints to get you going with GIVEIO. The first
section below mentions the INSTDRV utility that is provided with the
Microsoft DDK. If you do not have access to the DDK, you can use Paula
Tomlinson's program LOADDRV instead. She describes it in her May 1995
article in Windows/DOS Developer's Journal (now Windows Developer's
Journal). You can get the program from their FTP site at:
ftp://ftp.mfi.com/pub/windev/1995/may95.zip.
------------------------------------------------------------------
Device Driver Installation Made Easy
The Microsoft NT Device Driver Kit documentation implies in several
places that there are several steps involved in installing a device driver
and making it accessible to a Win32 application. It explains that you
should edit the registry manually and then reboot the system. But
device drivers are dynamically loadable and unloadable in NT, and the
DDK comes with a very handy utility called INSTDRV that
demonstrates this facility in a very practical manner.
INSTDRV is a console application that will register, load, and start a
kernel mode device driver. It does not require you to edit the registry
manually or reboot the computer. On the command line you simply
give the name of your device driver and the complete path to the .SYS
file (which does not need to be in the system's DRIVERS directory).
After this command is executed, you will find that the driver has been
registered with the system and appears in the Devices applet in the
control panel. If you give the word remove instead of the path, the
driver is removed from the system and taken out of the driver database.
Once the driver is loaded and started, you can use the control panel's
Devices applet to start and stop it, or you can use the net start and net
stop commands (these are much faster) from a console window. When
a kernel mode device is stopped, it is in also unloaded from memory.
The next time you start the device, a fresh copy of the driver is read
from the hard drive, if it has been modified. This makes it very
convenient to develop device drivers, since you can go through the
modify, stop, start cycle repeatedly without ever needing to reboot. If
you need your driver to load at boot time, you can go into the Devices
applet and change its startup mode to boot.
The other component that is needed to make the driver visible to user
mode applications, so they can use CreateFile() calls to access the
driver, is registering the name in the DOS Devices name space. This
can be done, as documented in the DDK, by editing the registry
manually and rebooting. Or, much more simply, the kernel mode
driver can call the IoCreateSymbolicLink() function to register the
name itself. The GIVEIO driver shown in Listing Four uses the later
technique. Once the name is registered, user mode applications can get
a file handle to the device driver by calling CreateFile() with the driver
name as the file parameter, but preceding the driver name with the
special cookie \\.\. The TESTIO application in Listing Five uses this
technique.
------------------------------------------------------------------
Quick Trick: Using DEBUG With Port I/O
Sometimes you just need to do a quick I/O operation to a port. In DOS,
you could use the DEBUG program to accomplish this. In NT, once
you have the GIVEIO device driver up and running, you can once
again use DEBUG for port I/O. If you look at the source code for the
test application, you'll see that all it does is open and close the GIVEIO
device driver. It uses the special cookie \\.\ before the driver name in
order to access it. Without modifying DEBUG, you can have it open
this device driver by simply typing debug \\.\giveio in an NT console
window. You will get an error message complaining that the file
\\.\giveio is not found, but it will give DEBUG I/O access anyway.
Subsequent DOS applications that are run from this console window
will also have I/O access.
WIN32 applications executed from this console window will still cause
exceptions. This is because DEBUG (and any other DOS application)
runs in the context of the VDM (Virtual DOS Machine) process of the
console box, whereas each WIN32 application gets its own process.
The VDM process stays active as long as the console window is open,
but each WIN32 application creates a brand new process with the
IOPM offset initialized to point beyond the end of the TSS.
没有合适的资源?快使用搜索试试~ 我知道了~
SJF2440源码(VC工程源码,官方发布)
共60个文件
c:13个
obj:10个
h:9个
4星 · 超过85%的资源 需积分: 9 22 下载量 8 浏览量
2009-02-28
03:16:07
上传
评论
收藏 602KB ZIP 举报
温馨提示
SJF2440通过JTAG烧写S3C2440的NANDFLASH。为官方发布的SJF2440的VC工程源码。
资源详情
资源评论
资源推荐
收起资源包目录
SJF2440_rev10.zip (60个子文件)
S3C2440_jtag_buf.bsd 40KB
sjf2440_v1.pdf 116KB
2440loader.bin 4KB
SJF2440
mem_rdwr.h 1KB
strata32.h 111B
am29f800.c 6KB
ppt.h 516B
pin2440.h 6KB
SJF2440.dsw 539B
am29f800.h 110B
sjf2440.h 123B
SJF2440.plg 5KB
SJF2440.dsp 5KB
k9s1208.h 98B
Def.h 243B
Debug
sjf2440.obj 18KB
vc60.pdb 68KB
pin2440.obj 12KB
SJF2440.ilk 224KB
vc60.idb 49KB
mem_rdwr.obj 43KB
am29f800.obj 13KB
jtag.obj 12KB
ppt.obj 12KB
k9s1208.obj 25KB
strata32.obj 13KB
SJF2440.pch 195KB
SJF2440.exe 208KB
SJF2440.pdb 433KB
jtag.c 8KB
pin2440.c 8KB
strata32.c 11KB
SJF2440.opt 57KB
SJF2440.ncb 97KB
jtag.h 985B
sjf2440.c 5KB
k9s1208.c 14KB
mem_rdwr.c 24KB
ppt.c 1KB
SJF2440.exe 208KB
u2440mon.bin 35KB
GIVEIO
giveio.INI 195B
GIVEIO.zip 48KB
giveio.inf 2KB
GIVEIO.SYS 2KB
Giveio
POKEIO.C 2KB
TOTALIO
OBJ
_OBJECTS.MAC 254B
I386
TOTALIO.OBJ 1KB
TOTALIO.C 4KB
I386
FREE
TOTALIO.SYS 2KB
MAKEFILE 267B
SOURCES 97B
POKEPROC.C 652B
TSTIO
TSTIO.OBJ 33KB
TSTIO.C 2KB
TSTIO.EXE 33KB
README.TXT 5KB
GIVEIO
OBJ
I386
I386
FREE
MAKEFILE 267B
SOURCES 95B
GIVEIO.C 6KB
共 60 条
- 1
ghent
- 粉丝: 0
- 资源: 5
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 【学生课程实验】基于Vue + Node的外卖系统设计与实现【源码+lw+部署文档+讲解】
- 大学生数学建模竞赛论文(长江水质的评价和趋势分析模型)II.zip
- WIN10安装S7-200 SP9不能通讯解决方案
- FreePic2Pdf-v5.01 图片批量转换pdf/双层pdf 书签提取/导入
- 基于区块链的信息追溯系统的设计与实现+详细文档+全部资料(高分毕业设计).zip
- IMG_0796.PNG
- Hyper+Lightning5+SDXL大模型比较推荐
- 基于matlab 模糊神经网络的预测算法-嘉陵江水质评价源代码+详细教程
- PHP8 PDO MYSQL示例
- 毕业设计 基于区块链以及人脸识别的NFT交易系统源码+详细文档+全部资料(高分项目).zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论1